primitive-admin 1.0.38 → 1.0.40
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/dist/src/commands/databases.js +202 -29
- package/dist/src/commands/databases.js.map +1 -1
- package/dist/src/commands/init.js +290 -118
- package/dist/src/commands/init.js.map +1 -1
- package/dist/src/commands/integrations.js +481 -20
- package/dist/src/commands/integrations.js.map +1 -1
- package/dist/src/commands/sync.js +27 -7
- package/dist/src/commands/sync.js.map +1 -1
- package/dist/src/commands/workflows.js +14 -4
- package/dist/src/commands/workflows.js.map +1 -1
- package/dist/src/lib/api-client.js +23 -3
- package/dist/src/lib/api-client.js.map +1 -1
- package/dist/src/lib/init-config.js +87 -0
- package/dist/src/lib/init-config.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { existsSync, readFileSync } from "fs";
|
|
2
|
+
import { join } from "path";
|
|
3
|
+
import * as TOML from "@iarna/toml";
|
|
4
|
+
export const INIT_CONFIG_FILENAME = ".primitive-init.toml";
|
|
5
|
+
/**
|
|
6
|
+
* Parses a TOML string into an InitConfig object.
|
|
7
|
+
* Throws if the string contains invalid TOML.
|
|
8
|
+
*/
|
|
9
|
+
export function parseInitConfigToml(content) {
|
|
10
|
+
const parsed = TOML.parse(content);
|
|
11
|
+
// The cast is safe because validateInitConfig() is always called after parsing
|
|
12
|
+
return parsed;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Loads and parses a .primitive-init.toml file from the given directory.
|
|
16
|
+
* Returns null if the file does not exist.
|
|
17
|
+
* Throws if the file exists but contains invalid TOML.
|
|
18
|
+
*/
|
|
19
|
+
export function loadInitConfig(dir) {
|
|
20
|
+
const configPath = join(dir, INIT_CONFIG_FILENAME);
|
|
21
|
+
if (!existsSync(configPath)) {
|
|
22
|
+
return null;
|
|
23
|
+
}
|
|
24
|
+
const content = readFileSync(configPath, "utf-8");
|
|
25
|
+
return parseInitConfigToml(content);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Validates an InitConfig object. Returns a ValidationResult with any errors.
|
|
29
|
+
*/
|
|
30
|
+
export function validateInitConfig(config) {
|
|
31
|
+
const errors = [];
|
|
32
|
+
// action is required
|
|
33
|
+
if (!config.action) {
|
|
34
|
+
errors.push('Missing required field: "action" (must be "create" or "use-existing")');
|
|
35
|
+
}
|
|
36
|
+
else if (config.action !== "create" && config.action !== "use-existing") {
|
|
37
|
+
errors.push('"action" must be "create" or "use-existing"');
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
// Validate action-specific required fields
|
|
41
|
+
if (config.action === "create" && !config.app_name) {
|
|
42
|
+
errors.push('"app_name" is required when action is "create"');
|
|
43
|
+
}
|
|
44
|
+
if (config.action === "use-existing" && !config.app_id) {
|
|
45
|
+
errors.push('"app_id" is required when action is "use-existing"');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
// Validate access_mode if provided
|
|
49
|
+
if (config.access_mode) {
|
|
50
|
+
const validModes = ["public", "domain", "invite-only"];
|
|
51
|
+
if (!validModes.includes(config.access_mode)) {
|
|
52
|
+
errors.push('"access_mode" must be "public", "domain", or "invite-only"');
|
|
53
|
+
}
|
|
54
|
+
else if (config.access_mode === "domain" && (!config.allowed_domains || config.allowed_domains.length === 0)) {
|
|
55
|
+
errors.push('"allowed_domains" is required when access_mode is "domain"');
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
// Validate dev_port if provided
|
|
59
|
+
if (config.dev_port !== undefined) {
|
|
60
|
+
if (typeof config.dev_port !== "number" || !Number.isInteger(config.dev_port) || config.dev_port < 1 || config.dev_port > 65535) {
|
|
61
|
+
errors.push('"dev_port" must be an integer between 1 and 65535');
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
// Validate invite_emails format if provided
|
|
65
|
+
if (config.invite_emails && Array.isArray(config.invite_emails)) {
|
|
66
|
+
for (const email of config.invite_emails) {
|
|
67
|
+
if (!email.includes("@")) {
|
|
68
|
+
errors.push(`Invalid email in invite_emails: "${email}"`);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
// Warn about fields ignored for use-existing action
|
|
73
|
+
if (config.action === "use-existing") {
|
|
74
|
+
const ignoredFields = [];
|
|
75
|
+
if (config.access_mode)
|
|
76
|
+
ignoredFields.push("access_mode");
|
|
77
|
+
if (config.invite_emails && config.invite_emails.length > 0)
|
|
78
|
+
ignoredFields.push("invite_emails");
|
|
79
|
+
if (config.allowed_domains && config.allowed_domains.length > 0)
|
|
80
|
+
ignoredFields.push("allowed_domains");
|
|
81
|
+
if (ignoredFields.length > 0) {
|
|
82
|
+
errors.push(`The following fields are ignored when action is "use-existing": ${ignoredFields.join(", ")}. Remove them to avoid confusion.`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return { valid: errors.length === 0, errors };
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=init-config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init-config.js","sourceRoot":"","sources":["../../../src/lib/init-config.ts"],"names":[],"mappings":"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"}
|