@by-association-only/cli 4.2.0 → 4.3.0
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/index.cjs +17 -73
- package/dist/index.js +17 -73
- package/dist/index.js.map +4 -4
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -103,62 +103,6 @@ async function ensureWranglerSessionExists(s) {
|
|
|
103
103
|
async function writeWranglerConfig(location, config) {
|
|
104
104
|
return await import_promises.writeFile(location, JSON.stringify(config, null, 2));
|
|
105
105
|
}
|
|
106
|
-
async function createD1Database(name, cwd) {
|
|
107
|
-
try {
|
|
108
|
-
await runWranglerCommand(["d1", "create", name, "--binding=DB", "--update-config=true"], cwd);
|
|
109
|
-
return {
|
|
110
|
-
success: true,
|
|
111
|
-
message: `✅ D1 Database: ${name} created!`
|
|
112
|
-
};
|
|
113
|
-
} catch (error) {
|
|
114
|
-
return {
|
|
115
|
-
success: false,
|
|
116
|
-
message: `❌ D1 Database: ${error.stderr || error.stdout || error.message}`
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
async function createKVNamespace(name, cwd) {
|
|
121
|
-
try {
|
|
122
|
-
await runWranglerCommand([
|
|
123
|
-
"kv",
|
|
124
|
-
"namespace",
|
|
125
|
-
"create",
|
|
126
|
-
name,
|
|
127
|
-
"--binding=KV",
|
|
128
|
-
"--update-config=true"
|
|
129
|
-
], cwd);
|
|
130
|
-
return {
|
|
131
|
-
success: true,
|
|
132
|
-
message: `✅ KV Namespace: ${name} created!`
|
|
133
|
-
};
|
|
134
|
-
} catch (error) {
|
|
135
|
-
return {
|
|
136
|
-
success: false,
|
|
137
|
-
message: `❌ KV Namespace: ${error.stderr || error.stdout || error.message}`
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
async function createR2Bucket(name, cwd) {
|
|
142
|
-
try {
|
|
143
|
-
await runWranglerCommand([
|
|
144
|
-
"r2",
|
|
145
|
-
"bucket",
|
|
146
|
-
"create",
|
|
147
|
-
name,
|
|
148
|
-
"--binding=BUCKET",
|
|
149
|
-
"--update-config=true"
|
|
150
|
-
], cwd);
|
|
151
|
-
return {
|
|
152
|
-
success: true,
|
|
153
|
-
message: `✅ KV Namespace: ${name} created!`
|
|
154
|
-
};
|
|
155
|
-
} catch (error) {
|
|
156
|
-
return {
|
|
157
|
-
success: false,
|
|
158
|
-
message: `❌ KV Namespace: ${error.stderr || error.stdout || error.message}`
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
106
|
|
|
163
107
|
// packages/cli/src/commands/create.ts
|
|
164
108
|
async function create() {
|
|
@@ -308,28 +252,28 @@ async function provisionCloudflareResources(context) {
|
|
|
308
252
|
placement: {
|
|
309
253
|
mode: "smart"
|
|
310
254
|
},
|
|
255
|
+
kv_namespaces: [
|
|
256
|
+
{
|
|
257
|
+
binding: "KV"
|
|
258
|
+
}
|
|
259
|
+
],
|
|
260
|
+
d1_databases: [
|
|
261
|
+
{
|
|
262
|
+
binding: "DB",
|
|
263
|
+
migrations_dir: "./src/lib/db/migrations"
|
|
264
|
+
}
|
|
265
|
+
],
|
|
266
|
+
r2_buckets: [
|
|
267
|
+
{
|
|
268
|
+
binding: "BUCKET"
|
|
269
|
+
}
|
|
270
|
+
],
|
|
311
271
|
observability: {
|
|
312
272
|
enabled: true
|
|
313
273
|
}
|
|
314
274
|
};
|
|
315
275
|
await writeWranglerConfig(`${context.localPath}/wrangler.json`, wranglerConfig);
|
|
316
|
-
const results = [];
|
|
317
|
-
context.spinner.message(`Creating KV namespace`);
|
|
318
|
-
results.push(await createKVNamespace(context.appName, context.localPath));
|
|
319
|
-
context.spinner.message(`Creating D1 database`);
|
|
320
|
-
results.push(await createD1Database(context.appName, context.localPath));
|
|
321
|
-
context.spinner.message(`Creating R2 bucket`);
|
|
322
|
-
results.push(await createR2Bucket(context.appName, context.localPath));
|
|
323
|
-
for (const result of results) {
|
|
324
|
-
if (!result.success) {
|
|
325
|
-
import_prompts2.log.error(result.message);
|
|
326
|
-
process.exit(0);
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
276
|
context.spinner.stop("Cloudflare resources created and wrangler.json updated");
|
|
330
|
-
const allResults = results.map((r) => r.message);
|
|
331
|
-
import_prompts2.note(allResults.join(`
|
|
332
|
-
`), "Here's what we did:");
|
|
333
277
|
}
|
|
334
278
|
async function cleanup(context) {
|
|
335
279
|
context.spinner.start("Removing unnecessary files from the template");
|
|
@@ -374,5 +318,5 @@ if (command === "create" && subcommand === "app") {
|
|
|
374
318
|
}
|
|
375
319
|
})
|
|
376
320
|
|
|
377
|
-
//# debugId=
|
|
321
|
+
//# debugId=E2479D2B09267A6964756E2164756E21
|
|
378
322
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js
CHANGED
|
@@ -94,62 +94,6 @@ async function ensureWranglerSessionExists(s) {
|
|
|
94
94
|
async function writeWranglerConfig(location, config) {
|
|
95
95
|
return await writeFile(location, JSON.stringify(config, null, 2));
|
|
96
96
|
}
|
|
97
|
-
async function createD1Database(name, cwd) {
|
|
98
|
-
try {
|
|
99
|
-
await runWranglerCommand(["d1", "create", name, "--binding=DB", "--update-config=true"], cwd);
|
|
100
|
-
return {
|
|
101
|
-
success: true,
|
|
102
|
-
message: `✅ D1 Database: ${name} created!`
|
|
103
|
-
};
|
|
104
|
-
} catch (error) {
|
|
105
|
-
return {
|
|
106
|
-
success: false,
|
|
107
|
-
message: `❌ D1 Database: ${error.stderr || error.stdout || error.message}`
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
async function createKVNamespace(name, cwd) {
|
|
112
|
-
try {
|
|
113
|
-
await runWranglerCommand([
|
|
114
|
-
"kv",
|
|
115
|
-
"namespace",
|
|
116
|
-
"create",
|
|
117
|
-
name,
|
|
118
|
-
"--binding=KV",
|
|
119
|
-
"--update-config=true"
|
|
120
|
-
], cwd);
|
|
121
|
-
return {
|
|
122
|
-
success: true,
|
|
123
|
-
message: `✅ KV Namespace: ${name} created!`
|
|
124
|
-
};
|
|
125
|
-
} catch (error) {
|
|
126
|
-
return {
|
|
127
|
-
success: false,
|
|
128
|
-
message: `❌ KV Namespace: ${error.stderr || error.stdout || error.message}`
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
async function createR2Bucket(name, cwd) {
|
|
133
|
-
try {
|
|
134
|
-
await runWranglerCommand([
|
|
135
|
-
"r2",
|
|
136
|
-
"bucket",
|
|
137
|
-
"create",
|
|
138
|
-
name,
|
|
139
|
-
"--binding=BUCKET",
|
|
140
|
-
"--update-config=true"
|
|
141
|
-
], cwd);
|
|
142
|
-
return {
|
|
143
|
-
success: true,
|
|
144
|
-
message: `✅ KV Namespace: ${name} created!`
|
|
145
|
-
};
|
|
146
|
-
} catch (error) {
|
|
147
|
-
return {
|
|
148
|
-
success: false,
|
|
149
|
-
message: `❌ KV Namespace: ${error.stderr || error.stdout || error.message}`
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
97
|
|
|
154
98
|
// packages/cli/src/commands/create.ts
|
|
155
99
|
async function create() {
|
|
@@ -299,28 +243,28 @@ async function provisionCloudflareResources(context) {
|
|
|
299
243
|
placement: {
|
|
300
244
|
mode: "smart"
|
|
301
245
|
},
|
|
246
|
+
kv_namespaces: [
|
|
247
|
+
{
|
|
248
|
+
binding: "KV"
|
|
249
|
+
}
|
|
250
|
+
],
|
|
251
|
+
d1_databases: [
|
|
252
|
+
{
|
|
253
|
+
binding: "DB",
|
|
254
|
+
migrations_dir: "./src/lib/db/migrations"
|
|
255
|
+
}
|
|
256
|
+
],
|
|
257
|
+
r2_buckets: [
|
|
258
|
+
{
|
|
259
|
+
binding: "BUCKET"
|
|
260
|
+
}
|
|
261
|
+
],
|
|
302
262
|
observability: {
|
|
303
263
|
enabled: true
|
|
304
264
|
}
|
|
305
265
|
};
|
|
306
266
|
await writeWranglerConfig(`${context.localPath}/wrangler.json`, wranglerConfig);
|
|
307
|
-
const results = [];
|
|
308
|
-
context.spinner.message(`Creating KV namespace`);
|
|
309
|
-
results.push(await createKVNamespace(context.appName, context.localPath));
|
|
310
|
-
context.spinner.message(`Creating D1 database`);
|
|
311
|
-
results.push(await createD1Database(context.appName, context.localPath));
|
|
312
|
-
context.spinner.message(`Creating R2 bucket`);
|
|
313
|
-
results.push(await createR2Bucket(context.appName, context.localPath));
|
|
314
|
-
for (const result of results) {
|
|
315
|
-
if (!result.success) {
|
|
316
|
-
log.error(result.message);
|
|
317
|
-
process.exit(0);
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
267
|
context.spinner.stop("Cloudflare resources created and wrangler.json updated");
|
|
321
|
-
const allResults = results.map((r) => r.message);
|
|
322
|
-
note(allResults.join(`
|
|
323
|
-
`), "Here's what we did:");
|
|
324
268
|
}
|
|
325
269
|
async function cleanup(context) {
|
|
326
270
|
context.spinner.start("Removing unnecessary files from the template");
|
|
@@ -364,5 +308,5 @@ if (command === "create" && subcommand === "app") {
|
|
|
364
308
|
process.exit(1);
|
|
365
309
|
}
|
|
366
310
|
|
|
367
|
-
//# debugId=
|
|
311
|
+
//# debugId=599C9D94C4A67E8B64756E2164756E21
|
|
368
312
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -2,13 +2,13 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["packages/cli/src/commands/create.ts", "packages/cli/src/constants.ts", "packages/cli/src/utils.ts", "packages/cli/src/wrangler.ts", "packages/cli/src/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import * as fs from 'node:fs'\nimport * as path from 'node:path'\nimport {\n\tintro,\n\tisCancel,\n\tlog,\n\tnote,\n\toutro,\n\tspinner,\n\ttext,\n} from '@clack/prompts'\nimport { Octokit } from 'octokit'\nimport color from 'picocolors'\nimport { APP_REFERENCE_NAME } from '../constants'\nimport type { PartialCreateContext, ValidatedCreateContext } from '../types'\nimport { GITHUB_INFO } from '../utils'\nimport {\n\
|
|
5
|
+
"import * as fs from 'node:fs'\nimport * as path from 'node:path'\nimport {\n\tintro,\n\tisCancel,\n\tlog,\n\tnote,\n\toutro,\n\tspinner,\n\ttext,\n} from '@clack/prompts'\nimport { Octokit } from 'octokit'\nimport color from 'picocolors'\nimport { APP_REFERENCE_NAME } from '../constants'\nimport type { PartialCreateContext, ValidatedCreateContext } from '../types'\nimport { GITHUB_INFO } from '../utils'\nimport { ensureWranglerSessionExists, writeWranglerConfig } from '../wrangler'\n\n/**\n * TODO: Instead of removing the shopify.app.toml we should probably do something so when it creates the new app it'll keep the scopes and anything else relevant\n * TODO: Once the new .app.toml is made we need the .env to be created and then `cf-typegen` to be run so we can commit\n * TODO: The migrations_dir for the d1_database entry in the wrangler.json is getting flushed. We need to add this and run db:migrate\n */\n\nexport async function create(): Promise<void> {\n\tconst initialContext = await initializeContext()\n\n\tconst context = await validateEnvironment(initialContext)\n\n\tawait createGithubRepository(context)\n\tawait cloneGithubRepository(context)\n\tawait provisionCloudflareResources(context)\n\tawait cleanup(context)\n\n\tnote(\n\t\t[\n\t\t\t`1. cd ${context.localPath}`,\n\t\t\t'2. shopify app config link',\n\t\t\t'3. bun run dev',\n\t\t].join(`\\n`),\n\t\t`${color.bgYellow(color.black('Next steps.'))}`,\n\t)\n\n\toutro(\n\t\t`Go and build something ${color.underline(color.italic(color.yellow('stupendous')))}.`,\n\t)\n}\n\nasync function initializeContext(): Promise<PartialCreateContext> {\n\tintro(`Setting up a new BAO ${APP_REFERENCE_NAME} project`)\n\n\tconst appName = await text({\n\t\tmessage: 'What is the name of your project?',\n\t\tplaceholder: `my-${APP_REFERENCE_NAME.toLowerCase()}-project`,\n\t\tvalidate: (value) => {\n\t\t\tif (typeof value === 'undefined') return `You must provide a value`\n\n\t\t\tif (!value.match(/^[a-z0-9-]+$/)) {\n\t\t\t\treturn `Invalid app name: ${value}. App names can only contain lowercase letters, numbers, and dashes.`\n\t\t\t}\n\t\t},\n\t})\n\n\tif (isCancel(appName)) {\n\t\toutro(color.red('An app name is required to continue'))\n\n\t\tprocess.exit(1)\n\t}\n\n\tconst repoName = `${String(appName)}-app`\n\tconst localPath = `./${repoName}`\n\n\tif (fs.existsSync(localPath)) {\n\t\tlog.error(`Unable to continue as ${localPath} already exists`)\n\n\t\tprocess.exit(0)\n\t}\n\n\tconst s = spinner()\n\n\treturn {\n\t\tappName: String(appName),\n\t\trepoName,\n\t\tlocalPath,\n\t\tspinner: s,\n\t}\n}\n\nasync function validateEnvironment(\n\tinitialContext: PartialCreateContext,\n): Promise<ValidatedCreateContext> {\n\tinitialContext.spinner.start(\n\t\t'Welcome! Checking to make sure your environment is set up correctly.',\n\t)\n\n\tconst hasEnvironmentAccessToken =\n\t\ttypeof process.env.GITHUB_TOKEN !== 'undefined' &&\n\t\tprocess.env.GITHUB_TOKEN.trim() !== ''\n\n\tif (!hasEnvironmentAccessToken) {\n\t\tlog.warning(\n\t\t\t`Unable to find a GITHUB_TOKEN environment variable. Please go to https://github.com/settings/tokens/new?description=BAO%20CLI&scopes=repo and create an access token to be able to use the CLI.`,\n\t\t)\n\t}\n\n\tconst githubAccessToken =\n\t\tprocess.env.GITHUB_TOKEN ||\n\t\t(await text({\n\t\t\tmessage: 'Access token',\n\t\t}))\n\n\ttry {\n\t\tawait testGithubAccessTokenIsValid(String(githubAccessToken))\n\t} catch (error: any) {\n\t\tlog.error(`Invalid access token: ${error.message}`)\n\n\t\tprocess.exit(0)\n\t}\n\n\tawait ensureWranglerSessionExists(initialContext.spinner)\n\n\tinitialContext.spinner.stop('Validated environment')\n\n\tnote(\n\t\t'Before using R2, Queues, and Durable objects,\\n' +\n\t\t\t\"make sure you've enabled them in the Cloudflare Dashboard.\\n\" +\n\t\t\t'https://dash.cloudflare.com/\\n' +\n\t\t\t'Otherwise, the following commands might fail! 😬',\n\t\t'👋 Heads-up:',\n\t)\n\n\treturn {\n\t\t...initialContext,\n\t\tgithubPersonalAccessToken: String(githubAccessToken),\n\t\tcloudflare: {},\n\t}\n}\n\nasync function testGithubAccessTokenIsValid(\n\taccessToken: string,\n): Promise<string> {\n\tconst octokit = new Octokit({\n\t\tauth: accessToken,\n\t})\n\n\tconst {\n\t\tdata: { login },\n\t} = await octokit.rest.users.getAuthenticated()\n\n\treturn login\n}\n\nasync function createGithubRepository(\n\tcontext: ValidatedCreateContext,\n): Promise<void> {\n\tcontext.spinner.start(`Creating GitHub Repository ${context.repoName}`)\n\n\tconst octokit = new Octokit({\n\t\tauth: context.githubPersonalAccessToken,\n\t})\n\n\ttry {\n\t\tconst appRepo = await octokit.rest.repos.createUsingTemplate({\n\t\t\ttemplate_owner: GITHUB_INFO.organization,\n\t\t\ttemplate_repo: GITHUB_INFO.templateRepository,\n\t\t\towner: GITHUB_INFO.organization,\n\t\t\tname: context.repoName,\n\t\t\tprivate: true,\n\t\t})\n\n\t\tcontext.repoHttpUrl = appRepo.data.html_url\n\t\tcontext.repoSshUrl = appRepo.data.ssh_url\n\t} catch (error: any) {\n\t\tlog.error(`Unable to create Github Repository ${context.repoName}`)\n\t\tlog.error(error)\n\n\t\tprocess.exit(0)\n\t}\n\n\tcontext.spinner.stop('Github repository created! ⭐')\n}\n\nasync function cloneGithubRepository(context: ValidatedCreateContext) {\n\tif (typeof context.repoSshUrl === 'undefined') {\n\t\tlog.error(\n\t\t\t`Unable to clone Github repository ${context.repoName} as can't find the .git URL`,\n\t\t)\n\n\t\tprocess.exit(0)\n\t}\n\n\tcontext.spinner.start(`Cloning ${context.repoName} from GitHub`)\n\n\tawait new Promise((resolve) => setTimeout(resolve, 5000))\n\n\tconst child = Bun.spawn(\n\t\t['git', 'clone', context.repoSshUrl, context.localPath],\n\t\t{\n\t\t\tstderr: 'ignore',\n\t\t\tstdout: 'ignore',\n\t\t},\n\t)\n\n\tawait child.exited\n\n\tif (fs.existsSync(context.localPath)) {\n\t\tcontext.spinner.stop(\n\t\t\t`Successfully cloned repository to ${context.localPath}`,\n\t\t)\n\n\t\treturn\n\t}\n\n\tcontext.spinner.stop()\n\tlog.error(`Unable to clone repository`)\n\n\tprocess.exit(0)\n}\n\nasync function provisionCloudflareResources(context: ValidatedCreateContext) {\n\tnote(\n\t\t[\n\t\t\t'Creating the following Cloudflare resources:',\n\t\t\t'- KV',\n\t\t\t'- D1',\n\t\t\t'- R2 Bucket',\n\t\t].join(`\\n`),\n\t)\n\n\tcontext.spinner.start(`Creating Cloudflare resources`)\n\n\tconst wranglerConfig = {\n\t\t$schema: 'node_modules/wrangler/config-schema.json',\n\t\tname: context.appName,\n\t\tcompatibility_date: '2025-09-21',\n\t\tcompatibility_flags: ['nodejs_compat'],\n\t\tmain: '@tanstack/react-start/server-entry',\n\t\tdev: {\n\t\t\tip: '0.0.0.0',\n\t\t\tport: 8647,\n\t\t},\n\t\tupload_source_maps: true,\n\t\tplacement: {\n\t\t\tmode: 'smart',\n\t\t},\n\t\tkv_namespaces: [\n\t\t\t{\n\t\t\t\tbinding: 'KV',\n\t\t\t},\n\t\t],\n\t\td1_databases: [\n\t\t\t{\n\t\t\t\tbinding: 'DB',\n\t\t\t\tmigrations_dir: './src/lib/db/migrations',\n\t\t\t},\n\t\t],\n\t\tr2_buckets: [\n\t\t\t{\n\t\t\t\tbinding: 'BUCKET',\n\t\t\t},\n\t\t],\n\t\tobservability: {\n\t\t\tenabled: true,\n\t\t},\n\t}\n\n\tawait writeWranglerConfig(\n\t\t`${context.localPath}/wrangler.json`,\n\t\twranglerConfig,\n\t)\n\n\tcontext.spinner.stop('Cloudflare resources created and wrangler.json updated')\n}\n\nasync function cleanup(context: ValidatedCreateContext) {\n\tcontext.spinner.start('Removing unnecessary files from the template')\n\n\tfs.unlinkSync(path.join(context.localPath, 'shopify.app.toml'))\n\tfs.unlinkSync(path.join(context.localPath, 'shopify.app.production.toml'))\n\n\tnote(\n\t\t[\n\t\t\t'- Removed default shopify.app.toml',\n\t\t\t'- Removed default shopify.app.production.toml',\n\t\t].join(`\\n`),\n\t\t'🧹 Cleaning up',\n\t)\n\n\tcontext.spinner.message('Installing packages')\n\n\tconst packageInstall = Bun.spawn(['bun', 'install'], {\n\t\tstderr: 'ignore',\n\t\tstdout: 'ignore',\n\t\tcwd: context.localPath,\n\t})\n\tawait packageInstall.exited\n\n\tcontext.spinner.message('Finalising app setup')\n\n\tconst gitAdd = Bun.spawn(['git', 'add', '.'], {\n\t\tstderr: 'ignore',\n\t\tstdout: 'ignore',\n\t\tcwd: context.localPath,\n\t})\n\tawait gitAdd.exited\n\n\tconst gitCommit = Bun.spawn(['git', 'commit', '-m', 'App setup'], {\n\t\tstderr: 'ignore',\n\t\tstdout: 'ignore',\n\t\tcwd: context.localPath,\n\t})\n\tawait gitCommit.exited\n\n\tcontext.spinner.stop()\n}\n",
|
|
6
6
|
"export const APP_REFERENCE_NAME = 'Unisian'\n",
|
|
7
7
|
"export const PACKAGE_RUNNER_COMMAND = 'bunx'\n\nexport const GITHUB_INFO = {\n\torganization: 'baoagency',\n\ttemplateRepository: 'unisian',\n} as const\n",
|
|
8
|
-
"import { readFile, writeFile } from 'node:fs/promises'\nimport { cancel, confirm, isCancel, type spinner } from '@clack/prompts'\nimport { APP_REFERENCE_NAME } from './constants'\nimport { PACKAGE_RUNNER_COMMAND } from './utils'\n\nexport async function runWranglerCommand(\n\tcommand: string[],\n\tcwd?: string,\n): Promise<{\n\tcode: number\n\tstdout: string\n\tstderr: string\n}> {\n\tconst child = Bun.spawn(\n\t\t[PACKAGE_RUNNER_COMMAND, 'wrangler@latest', ...command],\n\t\t{\n\t\t\tstdin: 'pipe',\n\t\t\tstderr: 'pipe',\n\t\t\tcwd,\n\t\t\tenv: {\n\t\t\t\t...process.env,\n\t\t\t\tCLOUDFLARE_ACCOUNT_ID: '824c12820335788e8daf77dba7e7891e',\n\t\t\t},\n\t\t},\n\t)\n\n\tconst stdout = await new Response(child.stdout).text()\n\tconst stderr = await new Response(child.stderr).text()\n\tconst code = await child.exited\n\n\treturn new Promise((resolve, reject) => {\n\t\tif (code === 0) {\n\t\t\tresolve({\n\t\t\t\tcode,\n\t\t\t\tstdout,\n\t\t\t\tstderr,\n\t\t\t})\n\t\t}\n\n\t\treject({\n\t\t\tcode,\n\t\t\tstdout,\n\t\t\tstderr,\n\t\t})\n\t})\n}\n\nexport async function ensureWranglerAuthenticated(): Promise<boolean> {\n\ttry {\n\t\tconst result = await runWranglerCommand(['whoami'])\n\n\t\treturn !result.stdout.includes('You are not authenticated')\n\t} catch {\n\t\t// Some older versions of Wrangler return a non-zero exit code when\n\t\t// you're not logged in.\n\t\treturn false\n\t}\n}\n\nexport async function wranglerLogin(): Promise<void> {\n\tconst child = Bun.spawn([PACKAGE_RUNNER_COMMAND, 'wrangler', 'login'], {\n\t\tstdin: 'inherit',\n\t})\n\tconst code = await child.exited\n\n\treturn await new Promise((resolve, reject) => {\n\t\tif (code === 0) {\n\t\t\tresolve()\n\t\t}\n\n\t\treject()\n\t})\n}\n\nexport async function ensureWranglerSessionExists(\n\ts: ReturnType<typeof spinner>,\n): Promise<void> {\n\ts.message(\n\t\t'Checking to make sure you have the Wrangler CLI installed and authenticated...',\n\t)\n\n\tif (!(await ensureWranglerAuthenticated())) {\n\t\ts.stop(\"Hmm. Looks like you're not logged in yet.\")\n\n\t\tconst wantsToLogIn = await confirm({\n\t\t\tmessage: `You need to be logged into wrangler to setup a ${APP_REFERENCE_NAME} app. Log in now?`,\n\t\t})\n\n\t\tif (isCancel(wantsToLogIn) || !wantsToLogIn) {\n\t\t\tcancel(\n\t\t\t\t`You need to be logged into wrangler to be able to setup a ${APP_REFERENCE_NAME} app.`,\n\t\t\t)\n\n\t\t\tprocess.exit(0)\n\t\t}\n\n\t\tawait wranglerLogin()\n\t}\n}\n\nexport async function getCurrentWranglerConfig(\n\tlocation: string,\n): Promise<Record<string, any>> {\n\treturn JSON.parse(await readFile(location, 'utf-8'))\n}\n\nexport async function writeWranglerConfig(\n\tlocation: string,\n\tconfig: Record<string, any>,\n): Promise<void> {\n\treturn await writeFile(location, JSON.stringify(config, null, 2))\n}\n
|
|
8
|
+
"import { readFile, writeFile } from 'node:fs/promises'\nimport { cancel, confirm, isCancel, type spinner } from '@clack/prompts'\nimport { APP_REFERENCE_NAME } from './constants'\nimport { PACKAGE_RUNNER_COMMAND } from './utils'\n\nexport async function runWranglerCommand(\n\tcommand: string[],\n\tcwd?: string,\n): Promise<{\n\tcode: number\n\tstdout: string\n\tstderr: string\n}> {\n\tconst child = Bun.spawn(\n\t\t[PACKAGE_RUNNER_COMMAND, 'wrangler@latest', ...command],\n\t\t{\n\t\t\tstdin: 'pipe',\n\t\t\tstderr: 'pipe',\n\t\t\tcwd,\n\t\t\tenv: {\n\t\t\t\t...process.env,\n\t\t\t\tCLOUDFLARE_ACCOUNT_ID: '824c12820335788e8daf77dba7e7891e',\n\t\t\t},\n\t\t},\n\t)\n\n\tconst stdout = await new Response(child.stdout).text()\n\tconst stderr = await new Response(child.stderr).text()\n\tconst code = await child.exited\n\n\treturn new Promise((resolve, reject) => {\n\t\tif (code === 0) {\n\t\t\tresolve({\n\t\t\t\tcode,\n\t\t\t\tstdout,\n\t\t\t\tstderr,\n\t\t\t})\n\t\t}\n\n\t\treject({\n\t\t\tcode,\n\t\t\tstdout,\n\t\t\tstderr,\n\t\t})\n\t})\n}\n\nexport async function ensureWranglerAuthenticated(): Promise<boolean> {\n\ttry {\n\t\tconst result = await runWranglerCommand(['whoami'])\n\n\t\treturn !result.stdout.includes('You are not authenticated')\n\t} catch {\n\t\t// Some older versions of Wrangler return a non-zero exit code when\n\t\t// you're not logged in.\n\t\treturn false\n\t}\n}\n\nexport async function wranglerLogin(): Promise<void> {\n\tconst child = Bun.spawn([PACKAGE_RUNNER_COMMAND, 'wrangler', 'login'], {\n\t\tstdin: 'inherit',\n\t})\n\tconst code = await child.exited\n\n\treturn await new Promise((resolve, reject) => {\n\t\tif (code === 0) {\n\t\t\tresolve()\n\t\t}\n\n\t\treject()\n\t})\n}\n\nexport async function ensureWranglerSessionExists(\n\ts: ReturnType<typeof spinner>,\n): Promise<void> {\n\ts.message(\n\t\t'Checking to make sure you have the Wrangler CLI installed and authenticated...',\n\t)\n\n\tif (!(await ensureWranglerAuthenticated())) {\n\t\ts.stop(\"Hmm. Looks like you're not logged in yet.\")\n\n\t\tconst wantsToLogIn = await confirm({\n\t\t\tmessage: `You need to be logged into wrangler to setup a ${APP_REFERENCE_NAME} app. Log in now?`,\n\t\t})\n\n\t\tif (isCancel(wantsToLogIn) || !wantsToLogIn) {\n\t\t\tcancel(\n\t\t\t\t`You need to be logged into wrangler to be able to setup a ${APP_REFERENCE_NAME} app.`,\n\t\t\t)\n\n\t\t\tprocess.exit(0)\n\t\t}\n\n\t\tawait wranglerLogin()\n\t}\n}\n\nexport async function getCurrentWranglerConfig(\n\tlocation: string,\n): Promise<Record<string, any>> {\n\treturn JSON.parse(await readFile(location, 'utf-8'))\n}\n\nexport async function writeWranglerConfig(\n\tlocation: string,\n\tconfig: Record<string, any>,\n): Promise<void> {\n\treturn await writeFile(location, JSON.stringify(config, null, 2))\n}\n",
|
|
9
9
|
"#!/usr/bin/env bun\n\nimport { create } from './commands/create'\n\nconst args = Bun.argv.slice(2)\nconst [command, subcommand] = args\n\nif (command === 'create' && subcommand === 'app') {\n\tcreate().catch(console.error)\n} else {\n\tconsole.error('Unknown command. Usage: bao create app')\n\n\tprocess.exit(1)\n}\n"
|
|
10
10
|
],
|
|
11
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;AAAoB,IAApB;AACsB,IAAtB;AASO,IARP;AASwB,IAAxB;AACkB,IAAlB;;;ACZO,IAAM,qBAAqB;;;ACA3B,IAAM,yBAAyB;AAE/B,IAAM,cAAc;AAAA,EAC1B,cAAc;AAAA,EACd,oBAAoB;AACrB;;;ACLoC,IAApC;AACwD,IAAxD;AAIA,eAAsB,kBAAkB,CACvC,SACA,KAKE;AAAA,EACF,MAAM,QAAQ,IAAI,MACjB,CAAC,wBAAwB,mBAAmB,GAAG,OAAO,GACtD;AAAA,IACC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR;AAAA,IACA,KAAK;AAAA,SACD,QAAQ;AAAA,MACX,uBAAuB;AAAA,IACxB;AAAA,EACD,CACD;AAAA,EAEA,MAAM,SAAS,MAAM,IAAI,SAAS,MAAM,MAAM,EAAE,KAAK;AAAA,EACrD,MAAM,SAAS,MAAM,IAAI,SAAS,MAAM,MAAM,EAAE,KAAK;AAAA,EACrD,MAAM,OAAO,MAAM,MAAM;AAAA,EAEzB,OAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAAA,IACvC,IAAI,SAAS,GAAG;AAAA,MACf,QAAQ;AAAA,QACP;AAAA,QACA;AAAA,QACA;AAAA,MACD,CAAC;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,MACN;AAAA,MACA;AAAA,MACA;AAAA,IACD,CAAC;AAAA,GACD;AAAA;AAGF,eAAsB,2BAA2B,GAAqB;AAAA,EACrE,IAAI;AAAA,IACH,MAAM,SAAS,MAAM,mBAAmB,CAAC,QAAQ,CAAC;AAAA,IAElD,OAAO,CAAC,OAAO,OAAO,SAAS,2BAA2B;AAAA,IACzD,MAAM;AAAA,IAGP,OAAO;AAAA;AAAA;AAIT,eAAsB,aAAa,GAAkB;AAAA,EACpD,MAAM,QAAQ,IAAI,MAAM,CAAC,wBAAwB,YAAY,OAAO,GAAG;AAAA,IACtE,OAAO;AAAA,EACR,CAAC;AAAA,EACD,MAAM,OAAO,MAAM,MAAM;AAAA,EAEzB,OAAO,MAAM,IAAI,QAAQ,CAAC,SAAS,WAAW;AAAA,IAC7C,IAAI,SAAS,GAAG;AAAA,MACf,QAAQ;AAAA,IACT;AAAA,IAEA,OAAO;AAAA,GACP;AAAA;AAGF,eAAsB,2BAA2B,CAChD,GACgB;AAAA,EAChB,EAAE,QACD,gFACD;AAAA,EAEA,IAAI,CAAE,MAAM,4BAA4B,GAAI;AAAA,IAC3C,EAAE,KAAK,2CAA2C;AAAA,IAElD,MAAM,eAAe,MAAM,uBAAQ;AAAA,MAClC,SAAS,kDAAkD;AAAA,IAC5D,CAAC;AAAA,IAED,IAAI,wBAAS,YAAY,KAAK,CAAC,cAAc;AAAA,MAC5C,sBACC,6DAA6D,yBAC9D;AAAA,MAEA,QAAQ,KAAK,CAAC;AAAA,IACf;AAAA,IAEA,MAAM,cAAc;AAAA,EACrB;AAAA;AASD,eAAsB,mBAAmB,CACxC,UACA,QACgB;AAAA,EAChB,OAAO,MAAM,0BAAU,UAAU,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC;AAAA
|
|
12
|
-
"debugId": "
|
|
11
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;AAAoB,IAApB;AACsB,IAAtB;AASO,IARP;AASwB,IAAxB;AACkB,IAAlB;;;ACZO,IAAM,qBAAqB;;;ACA3B,IAAM,yBAAyB;AAE/B,IAAM,cAAc;AAAA,EAC1B,cAAc;AAAA,EACd,oBAAoB;AACrB;;;ACLoC,IAApC;AACwD,IAAxD;AAIA,eAAsB,kBAAkB,CACvC,SACA,KAKE;AAAA,EACF,MAAM,QAAQ,IAAI,MACjB,CAAC,wBAAwB,mBAAmB,GAAG,OAAO,GACtD;AAAA,IACC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR;AAAA,IACA,KAAK;AAAA,SACD,QAAQ;AAAA,MACX,uBAAuB;AAAA,IACxB;AAAA,EACD,CACD;AAAA,EAEA,MAAM,SAAS,MAAM,IAAI,SAAS,MAAM,MAAM,EAAE,KAAK;AAAA,EACrD,MAAM,SAAS,MAAM,IAAI,SAAS,MAAM,MAAM,EAAE,KAAK;AAAA,EACrD,MAAM,OAAO,MAAM,MAAM;AAAA,EAEzB,OAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAAA,IACvC,IAAI,SAAS,GAAG;AAAA,MACf,QAAQ;AAAA,QACP;AAAA,QACA;AAAA,QACA;AAAA,MACD,CAAC;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,MACN;AAAA,MACA;AAAA,MACA;AAAA,IACD,CAAC;AAAA,GACD;AAAA;AAGF,eAAsB,2BAA2B,GAAqB;AAAA,EACrE,IAAI;AAAA,IACH,MAAM,SAAS,MAAM,mBAAmB,CAAC,QAAQ,CAAC;AAAA,IAElD,OAAO,CAAC,OAAO,OAAO,SAAS,2BAA2B;AAAA,IACzD,MAAM;AAAA,IAGP,OAAO;AAAA;AAAA;AAIT,eAAsB,aAAa,GAAkB;AAAA,EACpD,MAAM,QAAQ,IAAI,MAAM,CAAC,wBAAwB,YAAY,OAAO,GAAG;AAAA,IACtE,OAAO;AAAA,EACR,CAAC;AAAA,EACD,MAAM,OAAO,MAAM,MAAM;AAAA,EAEzB,OAAO,MAAM,IAAI,QAAQ,CAAC,SAAS,WAAW;AAAA,IAC7C,IAAI,SAAS,GAAG;AAAA,MACf,QAAQ;AAAA,IACT;AAAA,IAEA,OAAO;AAAA,GACP;AAAA;AAGF,eAAsB,2BAA2B,CAChD,GACgB;AAAA,EAChB,EAAE,QACD,gFACD;AAAA,EAEA,IAAI,CAAE,MAAM,4BAA4B,GAAI;AAAA,IAC3C,EAAE,KAAK,2CAA2C;AAAA,IAElD,MAAM,eAAe,MAAM,uBAAQ;AAAA,MAClC,SAAS,kDAAkD;AAAA,IAC5D,CAAC;AAAA,IAED,IAAI,wBAAS,YAAY,KAAK,CAAC,cAAc;AAAA,MAC5C,sBACC,6DAA6D,yBAC9D;AAAA,MAEA,QAAQ,KAAK,CAAC;AAAA,IACf;AAAA,IAEA,MAAM,cAAc;AAAA,EACrB;AAAA;AASD,eAAsB,mBAAmB,CACxC,UACA,QACgB;AAAA,EAChB,OAAO,MAAM,0BAAU,UAAU,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC;AAAA;;;AHtFjE,eAAsB,MAAM,GAAkB;AAAA,EAC7C,MAAM,iBAAiB,MAAM,kBAAkB;AAAA,EAE/C,MAAM,UAAU,MAAM,oBAAoB,cAAc;AAAA,EAExD,MAAM,uBAAuB,OAAO;AAAA,EACpC,MAAM,sBAAsB,OAAO;AAAA,EACnC,MAAM,6BAA6B,OAAO;AAAA,EAC1C,MAAM,QAAQ,OAAO;AAAA,EAErB,qBACC;AAAA,IACC,SAAS,QAAQ;AAAA,IACjB;AAAA,IACA;AAAA,EACD,EAAE,KAAK;AAAA,CAAI,GACX,GAAG,0BAAM,SAAS,0BAAM,MAAM,aAAa,CAAC,GAC7C;AAAA,EAEA,sBACC,0BAA0B,0BAAM,UAAU,0BAAM,OAAO,0BAAM,OAAO,YAAY,CAAC,CAAC,IACnF;AAAA;AAGD,eAAe,iBAAiB,GAAkC;AAAA,EACjE,sBAAM,wBAAwB,4BAA4B;AAAA,EAE1D,MAAM,UAAU,MAAM,qBAAK;AAAA,IAC1B,SAAS;AAAA,IACT,aAAa,MAAM,mBAAmB,YAAY;AAAA,IAClD,UAAU,CAAC,UAAU;AAAA,MACpB,IAAI,OAAO,UAAU;AAAA,QAAa,OAAO;AAAA,MAEzC,IAAI,CAAC,MAAM,MAAM,cAAc,GAAG;AAAA,QACjC,OAAO,qBAAqB;AAAA,MAC7B;AAAA;AAAA,EAEF,CAAC;AAAA,EAED,IAAI,yBAAS,OAAO,GAAG;AAAA,IACtB,sBAAM,0BAAM,IAAI,qCAAqC,CAAC;AAAA,IAEtD,QAAQ,KAAK,CAAC;AAAA,EACf;AAAA,EAEA,MAAM,WAAW,GAAG,OAAO,OAAO;AAAA,EAClC,MAAM,YAAY,KAAK;AAAA,EAEvB,IAAO,cAAW,SAAS,GAAG;AAAA,IAC7B,oBAAI,MAAM,yBAAyB,0BAA0B;AAAA,IAE7D,QAAQ,KAAK,CAAC;AAAA,EACf;AAAA,EAEA,MAAM,IAAI,wBAAQ;AAAA,EAElB,OAAO;AAAA,IACN,SAAS,OAAO,OAAO;AAAA,IACvB;AAAA,IACA;AAAA,IACA,SAAS;AAAA,EACV;AAAA;AAGD,eAAe,mBAAmB,CACjC,gBACkC;AAAA,EAClC,eAAe,QAAQ,MACtB,sEACD;AAAA,EAEA,MAAM,4BACL,OAAO,QAAQ,IAAI,iBAAiB,eACpC,QAAQ,IAAI,aAAa,KAAK,MAAM;AAAA,EAErC,IAAI,CAAC,2BAA2B;AAAA,IAC/B,oBAAI,QACH,iMACD;AAAA,EACD;AAAA,EAEA,MAAM,oBACL,QAAQ,IAAI,gBACX,MAAM,qBAAK;AAAA,IACX,SAAS;AAAA,EACV,CAAC;AAAA,EAEF,IAAI;AAAA,IACH,MAAM,6BAA6B,OAAO,iBAAiB,CAAC;AAAA,IAC3D,OAAO,OAAY;AAAA,IACpB,oBAAI,MAAM,yBAAyB,MAAM,SAAS;AAAA,IAElD,QAAQ,KAAK,CAAC;AAAA;AAAA,EAGf,MAAM,4BAA4B,eAAe,OAAO;AAAA,EAExD,eAAe,QAAQ,KAAK,uBAAuB;AAAA,EAEnD,qBACC;AAAA,IACC;AAAA,IACA;AAAA,IACA,8DACD,wBACD;AAAA,EAEA,OAAO;AAAA,OACH;AAAA,IACH,2BAA2B,OAAO,iBAAiB;AAAA,IACnD,YAAY,CAAC;AAAA,EACd;AAAA;AAGD,eAAe,4BAA4B,CAC1C,aACkB;AAAA,EAClB,MAAM,UAAU,IAAI,uBAAQ;AAAA,IAC3B,MAAM;AAAA,EACP,CAAC;AAAA,EAED;AAAA,IACC,QAAQ;AAAA,MACL,MAAM,QAAQ,KAAK,MAAM,iBAAiB;AAAA,EAE9C,OAAO;AAAA;AAGR,eAAe,sBAAsB,CACpC,SACgB;AAAA,EAChB,QAAQ,QAAQ,MAAM,8BAA8B,QAAQ,UAAU;AAAA,EAEtE,MAAM,UAAU,IAAI,uBAAQ;AAAA,IAC3B,MAAM,QAAQ;AAAA,EACf,CAAC;AAAA,EAED,IAAI;AAAA,IACH,MAAM,UAAU,MAAM,QAAQ,KAAK,MAAM,oBAAoB;AAAA,MAC5D,gBAAgB,YAAY;AAAA,MAC5B,eAAe,YAAY;AAAA,MAC3B,OAAO,YAAY;AAAA,MACnB,MAAM,QAAQ;AAAA,MACd,SAAS;AAAA,IACV,CAAC;AAAA,IAED,QAAQ,cAAc,QAAQ,KAAK;AAAA,IACnC,QAAQ,aAAa,QAAQ,KAAK;AAAA,IACjC,OAAO,OAAY;AAAA,IACpB,oBAAI,MAAM,sCAAsC,QAAQ,UAAU;AAAA,IAClE,oBAAI,MAAM,KAAK;AAAA,IAEf,QAAQ,KAAK,CAAC;AAAA;AAAA,EAGf,QAAQ,QAAQ,KAAK,8BAA6B;AAAA;AAGnD,eAAe,qBAAqB,CAAC,SAAiC;AAAA,EACrE,IAAI,OAAO,QAAQ,eAAe,aAAa;AAAA,IAC9C,oBAAI,MACH,qCAAqC,QAAQ,qCAC9C;AAAA,IAEA,QAAQ,KAAK,CAAC;AAAA,EACf;AAAA,EAEA,QAAQ,QAAQ,MAAM,WAAW,QAAQ,sBAAsB;AAAA,EAE/D,MAAM,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,IAAI,CAAC;AAAA,EAExD,MAAM,QAAQ,IAAI,MACjB,CAAC,OAAO,SAAS,QAAQ,YAAY,QAAQ,SAAS,GACtD;AAAA,IACC,QAAQ;AAAA,IACR,QAAQ;AAAA,EACT,CACD;AAAA,EAEA,MAAM,MAAM;AAAA,EAEZ,IAAO,cAAW,QAAQ,SAAS,GAAG;AAAA,IACrC,QAAQ,QAAQ,KACf,qCAAqC,QAAQ,WAC9C;AAAA,IAEA;AAAA,EACD;AAAA,EAEA,QAAQ,QAAQ,KAAK;AAAA,EACrB,oBAAI,MAAM,4BAA4B;AAAA,EAEtC,QAAQ,KAAK,CAAC;AAAA;AAGf,eAAe,4BAA4B,CAAC,SAAiC;AAAA,EAC5E,qBACC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD,EAAE,KAAK;AAAA,CAAI,CACZ;AAAA,EAEA,QAAQ,QAAQ,MAAM,+BAA+B;AAAA,EAErD,MAAM,iBAAiB;AAAA,IACtB,SAAS;AAAA,IACT,MAAM,QAAQ;AAAA,IACd,oBAAoB;AAAA,IACpB,qBAAqB,CAAC,eAAe;AAAA,IACrC,MAAM;AAAA,IACN,KAAK;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,IACP;AAAA,IACA,oBAAoB;AAAA,IACpB,WAAW;AAAA,MACV,MAAM;AAAA,IACP;AAAA,IACA,eAAe;AAAA,MACd;AAAA,QACC,SAAS;AAAA,MACV;AAAA,IACD;AAAA,IACA,cAAc;AAAA,MACb;AAAA,QACC,SAAS;AAAA,QACT,gBAAgB;AAAA,MACjB;AAAA,IACD;AAAA,IACA,YAAY;AAAA,MACX;AAAA,QACC,SAAS;AAAA,MACV;AAAA,IACD;AAAA,IACA,eAAe;AAAA,MACd,SAAS;AAAA,IACV;AAAA,EACD;AAAA,EAEA,MAAM,oBACL,GAAG,QAAQ,2BACX,cACD;AAAA,EAEA,QAAQ,QAAQ,KAAK,wDAAwD;AAAA;AAG9E,eAAe,OAAO,CAAC,SAAiC;AAAA,EACvD,QAAQ,QAAQ,MAAM,8CAA8C;AAAA,EAEjE,cAAgB,UAAK,QAAQ,WAAW,kBAAkB,CAAC;AAAA,EAC3D,cAAgB,UAAK,QAAQ,WAAW,6BAA6B,CAAC;AAAA,EAEzE,qBACC;AAAA,IACC;AAAA,IACA;AAAA,EACD,EAAE,KAAK;AAAA,CAAI,GACX,0BACD;AAAA,EAEA,QAAQ,QAAQ,QAAQ,qBAAqB;AAAA,EAE7C,MAAM,iBAAiB,IAAI,MAAM,CAAC,OAAO,SAAS,GAAG;AAAA,IACpD,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,KAAK,QAAQ;AAAA,EACd,CAAC;AAAA,EACD,MAAM,eAAe;AAAA,EAErB,QAAQ,QAAQ,QAAQ,sBAAsB;AAAA,EAE9C,MAAM,SAAS,IAAI,MAAM,CAAC,OAAO,OAAO,GAAG,GAAG;AAAA,IAC7C,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,KAAK,QAAQ;AAAA,EACd,CAAC;AAAA,EACD,MAAM,OAAO;AAAA,EAEb,MAAM,YAAY,IAAI,MAAM,CAAC,OAAO,UAAU,MAAM,WAAW,GAAG;AAAA,IACjE,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,KAAK,QAAQ;AAAA,EACd,CAAC;AAAA,EACD,MAAM,UAAU;AAAA,EAEhB,QAAQ,QAAQ,KAAK;AAAA;;;AIrTtB,IAAM,OAAO,IAAI,KAAK,MAAM,CAAC;AAC7B,KAAO,SAAS,cAAc;AAE9B,IAAI,YAAY,YAAY,eAAe,OAAO;AAAA,EACjD,OAAO,EAAE,MAAM,QAAQ,KAAK;AAC7B,EAAO;AAAA,EACN,QAAQ,MAAM,wCAAwC;AAAA,EAEtD,QAAQ,KAAK,CAAC;AAAA;",
|
|
12
|
+
"debugId": "E2479D2B09267A6964756E2164756E21",
|
|
13
13
|
"names": []
|
|
14
14
|
}
|