Create and deploy functions
Create backend functions as TypeScript files in your project’s functions directory and deploy them withfunctions deploy or deploy. By default the functions directory is base44/functions/, but you can customize the path in your project configuration.
Each function requires its own subdirectory containing two files:
functions
<function-name>
function.jsonc
index.ts
function.jsonc
The configuration file defines the function’s name and entry point:| Property | Description |
|---|---|
name | Unique identifier for the function. Used when invoking via SDK or HTTP. |
entry | The TypeScript file containing the function code. |
index.ts
The code file contains your function logic. Functions must use theDeno.serve() wrapper and return Response objects:
Call functions
Call backend functions from your frontend using the SDK, or via HTTP for webhooks and external integrations.Via the SDK
Usebase44.functions.invoke() to call functions from your frontend. The SDK handles authentication automatically, passing the current user’s credentials to your function.
Via HTTP
Each deployed function gets an HTTP endpoint at:- Webhooks: Receive callbacks from external services like Stripe or GitHub.
- External integrations: Allow other systems to interact with your app.
- Testing: Call functions directly with tools like cURL or Postman.
When calling functions via direct HTTP (like cURL or webhooks), there’s no authenticated user context. Use
asServiceRole for all operations in these cases.Use the SDK in functions
Inside your backend functions, you can access your app’s data, authentication, and integrations through the Base44 SDK. UsecreateClientFromRequest() to create a client from the incoming request.
The authentication context depends on how the function was called:
-
When called via the SDK from your frontend: The user’s authentication is passed through automatically. You can access the current user with
base44.auth.me()and perform operations with their permissions. For admin-level operations, useasServiceRole. -
When called via direct HTTP (cURL, webhooks, external services): There’s no authenticated user, so use
asServiceRolefor all operations.
Connect to third-party APIs
Backend functions are one of several ways to connect to third-party APIs. They’re ideal when you need full control over requests or want to store API keys securely as environment variables.See also
- Project Structure - How functions fit into your project
- functions module - SDK reference for invoking functions
- createClientFromRequest - Creating a client in backend functions
- Connect to third-party APIs - Different approaches for external integrations

