longcelot-sheet-db 0.1.5 → 0.1.8
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/CHANGELOG.md +93 -1
- package/LICENSE +1 -1
- package/README.md +167 -6
- package/dist/adapter/crud.d.ts +5 -3
- package/dist/adapter/crud.d.ts.map +1 -1
- package/dist/adapter/crud.js +41 -4
- package/dist/adapter/crud.js.map +1 -1
- package/dist/adapter/sheetAdapter.d.ts +2 -0
- package/dist/adapter/sheetAdapter.d.ts.map +1 -1
- package/dist/adapter/sheetAdapter.js +54 -1
- package/dist/adapter/sheetAdapter.js.map +1 -1
- package/dist/cli/commands/export.d.ts +8 -0
- package/dist/cli/commands/export.d.ts.map +1 -0
- package/dist/cli/commands/export.js +165 -0
- package/dist/cli/commands/export.js.map +1 -0
- package/dist/cli/commands/init.d.ts +3 -1
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +27 -5
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/mock-users.d.ts +3 -0
- package/dist/cli/commands/mock-users.d.ts.map +1 -0
- package/dist/cli/commands/mock-users.js +101 -0
- package/dist/cli/commands/mock-users.js.map +1 -0
- package/dist/cli/commands/seed.d.ts +1 -1
- package/dist/cli/commands/seed.d.ts.map +1 -1
- package/dist/cli/commands/seed.js +42 -1
- package/dist/cli/commands/seed.js.map +1 -1
- package/dist/cli/commands/sync.d.ts +3 -1
- package/dist/cli/commands/sync.d.ts.map +1 -1
- package/dist/cli/commands/sync.js +43 -2
- package/dist/cli/commands/sync.js.map +1 -1
- package/dist/cli/index.js +17 -1
- package/dist/cli/index.js.map +1 -1
- package/dist/schema/columnBuilder.d.ts.map +1 -1
- package/dist/schema/columnBuilder.js +1 -0
- package/dist/schema/columnBuilder.js.map +1 -1
- package/dist/schema/defineTable.d.ts.map +1 -1
- package/dist/schema/defineTable.js +8 -0
- package/dist/schema/defineTable.js.map +1 -1
- package/dist/schema/types.d.ts +6 -0
- package/dist/schema/types.d.ts.map +1 -1
- package/package.json +7 -3
- package/skills/auth/SKILL.md +142 -0
- package/skills/cli/SKILL.md +150 -0
- package/skills/core/SKILL.md +115 -0
- package/skills/crud/SKILL.md +185 -0
- package/skills/schema/SKILL.md +129 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.exportCommand = exportCommand;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
10
|
+
function mapTypeToPrisma(col) {
|
|
11
|
+
switch (col.type) {
|
|
12
|
+
case 'string': return 'String';
|
|
13
|
+
case 'number': return 'Float';
|
|
14
|
+
case 'boolean': return 'Boolean';
|
|
15
|
+
case 'date': return 'DateTime';
|
|
16
|
+
case 'json': return 'Json';
|
|
17
|
+
default: return 'String';
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
function mapTypeToSQL(col) {
|
|
21
|
+
switch (col.type) {
|
|
22
|
+
case 'string': return 'VARCHAR(255)';
|
|
23
|
+
case 'number': return 'DECIMAL(10,2)';
|
|
24
|
+
case 'boolean': return 'BOOLEAN';
|
|
25
|
+
case 'date': return 'DATETIME';
|
|
26
|
+
case 'json': return 'JSON';
|
|
27
|
+
default: return 'VARCHAR(255)';
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function generatePrismaModel(schema) {
|
|
31
|
+
const lines = [`model ${schema.name} {`];
|
|
32
|
+
for (const [colName, col] of Object.entries(schema.columns)) {
|
|
33
|
+
const prismaType = mapTypeToPrisma(col);
|
|
34
|
+
const isOptional = !col.required && !col.primary;
|
|
35
|
+
const typeSuffix = isOptional ? '?' : '';
|
|
36
|
+
const annotations = [];
|
|
37
|
+
// @id annotation
|
|
38
|
+
if (colName === (schema.pkColumn ?? '_id')) {
|
|
39
|
+
annotations.push('@id');
|
|
40
|
+
if (col.type === 'string') {
|
|
41
|
+
annotations.push('@default(cuid())');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// @unique annotation (skip if @id already added)
|
|
45
|
+
if (col.unique && colName !== (schema.pkColumn ?? '_id')) {
|
|
46
|
+
annotations.push('@unique');
|
|
47
|
+
}
|
|
48
|
+
// @relation annotation for FK columns
|
|
49
|
+
if (col.ref) {
|
|
50
|
+
const [refTable, refCol] = col.ref.split('.');
|
|
51
|
+
annotations.push(`@relation(fields: [${colName}], references: [${refCol}])`);
|
|
52
|
+
// Add a relation field after this column
|
|
53
|
+
const annotationStr = annotations.length > 0 ? ' ' + annotations.join(' ') : '';
|
|
54
|
+
lines.push(` ${colName} ${prismaType}${typeSuffix}${annotationStr}`);
|
|
55
|
+
lines.push(` ${refTable}_rel ${refTable} @relation(fields: [${colName}], references: [${refCol}])`);
|
|
56
|
+
continue;
|
|
57
|
+
}
|
|
58
|
+
const annotationStr = annotations.length > 0 ? ' ' + annotations.join(' ') : '';
|
|
59
|
+
lines.push(` ${colName} ${prismaType}${typeSuffix}${annotationStr}`);
|
|
60
|
+
}
|
|
61
|
+
lines.push('}');
|
|
62
|
+
lines.push('');
|
|
63
|
+
return lines.join('\n');
|
|
64
|
+
}
|
|
65
|
+
function generateSQLTable(schema) {
|
|
66
|
+
const lines = [`CREATE TABLE ${schema.name} (`];
|
|
67
|
+
const columnLines = [];
|
|
68
|
+
const constraintLines = [];
|
|
69
|
+
for (const [colName, col] of Object.entries(schema.columns)) {
|
|
70
|
+
const sqlType = mapTypeToSQL(col);
|
|
71
|
+
const notNull = col.required || col.primary ? ' NOT NULL' : '';
|
|
72
|
+
columnLines.push(` ${colName} ${sqlType}${notNull}`);
|
|
73
|
+
if (col.ref) {
|
|
74
|
+
const [refTable, refCol] = col.ref.split('.');
|
|
75
|
+
constraintLines.push(` FOREIGN KEY (${colName}) REFERENCES ${refTable}(${refCol})`);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// PRIMARY KEY constraint
|
|
79
|
+
const pkCol = schema.pkColumn ?? '_id';
|
|
80
|
+
constraintLines.unshift(` PRIMARY KEY (${pkCol})`);
|
|
81
|
+
const allLines = [...columnLines, ...constraintLines];
|
|
82
|
+
for (let i = 0; i < allLines.length; i++) {
|
|
83
|
+
lines.push(allLines[i] + (i < allLines.length - 1 ? ',' : ''));
|
|
84
|
+
}
|
|
85
|
+
lines.push(');');
|
|
86
|
+
lines.push('');
|
|
87
|
+
return lines.join('\n');
|
|
88
|
+
}
|
|
89
|
+
function loadSchemas(config) {
|
|
90
|
+
const schemas = [];
|
|
91
|
+
const schemasDir = path_1.default.join(process.cwd(), 'schemas');
|
|
92
|
+
for (const actor of config.actors) {
|
|
93
|
+
const actorDir = path_1.default.join(schemasDir, actor);
|
|
94
|
+
if (!fs_1.default.existsSync(actorDir))
|
|
95
|
+
continue;
|
|
96
|
+
const files = fs_1.default.readdirSync(actorDir).filter((f) => f.endsWith('.ts') || f.endsWith('.js'));
|
|
97
|
+
for (const file of files) {
|
|
98
|
+
try {
|
|
99
|
+
const schema = require(path_1.default.join(actorDir, file)).default;
|
|
100
|
+
if (schema?.columns)
|
|
101
|
+
schemas.push(schema);
|
|
102
|
+
}
|
|
103
|
+
catch {
|
|
104
|
+
// skip unloadable files
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return schemas;
|
|
109
|
+
}
|
|
110
|
+
async function exportCommand(options) {
|
|
111
|
+
console.log(chalk_1.default.blue.bold('📦 Exporting schemas...\n'));
|
|
112
|
+
if (!options.prisma && !options.sql) {
|
|
113
|
+
console.error(chalk_1.default.red('❌ Specify --prisma or --sql (or both)'));
|
|
114
|
+
process.exit(1);
|
|
115
|
+
}
|
|
116
|
+
let config;
|
|
117
|
+
try {
|
|
118
|
+
config = require(path_1.default.join(process.cwd(), 'sheet-db.config.ts')).default;
|
|
119
|
+
}
|
|
120
|
+
catch {
|
|
121
|
+
console.error(chalk_1.default.red('❌ sheet-db.config.ts not found'));
|
|
122
|
+
process.exit(1);
|
|
123
|
+
}
|
|
124
|
+
const schemas = loadSchemas(config);
|
|
125
|
+
if (schemas.length === 0) {
|
|
126
|
+
console.log(chalk_1.default.yellow('⚠️ No schemas found'));
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
if (options.prisma) {
|
|
130
|
+
const prismaHeader = [
|
|
131
|
+
'generator client {',
|
|
132
|
+
' provider = "prisma-client-js"',
|
|
133
|
+
'}',
|
|
134
|
+
'',
|
|
135
|
+
'datasource db {',
|
|
136
|
+
' provider = "postgresql"',
|
|
137
|
+
' url = env("DATABASE_URL")',
|
|
138
|
+
'}',
|
|
139
|
+
'',
|
|
140
|
+
].join('\n');
|
|
141
|
+
const models = schemas.map(generatePrismaModel).join('\n');
|
|
142
|
+
const prismaOutput = prismaHeader + models;
|
|
143
|
+
const outPath = options.output
|
|
144
|
+
? path_1.default.join(options.output, 'schema.prisma')
|
|
145
|
+
: path_1.default.join(process.cwd(), 'schema.prisma');
|
|
146
|
+
if (options.output && !fs_1.default.existsSync(options.output)) {
|
|
147
|
+
fs_1.default.mkdirSync(options.output, { recursive: true });
|
|
148
|
+
}
|
|
149
|
+
fs_1.default.writeFileSync(outPath, prismaOutput);
|
|
150
|
+
console.log(chalk_1.default.green(`✅ Prisma schema written to ${outPath}`));
|
|
151
|
+
}
|
|
152
|
+
if (options.sql) {
|
|
153
|
+
const tables = schemas.map(generateSQLTable).join('\n');
|
|
154
|
+
const outPath = options.output
|
|
155
|
+
? path_1.default.join(options.output, 'schema.sql')
|
|
156
|
+
: path_1.default.join(process.cwd(), 'schema.sql');
|
|
157
|
+
if (options.output && !fs_1.default.existsSync(options.output)) {
|
|
158
|
+
fs_1.default.mkdirSync(options.output, { recursive: true });
|
|
159
|
+
}
|
|
160
|
+
fs_1.default.writeFileSync(outPath, tables);
|
|
161
|
+
console.log(chalk_1.default.green(`✅ SQL DDL written to ${outPath}`));
|
|
162
|
+
}
|
|
163
|
+
console.log(chalk_1.default.cyan(`\nExported ${schemas.length} table(s)`));
|
|
164
|
+
}
|
|
165
|
+
//# sourceMappingURL=export.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../../src/cli/commands/export.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/init.ts"],"names":[],"mappings":"AAwBA,wBAAsB,WAAW,
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/init.ts"],"names":[],"mappings":"AAwBA,wBAAsB,WAAW,CAAC,OAAO,EAAE;IAAE,SAAS,CAAC,EAAE,OAAO,CAAA;CAAE,iBAsIjE"}
|
|
@@ -23,14 +23,19 @@ function printBanner() {
|
|
|
23
23
|
console.log(' ' + chalk_1.default.hex('#05b5fb')('Google Sheets-backed Staging Database Adapter'));
|
|
24
24
|
console.log();
|
|
25
25
|
}
|
|
26
|
-
async function initCommand() {
|
|
26
|
+
async function initCommand(options) {
|
|
27
27
|
printBanner();
|
|
28
|
+
if (options.integrate) {
|
|
29
|
+
console.log(chalk_1.default.blue('Integrating into an existing project...\n'));
|
|
30
|
+
}
|
|
31
|
+
const defaultProjectName = path_1.default.basename(process.cwd());
|
|
28
32
|
const answers = await inquirer_1.default.prompt([
|
|
29
33
|
{
|
|
30
34
|
type: 'input',
|
|
31
35
|
name: 'projectName',
|
|
32
36
|
message: 'Project name:',
|
|
33
|
-
default:
|
|
37
|
+
default: defaultProjectName,
|
|
38
|
+
when: !options.integrate,
|
|
34
39
|
},
|
|
35
40
|
{
|
|
36
41
|
type: 'input',
|
|
@@ -46,8 +51,9 @@ async function initCommand() {
|
|
|
46
51
|
filter: (input) => input.split(',').map((s) => s.trim()),
|
|
47
52
|
},
|
|
48
53
|
]);
|
|
54
|
+
const projectName = options.integrate ? defaultProjectName : answers.projectName;
|
|
49
55
|
const configContent = `export default {
|
|
50
|
-
projectName: "${
|
|
56
|
+
projectName: "${projectName}",
|
|
51
57
|
superAdminEmail: "${answers.superAdminEmail}",
|
|
52
58
|
actors: ${JSON.stringify(answers.actors, null, 2)}
|
|
53
59
|
};
|
|
@@ -65,8 +71,24 @@ ADMIN_SHEET_ID=
|
|
|
65
71
|
# Super admin email (new user sheets will be shared with this account)
|
|
66
72
|
SUPER_ADMIN_EMAIL=${answers.superAdminEmail}
|
|
67
73
|
`;
|
|
68
|
-
fs_1.default.
|
|
69
|
-
|
|
74
|
+
if (!fs_1.default.existsSync('sheet-db.config.ts') || !options.integrate) {
|
|
75
|
+
fs_1.default.writeFileSync('sheet-db.config.ts', configContent);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
console.log(chalk_1.default.yellow('ℹ sheet-db.config.ts already exists, skipping creation.'));
|
|
79
|
+
}
|
|
80
|
+
if (!fs_1.default.existsSync('.env') || !options.integrate) {
|
|
81
|
+
fs_1.default.writeFileSync('.env', envContent);
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
console.log(chalk_1.default.yellow('ℹ .env already exists, please merge Google OAuth vars manually.'));
|
|
85
|
+
// Optionally append to .env
|
|
86
|
+
const currentEnv = fs_1.default.readFileSync('.env', 'utf-8');
|
|
87
|
+
if (!currentEnv.includes('GOOGLE_CLIENT_ID')) {
|
|
88
|
+
fs_1.default.appendFileSync('.env', '\n' + envContent);
|
|
89
|
+
console.log(chalk_1.default.green('✅ Appended Google Sheet DB variables to .env'));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
70
92
|
if (!fs_1.default.existsSync('schemas')) {
|
|
71
93
|
fs_1.default.mkdirSync('schemas');
|
|
72
94
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/cli/commands/init.ts"],"names":[],"mappings":";;;;;AAwBA,
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/cli/commands/init.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-users.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/mock-users.ts"],"names":[],"mappings":"AASA,wBAAsB,gBAAgB,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,iBA4FhE;AAED,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.mockUsersCommand = mockUsersCommand;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
10
|
+
const sheetAdapter_1 = require("../../adapter/sheetAdapter");
|
|
11
|
+
function makeEmail(userId, role) {
|
|
12
|
+
return `${role}.${userId}@example.local`;
|
|
13
|
+
}
|
|
14
|
+
async function mockUsersCommand(countArg) {
|
|
15
|
+
const count = Number(countArg) || 3;
|
|
16
|
+
console.log(chalk_1.default.blue.bold(`
|
|
17
|
+
🧪 Creating ${count} mock users (development)...
|
|
18
|
+
`));
|
|
19
|
+
require('dotenv').config();
|
|
20
|
+
const requiredEnvVars = [
|
|
21
|
+
'GOOGLE_CLIENT_ID',
|
|
22
|
+
'GOOGLE_CLIENT_SECRET',
|
|
23
|
+
'GOOGLE_REDIRECT_URI',
|
|
24
|
+
'ADMIN_SHEET_ID',
|
|
25
|
+
'SUPER_ADMIN_EMAIL',
|
|
26
|
+
];
|
|
27
|
+
for (const envVar of requiredEnvVars) {
|
|
28
|
+
if (!process.env[envVar]) {
|
|
29
|
+
console.error(chalk_1.default.red(`❌ Missing environment variable: ${envVar}`));
|
|
30
|
+
process.exit(1);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const tokensPath = path_1.default.join(process.cwd(), '.sheet-db-tokens.json');
|
|
34
|
+
if (!fs_1.default.existsSync(tokensPath)) {
|
|
35
|
+
console.error(chalk_1.default.red('❌ No OAuth tokens found. Run: sheet-db sync'));
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
let tokens;
|
|
39
|
+
try {
|
|
40
|
+
tokens = JSON.parse(fs_1.default.readFileSync(tokensPath, 'utf-8'));
|
|
41
|
+
}
|
|
42
|
+
catch {
|
|
43
|
+
console.error(chalk_1.default.red('❌ Failed to read tokens file.'));
|
|
44
|
+
process.exit(1);
|
|
45
|
+
}
|
|
46
|
+
// Load config and schemas
|
|
47
|
+
let config;
|
|
48
|
+
try {
|
|
49
|
+
config = require(path_1.default.join(process.cwd(), 'sheet-db.config.ts')).default;
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
console.error(chalk_1.default.red('❌ sheet-db.config.ts not found. Run: sheet-db init'));
|
|
53
|
+
process.exit(1);
|
|
54
|
+
}
|
|
55
|
+
const adapter = (0, sheetAdapter_1.createSheetAdapter)({
|
|
56
|
+
adminSheetId: process.env.ADMIN_SHEET_ID,
|
|
57
|
+
credentials: {
|
|
58
|
+
clientId: process.env.GOOGLE_CLIENT_ID,
|
|
59
|
+
clientSecret: process.env.GOOGLE_CLIENT_SECRET,
|
|
60
|
+
redirectUri: process.env.GOOGLE_REDIRECT_URI,
|
|
61
|
+
},
|
|
62
|
+
tokens,
|
|
63
|
+
});
|
|
64
|
+
// Load and register all schemas
|
|
65
|
+
const schemasDir = path_1.default.join(process.cwd(), 'schemas');
|
|
66
|
+
for (const actor of config.actors) {
|
|
67
|
+
const actorDir = path_1.default.join(schemasDir, actor);
|
|
68
|
+
if (!fs_1.default.existsSync(actorDir))
|
|
69
|
+
continue;
|
|
70
|
+
const files = fs_1.default.readdirSync(actorDir).filter((f) => f.endsWith('.ts'));
|
|
71
|
+
for (const file of files) {
|
|
72
|
+
try {
|
|
73
|
+
const schema = require(path_1.default.join(actorDir, file)).default;
|
|
74
|
+
adapter.registerSchema(schema);
|
|
75
|
+
}
|
|
76
|
+
catch {
|
|
77
|
+
// ignore failures to require optional schemas
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
let created = 0;
|
|
82
|
+
for (let i = 0; i < count; i++) {
|
|
83
|
+
const userId = `mock-${Date.now().toString(36)}-${i}`;
|
|
84
|
+
// Rotate roles among configured actors (skip admin)
|
|
85
|
+
const actors = config.actors.filter((a) => a !== 'admin');
|
|
86
|
+
const role = actors[i % actors.length] || 'student';
|
|
87
|
+
const email = makeEmail(userId, role);
|
|
88
|
+
try {
|
|
89
|
+
const sheetId = await adapter.createUserSheet(userId, role, email);
|
|
90
|
+
console.log(chalk_1.default.green(` ✓ Created ${role} user ${userId} → sheet ${sheetId}`));
|
|
91
|
+
created++;
|
|
92
|
+
}
|
|
93
|
+
catch (err) {
|
|
94
|
+
console.error(chalk_1.default.red(` ✖ Failed to create user ${userId}: ${err}`));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
console.log();
|
|
98
|
+
console.log(chalk_1.default.bold(`Done. ${created}/${count} mock users created.`));
|
|
99
|
+
}
|
|
100
|
+
exports.default = mockUsersCommand;
|
|
101
|
+
//# sourceMappingURL=mock-users.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-users.js","sourceRoot":"","sources":["../../../src/cli/commands/mock-users.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare function seedCommand(seedFile: string): Promise<void>;
|
|
1
|
+
export declare function seedCommand(seedFile: string, opts?: any): Promise<void>;
|
|
2
2
|
//# sourceMappingURL=seed.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seed.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/seed.ts"],"names":[],"mappings":"AAKA,wBAAsB,WAAW,CAAC,QAAQ,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"seed.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/seed.ts"],"names":[],"mappings":"AAKA,wBAAsB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,iBAkK7D"}
|
|
@@ -8,7 +8,7 @@ const fs_1 = __importDefault(require("fs"));
|
|
|
8
8
|
const path_1 = __importDefault(require("path"));
|
|
9
9
|
const chalk_1 = __importDefault(require("chalk"));
|
|
10
10
|
const sheetAdapter_1 = require("../../adapter/sheetAdapter");
|
|
11
|
-
async function seedCommand(seedFile) {
|
|
11
|
+
async function seedCommand(seedFile, opts) {
|
|
12
12
|
console.log(chalk_1.default.blue.bold('🌱 Seeding data into Google Sheets...\n'));
|
|
13
13
|
require('dotenv').config();
|
|
14
14
|
const requiredEnvVars = [
|
|
@@ -88,6 +88,47 @@ async function seedCommand(seedFile) {
|
|
|
88
88
|
const adapterWithContext = adapter.withContext({ userId: 'seed-cli', role: 'admin', actorSheetId: process.env.ADMIN_SHEET_ID });
|
|
89
89
|
let totalInserted = 0;
|
|
90
90
|
let totalFailed = 0;
|
|
91
|
+
if (opts && opts.allActors) {
|
|
92
|
+
console.log(chalk_1.default.cyan('\nSeeding to all actor sheets (--all-actors)...'));
|
|
93
|
+
// Read users from admin users table
|
|
94
|
+
let users = [];
|
|
95
|
+
try {
|
|
96
|
+
users = await adapterWithContext.table('users').findMany();
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
console.error(chalk_1.default.red('❌ Could not read admin users table. Make sure `users` schema is registered and admin sheet has been synced.'));
|
|
100
|
+
process.exit(1);
|
|
101
|
+
}
|
|
102
|
+
if (!users || users.length === 0) {
|
|
103
|
+
console.warn(chalk_1.default.yellow('No users found in admin users table. Nothing to seed.'));
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
let totalInsertedActors = 0;
|
|
107
|
+
let totalFailedActors = 0;
|
|
108
|
+
for (const user of users) {
|
|
109
|
+
if (!user.actor_sheet_id)
|
|
110
|
+
continue;
|
|
111
|
+
const targetAdapter = adapter.withContext({ userId: 'seed-cli', role: 'admin', actorSheetId: user.actor_sheet_id });
|
|
112
|
+
for (const [tableName, records] of Object.entries(seedData)) {
|
|
113
|
+
if (!Array.isArray(records))
|
|
114
|
+
continue;
|
|
115
|
+
for (const record of records) {
|
|
116
|
+
try {
|
|
117
|
+
await targetAdapter.table(tableName).create(record);
|
|
118
|
+
totalInsertedActors++;
|
|
119
|
+
}
|
|
120
|
+
catch {
|
|
121
|
+
totalFailedActors++;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
console.log();
|
|
127
|
+
console.log(chalk_1.default.bold(`Seed complete (all-actors): ${totalInsertedActors} inserted, ${totalFailedActors} failed.`));
|
|
128
|
+
if (totalFailedActors > 0)
|
|
129
|
+
process.exit(1);
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
91
132
|
for (const [tableName, records] of Object.entries(seedData)) {
|
|
92
133
|
if (!Array.isArray(records)) {
|
|
93
134
|
console.warn(chalk_1.default.yellow(` ⚠️ Skipping "${tableName}": expected an array of records`));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seed.js","sourceRoot":"","sources":["../../../src/cli/commands/seed.ts"],"names":[],"mappings":";;;;;AAKA,
|
|
1
|
+
{"version":3,"file":"seed.js","sourceRoot":"","sources":["../../../src/cli/commands/seed.ts"],"names":[],"mappings":";;;;;AAKA,kCAkKC;AAvKD,4CAAoB;AACpB,gDAAwB;AACxB,kDAA0B;AAC1B,6DAAgE;AAEzD,KAAK,UAAU,WAAW,CAAC,QAAgB,EAAE,IAAU;IAC5D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC,CAAC;IAExE,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,CAAC;IAE3B,MAAM,eAAe,GAAG;QACtB,kBAAkB;QAClB,sBAAsB;QACtB,qBAAqB;QACrB,gBAAgB;KACjB,CAAC;IAEF,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,mCAAmC,MAAM,EAAE,CAAC,CAAC,CAAC;YACtE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;IACH,CAAC;IAED,cAAc;IACd,MAAM,UAAU,GAAG,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,uBAAuB,CAAC,CAAC;IACrE,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/B,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC,CAAC;QACxE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,MAAW,CAAC;IAChB,IAAI,CAAC;QACH,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAE,CAAC,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC;IAC5D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC,CAAC;QAC1D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,iBAAiB;IACjB,MAAM,YAAY,GAAG,cAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;IAC3D,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;QACjC,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,0BAA0B,YAAY,EAAE,CAAC,CAAC,CAAC;QACnE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,QAA+B,CAAC;IACpC,IAAI,CAAC;QACH,QAAQ,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;IACnC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,+BAA+B,GAAG,EAAE,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,0BAA0B;IAC1B,IAAI,MAAW,CAAC;IAChB,IAAI,CAAC;QACH,MAAM,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC;IAC3E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,oDAAoD,CAAC,CAAC,CAAC;QAC/E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,OAAO,GAAG,IAAA,iCAAkB,EAAC;QACjC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,cAAe;QACzC,WAAW,EAAE;YACX,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,gBAAiB;YACvC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAqB;YAC/C,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAoB;SAC9C;QACD,MAAM;KACP,CAAC,CAAC;IAEH,gCAAgC;IAChC,MAAM,UAAU,GAAG,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IACvD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,cAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,SAAS;QACvC,MAAM,KAAK,GAAG,YAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QACxE,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;gBAC1D,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YACjC,CAAC;YAAC,MAAM,CAAC,CAAA,CAAC;QACZ,CAAC;IACH,CAAC;IAED,gCAAgC;IAChC,MAAM,kBAAkB,GAAG,OAAO,CAAC,WAAW,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,cAAe,EAAE,CAAC,CAAC;IAEjI,IAAI,aAAa,GAAG,CAAC,CAAC;IACtB,IAAI,WAAW,GAAG,CAAC,CAAC;IAEpB,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iDAAiD,CAAC,CAAC,CAAC;QAE3E,oCAAoC;QACpC,IAAI,KAAK,GAAU,EAAE,CAAC;QACtB,IAAI,CAAC;YACH,KAAK,GAAG,MAAM,kBAAkB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC7D,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,6GAA6G,CAAC,CAAC,CAAC;YACxI,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACjC,OAAO,CAAC,IAAI,CAAC,eAAK,CAAC,MAAM,CAAC,uDAAuD,CAAC,CAAC,CAAC;YACpF,OAAO;QACT,CAAC;QAED,IAAI,mBAAmB,GAAG,CAAC,CAAC;QAC5B,IAAI,iBAAiB,GAAG,CAAC,CAAC;QAE1B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,IAAI,CAAC,cAAc;gBAAE,SAAS;YACnC,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;YAEpH,KAAK,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC5D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;oBAAE,SAAS;gBACtC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;oBAC7B,IAAI,CAAC;wBACH,MAAM,aAAa,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;wBACpD,mBAAmB,EAAE,CAAC;oBACxB,CAAC;oBAAC,MAAM,CAAC;wBACP,iBAAiB,EAAE,CAAC;oBACtB,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,CAAC,GAAG,EAAE,CAAC;QACd,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,+BAA+B,mBAAmB,cAAc,iBAAiB,UAAU,CAAC,CAAC,CAAC;QACrH,IAAI,iBAAiB,GAAG,CAAC;YAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAE3C,OAAO;IACT,CAAC;IAED,KAAK,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC5D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5B,OAAO,CAAC,IAAI,CAAC,eAAK,CAAC,MAAM,CAAC,mBAAmB,SAAS,iCAAiC,CAAC,CAAC,CAAC;YAC1F,SAAS;QACX,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,aAAa,SAAS,KAAK,OAAO,CAAC,MAAM,cAAc,CAAC,CAAC,CAAC;QACjF,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,IAAI,MAAM,GAAG,CAAC,CAAC;QAEf,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC;gBACH,MAAM,kBAAkB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACzD,QAAQ,EAAE,CAAC;YACb,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,eAAe,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC/C,MAAM,EAAE,CAAC;YACX,CAAC;QACH,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,eAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,eAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACnE,OAAO,CAAC,GAAG,CAAC,KAAK,MAAM,IAAI,QAAQ,cAAc,MAAM,SAAS,CAAC,CAAC;QAClE,aAAa,IAAI,QAAQ,CAAC;QAC1B,WAAW,IAAI,MAAM,CAAC;IACxB,CAAC;IAED,OAAO,CAAC,GAAG,EAAE,CAAC;IACd,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,kBAAkB,aAAa,cAAc,WAAW,UAAU,CAAC,CAAC,CAAC;IAE5F,IAAI,WAAW,GAAG,CAAC;QAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACvC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/sync.ts"],"names":[],"mappings":"AAqEA,wBAAsB,WAAW,
|
|
1
|
+
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/sync.ts"],"names":[],"mappings":"AAqEA,wBAAsB,WAAW,CAAC,OAAO,EAAE;IAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,iBA8IhE"}
|
|
@@ -60,7 +60,7 @@ async function resolveTokens(oauth) {
|
|
|
60
60
|
console.log(chalk_1.default.green(`✅ Tokens saved to ${TOKENS_FILE}\n`));
|
|
61
61
|
return tokens;
|
|
62
62
|
}
|
|
63
|
-
async function syncCommand() {
|
|
63
|
+
async function syncCommand(options) {
|
|
64
64
|
console.log(chalk_1.default.blue.bold('🔄 Syncing schemas to Google Sheets...\n'));
|
|
65
65
|
require('dotenv').config();
|
|
66
66
|
const requiredEnvVars = [
|
|
@@ -133,7 +133,11 @@ async function syncCommand() {
|
|
|
133
133
|
adapter.registerSchemas(schemas);
|
|
134
134
|
let synced = 0;
|
|
135
135
|
let failed = 0;
|
|
136
|
-
|
|
136
|
+
// Sync admin schemas first
|
|
137
|
+
const adminSchemas = schemas.filter(s => s.actor === 'admin');
|
|
138
|
+
const userSchemas = schemas.filter(s => s.actor !== 'admin');
|
|
139
|
+
console.log(chalk_1.default.bold('\nSyncing Admin Schemas...'));
|
|
140
|
+
for (const schema of adminSchemas) {
|
|
137
141
|
try {
|
|
138
142
|
await adapter.syncSchema(schema);
|
|
139
143
|
console.log(chalk_1.default.green(` ✓ ${schema.name} (${schema.actor})`));
|
|
@@ -144,6 +148,43 @@ async function syncCommand() {
|
|
|
144
148
|
failed++;
|
|
145
149
|
}
|
|
146
150
|
}
|
|
151
|
+
if (options.allUsers && userSchemas.length > 0) {
|
|
152
|
+
console.log(chalk_1.default.bold('\nSyncing User Schemas...'));
|
|
153
|
+
try {
|
|
154
|
+
// Fetch all users from admin sheet to get their actor_sheet_id
|
|
155
|
+
const usersTable = adapter.table('users');
|
|
156
|
+
const allUsers = await usersTable.findMany({});
|
|
157
|
+
for (const user of allUsers) {
|
|
158
|
+
if (!user.actor_sheet_id)
|
|
159
|
+
continue;
|
|
160
|
+
console.log(chalk_1.default.cyan(`\nUser: ${user.email} (${user.role})`));
|
|
161
|
+
const roleSchemas = userSchemas.filter(s => s.actor === user.role);
|
|
162
|
+
// inject context for this user to resolve correct sheet ID
|
|
163
|
+
const userAdapter = adapter.withContext({
|
|
164
|
+
userId: user.user_id,
|
|
165
|
+
role: user.role,
|
|
166
|
+
actorSheetId: user.actor_sheet_id
|
|
167
|
+
});
|
|
168
|
+
for (const schema of roleSchemas) {
|
|
169
|
+
try {
|
|
170
|
+
await userAdapter.syncSchema(schema);
|
|
171
|
+
console.log(chalk_1.default.green(` ✓ ${schema.name} (${schema.actor})`));
|
|
172
|
+
synced++;
|
|
173
|
+
}
|
|
174
|
+
catch (err) {
|
|
175
|
+
console.error(chalk_1.default.red(` ✖ ${schema.name} — ${err}`));
|
|
176
|
+
failed++;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
catch (err) {
|
|
182
|
+
console.log(chalk_1.default.yellow(`⚠️ Could not fetch users table for all-users sync. Is it initialized? ${err}`));
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
else if (userSchemas.length > 0) {
|
|
186
|
+
console.log(chalk_1.default.yellow('\nℹ Skipping user schemas sync. Use --all-users to sync to all user sheets.'));
|
|
187
|
+
}
|
|
147
188
|
console.log();
|
|
148
189
|
console.log(chalk_1.default.bold(`Sync complete: ${synced} synced, ${failed} failed.`));
|
|
149
190
|
if (failed > 0)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../../src/cli/commands/sync.ts"],"names":[],"mappings":";;;;;AAqEA,
|
|
1
|
+
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../../src/cli/commands/sync.ts"],"names":[],"mappings":";;;;;AAqEA,kCA8IC;AAnND,4CAAoB;AACpB,gDAAwB;AACxB,kDAA0B;AAC1B,wDAAgC;AAChC,6DAAgE;AAChE,4CAAsD;AAGtD,MAAM,WAAW,GAAG,uBAAuB,CAAC;AAE5C,SAAS,UAAU;IACjB,MAAM,SAAS,GAAG,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;IACxD,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,SAAS,CAAC;QAAE,OAAO,IAAI,CAAC;IAC3C,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAE,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC;IACzD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAS,UAAU,CAAC,MAAW;IAC7B,YAAE,CAAC,aAAa,CACd,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,EACrC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAC/B,OAAO,CACR,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,aAAa,CAC1B,KAA4C;IAE5C,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;IAE5B,uDAAuD;IACvD,IAAI,MAAM,EAAE,aAAa,EAAE,CAAC;QAC1B,IAAI,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAC,CAAC;YAC3D,MAAM,SAAS,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAClE,sEAAsE;YACtE,MAAM,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,SAAS,EAAE,CAAC;YAC3C,UAAU,CAAC,MAAM,CAAC,CAAC;YACnB,OAAO,MAAM,CAAC;QAChB,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,+CAA+C,CAAC,CAAC,CAAC;QAC7E,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,EAAE,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC,CAAC;IACxD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,2CAA2C,CAAC,CAAC,CAAC;IACtE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IAC3C,OAAO,CAAC,GAAG,EAAE,CAAC;IAEd,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,kBAAQ,CAAC,MAAM,CAAC;QACrC;YACE,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,qDAAqD;YAC9D,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,sBAAsB,CAAC;SACvE;KACF,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAClD,UAAU,CAAC,MAAM,CAAC,CAAC;IACnB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,qBAAqB,WAAW,IAAI,CAAC,CAAC,CAAC;IAC/D,OAAO,MAAM,CAAC;AAChB,CAAC;AAEM,KAAK,UAAU,WAAW,CAAC,OAA+B;IAC/D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC,CAAC;IAEzE,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,CAAC;IAE3B,MAAM,eAAe,GAAG;QACtB,kBAAkB;QAClB,sBAAsB;QACtB,qBAAqB;QACrB,gBAAgB;KACjB,CAAC;IAEF,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,mCAAmC,MAAM,EAAE,CAAC,CAAC,CAAC;YACtE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC;IACX,IAAI,CAAC;QACH,MAAM,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC;IAC3E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,oDAAoD,CAAC,CAAC,CAAC;QAC/E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,kBAAkB;IAClB,MAAM,OAAO,GAAkB,EAAE,CAAC;IAClC,MAAM,UAAU,GAAG,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;IAEvD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,cAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,SAAS;QAEvC,MAAM,KAAK,GAAG,YAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QACxE,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;gBAC1D,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACvB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,4BAA4B,IAAI,MAAM,KAAK,EAAE,CAAC,CAAC,CAAC;YAC1E,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,wCAAwC,CAAC,CAAC,CAAC;QACpE,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,OAAO,CAAC,MAAM,sCAAsC,CAAC,CAAC,CAAC;IAEvF,8CAA8C;IAC9C,MAAM,KAAK,GAAG,IAAA,0BAAkB,EAAC;QAC/B,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,gBAAiB;QACvC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAqB;QAC/C,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAoB;KAC9C,CAAC,CAAC;IAEH,IAAI,MAAW,CAAC;IAChB,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,aAAa,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,4BAA4B,GAAG,EAAE,CAAC,CAAC,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,sCAAsC;IACtC,MAAM,OAAO,GAAG,IAAA,iCAAkB,EAAC;QACjC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,cAAe;QACzC,WAAW,EAAE;YACX,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,gBAAiB;YACvC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAqB;YAC/C,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAoB;SAC9C;QACD,MAAM;KACP,CAAC,CAAC;IAEH,OAAO,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IAEjC,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,IAAI,MAAM,GAAG,CAAC,CAAC;IAEf,2BAA2B;IAC3B,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC;IAC9D,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC;IAE7D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC,CAAC;IACtD,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE,CAAC;QAClC,IAAI,CAAC;YACH,MAAM,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YACjC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,OAAO,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YACjE,MAAM,EAAE,CAAC;QACX,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,OAAO,MAAM,CAAC,IAAI,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC;YACxD,MAAM,EAAE,CAAC;QACX,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC/C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC;YACH,+DAA+D;YAC/D,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC1C,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAE/C,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;gBAC5B,IAAI,CAAC,IAAI,CAAC,cAAc;oBAAE,SAAS;gBAEnC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;gBAChE,MAAM,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEnE,2DAA2D;gBAC3D,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;oBACtC,MAAM,EAAE,IAAI,CAAC,OAAO;oBACpB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,YAAY,EAAE,IAAI,CAAC,cAAc;iBAClC,CAAC,CAAC;gBAEH,KAAK,MAAM,MAAM,IAAI,WAAW,EAAE,CAAC;oBACjC,IAAI,CAAC;wBACH,MAAM,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;wBACrC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,OAAO,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;wBACjE,MAAM,EAAE,CAAC;oBACX,CAAC;oBAAC,OAAO,GAAG,EAAE,CAAC;wBACb,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,OAAO,MAAM,CAAC,IAAI,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC;wBACxD,MAAM,EAAE,CAAC;oBACX,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,yEAAyE,GAAG,EAAE,CAAC,CAAC,CAAC;QAC5G,CAAC;IACH,CAAC;SAAM,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,6EAA6E,CAAC,CAAC,CAAC;IAC3G,CAAC;IAED,OAAO,CAAC,GAAG,EAAE,CAAC;IACd,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,kBAAkB,MAAM,YAAY,MAAM,UAAU,CAAC,CAAC,CAAC;IAE9E,IAAI,MAAM,GAAG,CAAC;QAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClC,CAAC"}
|