Base44 Coder
Créez des applications sur la plateforme Base44 avec le SDK JavaScript Base44.⚡ ACTION IMMÉDIATE REQUISE - À lire en premier
Cette compétence s’active à toute mention de « base44 » ou lorsqu’un dossierbase44/ existe. Ne lisez PAS les fichiers de documentation et ne recherchez PAS sur le web avant d’agir.
Votre première action DOIT être :
- Vérifier si
base44/config.jsoncexiste dans le répertoire courant - Si OUI (scénario projet existant) :
- Cette compétence (base44-sdk) traite la requête
- Implémentez les fonctionnalités avec le SDK Base44
- N’utilisez PAS base44-cli sauf si l’utilisateur demande explicitement des commandes CLI
- Si NON (scénario nouveau projet) :
- Transférez à la compétence base44-cli pour l’initialisation du projet
- Cette compétence ne peut pas aider tant que le projet n’est pas initialisé
Quand utiliser cette compétence par rapport à base44-cli
Utilisez base44-sdk quand :- Construire des fonctionnalités dans un projet Base44 EXISTANT
base44/config.jsoncexiste déjà dans le projet- Des imports du SDK Base44 sont présents (
@base44/sdk) - Écrire du code JavaScript/TypeScript utilisant les modules du SDK Base44
- Implémenter des fonctionnalités, composants ou features
- L’utilisateur mentionne : « implémenter », « construire une fonctionnalité », « ajouter une fonctionnalité », « écrire du code pour »
- L’utilisateur dit « créer une application de [type] » et un projet Base44 existe déjà
- ❌ Initialiser de nouveaux projets Base44 (utilisez
base44-clià la place) - ❌ Répertoires vides sans configuration Base44
- ❌ Quand l’utilisateur dit « créer un nouveau projet/application/site Base44 » et qu’aucun projet n’existe
- ❌ Commandes CLI comme
npx base44 create,npx base44 deploy,npx base44 login(utilisezbase44-cli)
base44-sdksuppose qu’un projet Base44 est déjà initialisébase44-cliest un prérequis debase44-sdkpour les nouveaux projets- Si l’utilisateur veut « créer une application » et qu’aucun projet Base44 n’existe, utilisez d’abord
base44-cli
- SI (l’utilisateur mentionne « créer/construire une application » OU « faire un projet ») :
- SI (le répertoire est vide OU aucun
base44/config.jsoncn’existe) : → Utilisez base44-cli (initialisation de projet nécessaire) - SINON : → Utilisez base44-sdk (le projet existe, construisez des fonctionnalités)
- SI (le répertoire est vide OU aucun
Démarrage rapide
⚠️ CRITIQUE : ne pas halluciner d’API
Avant d’écrire N’IMPORTE QUEL code Base44, vérifiez les noms de méthode dans ce tableau ou dans QUICK_REFERENCE.md. Le SDK Base44 a des noms de méthode uniques. Ne présumez PAS de motifs venant de Firebase, Supabase ou d’autres SDK.Authentification — MAUVAIS vs CORRECT
| ❌ MAUVAIS (halluciné) | ✅ CORRECT |
|---|---|
signInWithGoogle() | loginWithProvider('google') |
signInWithProvider('google') | loginWithProvider('google') |
auth.google() | loginWithProvider('google') |
signInWithEmailAndPassword(email, pw) | loginViaEmailPassword(email, pw) |
signIn(email, pw) | loginViaEmailPassword(email, pw) |
createUser() / signUp() | register({email, password}) |
onAuthStateChanged() | me() (pas de listener, appelez au besoin) |
currentUser | await auth.me() |
Functions — MAUVAIS vs CORRECT
| ❌ MAUVAIS (halluciné) | ✅ CORRECT |
|---|---|
functions.call('name', data) | functions.invoke('name', data) |
functions.run('name', data) | functions.invoke('name', data) |
callFunction('name', data) | functions.invoke('name', data) |
httpsCallable('name')(data) | functions.invoke('name', data) |
Integrations — MAUVAIS vs CORRECT
| ❌ MAUVAIS (halluciné) | ✅ CORRECT |
|---|---|
ai.generate(prompt) | integrations.Core.InvokeLLM({prompt}) |
openai.chat(prompt) | integrations.Core.InvokeLLM({prompt}) |
llm(prompt) | integrations.Core.InvokeLLM({prompt}) |
sendEmail(to, subject, body) | integrations.Core.SendEmail({to, subject, body}) |
email.send() | integrations.Core.SendEmail({to, subject, body}) |
uploadFile(file) | integrations.Core.UploadFile({file}) |
storage.upload(file) | integrations.Core.UploadFile({file}) |
Entities — MAUVAIS vs CORRECT
| ❌ MAUVAIS (halluciné) | ✅ CORRECT |
|---|---|
entities.Task.find({...}) | entities.Task.filter({...}) |
entities.Task.findOne(id) | entities.Task.get(id) |
entities.Task.insert(data) | entities.Task.create(data) |
entities.Task.remove(id) | entities.Task.delete(id) |
entities.Task.onChange(cb) | entities.Task.subscribe(cb) |
Modules du SDK
| Module | Objet | Référence |
|---|---|---|
entities | Opérations CRUD sur les modèles de données | entities.md |
auth | Connexion, inscription, gestion des utilisateurs | auth.md |
agents | Conversations et messages IA | base44-agents.md |
functions | Invocation de fonctions backend | functions.md |
integrations | IA, e-mail, envois de fichiers, API personnalisées | integrations.md |
analytics | Suivre des événements personnalisés et l’activité utilisateur | analytics.md |
appLogs | Enregistrer l’activité utilisateur dans l’application | app-logs.md |
users | Inviter des utilisateurs à l’application | users.md |
asServiceRole.connectors | Tokens OAuth à l’échelle de l’application (service role uniquement) | connectors.md |
asServiceRole.sso | Génération de tokens SSO (service role uniquement) | sso.md |
TypeScript et registres de types
Chaque fichier de référence inclut une section « Type Definitions » avec les interfaces et types TypeScript pour les méthodes, paramètres et valeurs de retour du module. Obtenir entités, fonctions et agents typés : le CLI Base44 génère les types à partir des ressources du projet (entités, fonctions, agents), y compris les augmentations deEntityTypeRegistry, FunctionNameRegistry et AgentNameRegistry, et les intègre à votre projet pour vous fournir autocomplétion et vérification de types sans configuration manuelle. Pour la génération de types, utilisez la compétence base44-cli.
Augmentation manuelle : vous pouvez à la place augmenter les registres vous-même dans un fichier .d.ts ; consultez les sections Type Definitions dans entities.md, functions.md et base44-agents.md.
Installation
Installez le SDK Base44 :@base44/sdk. Installez toujours sans spécification de version pour obtenir la dernière.
Créer un client (applications externes)
Lors de la création d’un client dans les applications externes, utilisez TOUJOURSappId comme nom de paramètre :
appId (string) — l’ID de votre application Base44
Paramètres facultatifs :
token(string) — token utilisateur préauthentifiéoptions(object) — options de configurationoptions.onError(function) — gestionnaire d’erreurs global
Sélection de module
Travailler avec les données de l’application ?- Créer/lire/mettre à jour/supprimer des enregistrements →
entities - Importer des données depuis un fichier →
entities.importEntities() - Mises à jour en temps réel →
entities.EntityName.subscribe()
- Connexion/inscription/déconnexion →
auth - Obtenir l’utilisateur courant →
auth.me() - Mettre à jour le profil utilisateur →
auth.updateMe() - Inviter des utilisateurs →
users.inviteUser()
- Discuter avec des agents IA →
agents(nécessite un utilisateur connecté) - Créer une nouvelle conversation →
agents.createConversation() - Gérer les conversations →
agents.getConversations() - Générer du texte/JSON avec l’IA →
integrations.Core.InvokeLLM() - Générer des images →
integrations.Core.GenerateImage()
- Exécuter du code côté serveur →
functions.invoke() - Besoin d’accès administrateur →
base44.asServiceRole.functions.invoke()
- Envoyer des e-mails →
integrations.Core.SendEmail() - Envoyer des fichiers →
integrations.Core.UploadFile() - API personnalisées →
integrations.custom.call() - OAuth à l’échelle de l’application (compte du builder) →
asServiceRole.connectors.getConnection()(backend uniquement)
- Suivre des événements personnalisés →
analytics.track() - Enregistrer les vues de pages/l’activité →
appLogs.logUserInApp()
Motifs courants
Filtrer et trier les données
Routes protégées (vérifier l’authentification)
Appel de fonction backend
Accès Service Role
UtilisezasServiceRole dans les fonctions backend pour les opérations niveau administrateur :
Frontend vs Backend
| Capacité | Frontend | Backend |
|---|---|---|
entities (données de l’utilisateur) | Oui | Oui |
auth | Oui | Oui |
agents | Oui | Oui |
functions.invoke() | Oui | Oui |
functions.fetch() | Oui | Oui |
integrations | Oui | Oui |
analytics | Oui | Oui |
appLogs | Oui | Oui |
users | Oui | Oui |
asServiceRole.* | Non | Oui |
asServiceRole.connectors (OAuth d’application) | Non | Oui |
asServiceRole.sso | Non | Oui |
Deno.serve() et createClientFromRequest(req) pour obtenir un client authentifié correctement.
Cette page a été traduite à l’aide de l’IA. Pour les informations les plus précises et à jour, consultez la version anglaise.

