@base44-preview/cli 0.0.15-pr.93.4af3300 → 0.0.15-pr.95.fb9043c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +138 -42
- package/dist/cli/index.js +3498 -3184
- package/dist/cli/templates/backend-and-client/base44/env.local.ejs +9 -0
- package/dist/cli/templates/backend-only/base44/env.local.ejs +9 -0
- package/package.json +3 -2
- package/dist/cli/templates/backend-and-client/base44/app.jsonc.ejs +0 -9
- package/dist/cli/templates/backend-only/base44/app.jsonc.ejs +0 -9
package/README.md
CHANGED
|
@@ -1,78 +1,174 @@
|
|
|
1
1
|
# Base44 CLI
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
A unified command-line interface for managing Base44 applications, entities, functions, deployments, and related services.
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
- **Create projects** from templates.
|
|
8
|
-
- **Sync** resources defined in local code with your Base44 backend.
|
|
9
|
-
- **Deploy sites** to Base44's hosting platform.
|
|
10
|
-
|
|
11
|
-
To get started, see the full list of commands below or check out the [documentation](https://docs.base44.com/developers/references/cli/get-started/overview).
|
|
5
|
+
**Zero dependencies** - installs in seconds with no dependency resolution.
|
|
12
6
|
|
|
13
7
|
## Installation
|
|
14
8
|
|
|
15
9
|
```bash
|
|
10
|
+
# Using npm (globally)
|
|
16
11
|
npm install -g base44
|
|
17
|
-
```
|
|
18
12
|
|
|
19
|
-
Or run
|
|
20
|
-
|
|
21
|
-
```bash
|
|
13
|
+
# Or run directly with npx
|
|
22
14
|
npx base44 <command>
|
|
23
15
|
```
|
|
24
16
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
## Quick start
|
|
17
|
+
## Quick Start
|
|
28
18
|
|
|
29
19
|
```bash
|
|
30
|
-
#
|
|
20
|
+
# 1. Login to Base44
|
|
31
21
|
base44 login
|
|
32
22
|
|
|
33
|
-
# Create a project
|
|
23
|
+
# 2. Create a new project
|
|
34
24
|
base44 create
|
|
25
|
+
|
|
26
|
+
# 3. Deploy everything (entities, functions, and site)
|
|
27
|
+
npm run build
|
|
28
|
+
base44 deploy
|
|
35
29
|
```
|
|
36
30
|
|
|
37
|
-
|
|
31
|
+
## Commands
|
|
38
32
|
|
|
39
|
-
|
|
40
|
-
- [React](https://docs.base44.com/developers/backend/quickstart/quickstart-with-react) — full-stack with Vite + React
|
|
33
|
+
### Authentication
|
|
41
34
|
|
|
42
|
-
|
|
35
|
+
| Command | Description |
|
|
36
|
+
|---------|-------------|
|
|
37
|
+
| `base44 login` | Authenticate with Base44 using device code flow |
|
|
38
|
+
| `base44 whoami` | Display current authenticated user |
|
|
39
|
+
| `base44 logout` | Logout from current device |
|
|
40
|
+
|
|
41
|
+
### Project Management
|
|
43
42
|
|
|
44
43
|
| Command | Description |
|
|
45
|
-
|
|
46
|
-
|
|
|
47
|
-
|
|
|
48
|
-
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
|
53
|
-
|
|
54
|
-
|
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
44
|
+
|---------|-------------|
|
|
45
|
+
| `base44 create` | Create a new Base44 project from a template |
|
|
46
|
+
| `base44 link` | Link an existing local project to Base44 |
|
|
47
|
+
| `base44 dashboard` | Open the app dashboard in your browser |
|
|
48
|
+
|
|
49
|
+
### Deployment
|
|
50
|
+
|
|
51
|
+
| Command | Description |
|
|
52
|
+
|---------|-------------|
|
|
53
|
+
| `base44 deploy` | Deploy all resources (entities, functions, and site) |
|
|
54
|
+
|
|
55
|
+
### Entities
|
|
56
|
+
|
|
57
|
+
| Command | Description |
|
|
58
|
+
|---------|-------------|
|
|
59
|
+
| `base44 entities push` | Push local entity schemas to Base44 |
|
|
60
|
+
|
|
61
|
+
### Functions
|
|
62
|
+
|
|
63
|
+
| Command | Description |
|
|
64
|
+
|---------|-------------|
|
|
65
|
+
| `base44 functions deploy` | Deploy local functions to Base44 |
|
|
66
|
+
|
|
67
|
+
### Site
|
|
68
|
+
|
|
69
|
+
| Command | Description |
|
|
70
|
+
|---------|-------------|
|
|
71
|
+
| `base44 site deploy` | Deploy built site files to Base44 hosting |
|
|
72
|
+
|
|
73
|
+
## Configuration
|
|
74
|
+
|
|
75
|
+
### Project Configuration
|
|
76
|
+
|
|
77
|
+
Base44 projects are configured via a `config.jsonc` (or `config.json`) file in the `base44/` subdirectory:
|
|
78
|
+
|
|
79
|
+
```jsonc
|
|
80
|
+
// base44/config.jsonc
|
|
81
|
+
{
|
|
82
|
+
"id": "your-app-id", // Set after project creation
|
|
83
|
+
"name": "My Project",
|
|
84
|
+
"entitiesDir": "./entities", // Default: ./entities
|
|
85
|
+
"functionsDir": "./functions", // Default: ./functions
|
|
86
|
+
"site": {
|
|
87
|
+
"outputDirectory": "../dist" // Path to built site files
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
### Environment Variables
|
|
93
|
+
|
|
94
|
+
| Variable | Description | Default |
|
|
95
|
+
|----------|-------------|---------|
|
|
96
|
+
| `BASE44_CLIENT_ID` | Your app ID | - |
|
|
97
|
+
|
|
98
|
+
You can set these in a `.env.local` file in your `base44/` directory:
|
|
99
|
+
|
|
100
|
+
```bash
|
|
101
|
+
# base44/.env.local
|
|
102
|
+
BASE44_CLIENT_ID=your-app-id
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
## Project Structure
|
|
106
|
+
|
|
107
|
+
A typical Base44 project has this structure:
|
|
108
|
+
|
|
109
|
+
```
|
|
110
|
+
my-project/
|
|
111
|
+
├── base44/
|
|
112
|
+
│ ├── config.jsonc # Project configuration
|
|
113
|
+
│ ├── .env.local # Environment variables (git-ignored)
|
|
114
|
+
│ ├── entities/ # Entity schema files
|
|
115
|
+
│ │ ├── user.jsonc
|
|
116
|
+
│ │ └── product.jsonc
|
|
117
|
+
│ └── functions/ # Backend functions
|
|
118
|
+
│ └── my-function/
|
|
119
|
+
│ ├── config.jsonc
|
|
120
|
+
│ └── index.js
|
|
121
|
+
├── src/ # Your frontend code
|
|
122
|
+
├── dist/ # Built site files (for deployment)
|
|
123
|
+
└── package.json
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
## Development
|
|
127
|
+
|
|
128
|
+
### Prerequisites
|
|
129
|
+
|
|
130
|
+
- Node.js >= 20.19.0
|
|
131
|
+
- npm
|
|
132
|
+
|
|
133
|
+
### Setup
|
|
59
134
|
|
|
60
135
|
```bash
|
|
61
|
-
|
|
62
|
-
|
|
136
|
+
# Clone the repository
|
|
137
|
+
git clone https://github.com/base44/cli.git
|
|
138
|
+
cd cli
|
|
139
|
+
|
|
140
|
+
# Install dependencies
|
|
141
|
+
npm install
|
|
142
|
+
|
|
143
|
+
# Build
|
|
144
|
+
npm run build
|
|
145
|
+
|
|
146
|
+
# Run in development mode
|
|
147
|
+
npm run dev -- <command>
|
|
63
148
|
```
|
|
64
149
|
|
|
65
|
-
|
|
150
|
+
### Available Scripts
|
|
66
151
|
|
|
67
152
|
```bash
|
|
68
|
-
|
|
153
|
+
npm run build # Build with tsdown
|
|
154
|
+
npm run typecheck # Type check with tsc
|
|
155
|
+
npm run dev # Run in development mode with tsx
|
|
156
|
+
npm run lint # Lint with ESLint
|
|
157
|
+
npm test # Run tests with Vitest
|
|
69
158
|
```
|
|
70
159
|
|
|
71
|
-
|
|
160
|
+
### Running the Built CLI
|
|
72
161
|
|
|
73
|
-
|
|
162
|
+
```bash
|
|
163
|
+
# After building
|
|
164
|
+
npm start -- <command>
|
|
165
|
+
|
|
166
|
+
# Or directly
|
|
167
|
+
./dist/cli/index.js <command>
|
|
168
|
+
```
|
|
169
|
+
## Contributing
|
|
74
170
|
|
|
75
|
-
|
|
171
|
+
See [AGENTS.md](./AGENTS.md) for development guidelines and architecture documentation.
|
|
76
172
|
|
|
77
173
|
## License
|
|
78
174
|
|