create command creates new projects with all necessary files and configuration. This article describes the Base44 backend project structure and explains what each file and directory does.
Backend project structure
When you create a backend-only Base44 project, the CLI generates this minimal structure:<your-project-name>
base44
.app.jsonc
config.jsonc
.gitignore
<your-project-name>
base44
.app.jsonc
config.jsonc
entities
<entity-name>.jsonc
functions
<function-name>
function.jsonc
index.ts
.gitignore
base44/
Contains all Base44 backend configuration and resource definitions.config.jsonc
Defines your project configuration, including paths to entities, functions, and site hosting settings for full-stack projects. The CLI creates this with just your project name, and you can add more configuration as needed. Your project requires aconfig.jsonc (or config.json) file in the base44/ directory:
| Property | Description | Default |
|---|---|---|
name | Project name (required) | — |
description | Project description | — |
entitiesDir | Path to entities directory | ./entities |
functionsDir | Path to functions directory | ./functions |
site.outputDirectory | Where your built site files are located (required for site deployment) | — |
site.buildCommand | Used only during base44 create for automated deployment | — |
site.installCommand | Used only during base44 create for automated deployment | — |
site.serveCommand | Reference only. Not currently used by the CLI | — |
The
buildCommand, installCommand, and serveCommand properties are included automatically when you create a project from the full-stack template. They’re used only during the initial base44 create flow for automated deployment. You don’t need to specify or modify these properties after project creation. When deploying your site later with site deploy, only outputDirectory is used..app.jsonc
Links your local project to your Base44 app. This file is automatically created by the CLI when you create or link a project.The
.app.jsonc file should not be committed to version control. The CLI automatically creates a .gitignore file that excludes this file.entities/
Directory containing entity schema definitions. Each entity is defined in a separate.json or .jsonc file. Create this directory when you’re ready to define your first entity.
functions/
Directory containing serverless backend functions. Each function requires its own subdirectory with afunction.jsonc configuration file and an index.ts code file.
Function structure:
Each function is organized in its own directory:
functions
<function-name>
function.jsonc
index.ts
sendWelcomeEmail would be called with base44.functions.invoke('sendWelcomeEmail', {...}).
index.ts
The function code using Deno runtime. For example:
- Your function must use the
Deno.serve()wrapper. - Import the Base44 SDK (
npm:@base44/[email protected]) to access your app’s data, authentication, and integrations. - Use
createClientFromRequest(req)to identify the current user and access Base44 services. - Your function must return
Responseobjects, not plain strings or objects.
<your-app-domain>/functions/<function-name>. Deploy with base44 functions deploy.
.gitignore
Prevents files from being committed to version control. Your project starts with this file to prevent.app.jsonc from being committed.

