apibara 2.1.0-beta.5 → 2.1.0-beta.50

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.
Files changed (119) hide show
  1. package/dist/chunks/add.mjs +16 -8
  2. package/dist/chunks/add.mjs.map +1 -0
  3. package/dist/chunks/build.mjs +4 -2
  4. package/dist/chunks/build.mjs.map +1 -0
  5. package/dist/chunks/dev.mjs +55 -21
  6. package/dist/chunks/dev.mjs.map +1 -0
  7. package/dist/chunks/init.mjs +11 -7
  8. package/dist/chunks/init.mjs.map +1 -0
  9. package/dist/chunks/prepare.mjs +4 -2
  10. package/dist/chunks/prepare.mjs.map +1 -0
  11. package/dist/chunks/start.mjs +16 -4
  12. package/dist/chunks/start.mjs.map +1 -0
  13. package/dist/chunks/write-project-info.mjs +51 -0
  14. package/dist/chunks/write-project-info.mjs.map +1 -0
  15. package/dist/cli/index.mjs +3 -1
  16. package/dist/cli/index.mjs.map +1 -0
  17. package/dist/common/index.d.mts +33 -0
  18. package/dist/common/index.d.ts +33 -0
  19. package/dist/common/index.mjs +91 -0
  20. package/dist/common/index.mjs.map +1 -0
  21. package/dist/config/index.mjs +1 -0
  22. package/dist/config/index.mjs.map +1 -0
  23. package/dist/core/index.mjs +134 -69
  24. package/dist/core/index.mjs.map +1 -0
  25. package/dist/create/index.d.mts +2 -1
  26. package/dist/create/index.d.ts +2 -1
  27. package/dist/create/index.mjs +80 -136
  28. package/dist/create/index.mjs.map +1 -0
  29. package/dist/hooks/index.mjs +6 -1
  30. package/dist/hooks/index.mjs.map +1 -0
  31. package/dist/indexer/index.d.ts +1 -0
  32. package/dist/indexer/index.mjs +1 -0
  33. package/dist/indexer/plugins.d.ts +1 -0
  34. package/dist/indexer/plugins.mjs +1 -0
  35. package/dist/indexer/testing.d.ts +1 -0
  36. package/dist/indexer/testing.mjs +1 -0
  37. package/dist/indexer/vcr.d.ts +1 -0
  38. package/dist/indexer/vcr.mjs +1 -0
  39. package/dist/rolldown/index.d.mts +7 -0
  40. package/dist/rolldown/index.d.ts +7 -0
  41. package/dist/rolldown/index.mjs +141 -0
  42. package/dist/rolldown/index.mjs.map +1 -0
  43. package/dist/runtime/dev.mjs +39 -17
  44. package/dist/runtime/internal/app.d.ts +14 -1
  45. package/dist/runtime/internal/app.mjs +26 -21
  46. package/dist/runtime/project-info.d.ts +3 -0
  47. package/dist/runtime/project-info.mjs +67 -0
  48. package/dist/runtime/start.mjs +78 -11
  49. package/dist/shared/apibara.730bb1e4.mjs +18 -0
  50. package/dist/shared/apibara.730bb1e4.mjs.map +1 -0
  51. package/dist/types/index.d.mts +24 -20
  52. package/dist/types/index.d.ts +24 -20
  53. package/dist/types/index.mjs +1 -0
  54. package/dist/types/index.mjs.map +1 -0
  55. package/package.json +34 -17
  56. package/src/cli/commands/add.ts +16 -7
  57. package/src/cli/commands/build.ts +5 -2
  58. package/src/cli/commands/dev.ts +64 -20
  59. package/src/cli/commands/init.ts +12 -7
  60. package/src/cli/commands/prepare.ts +4 -3
  61. package/src/cli/commands/start.ts +18 -3
  62. package/src/cli/commands/write-project-info.ts +56 -0
  63. package/src/cli/index.ts +2 -0
  64. package/src/common/cli.ts +40 -0
  65. package/src/common/constants.ts +6 -0
  66. package/src/common/helper.ts +86 -0
  67. package/src/common/index.ts +3 -0
  68. package/src/core/apibara.ts +7 -2
  69. package/src/core/build/build.ts +13 -5
  70. package/src/core/build/dev.ts +46 -23
  71. package/src/core/build/error.ts +9 -14
  72. package/src/core/build/prepare.ts +5 -3
  73. package/src/core/build/prod.ts +25 -16
  74. package/src/core/build/types.ts +11 -1
  75. package/src/core/config/defaults.ts +3 -0
  76. package/src/core/config/loader.ts +15 -7
  77. package/src/core/config/resolvers/runtime.resolver.ts +44 -0
  78. package/src/core/config/update.ts +6 -2
  79. package/src/core/scan.ts +1 -1
  80. package/src/create/add.ts +14 -20
  81. package/src/create/constants.ts +5 -7
  82. package/src/create/init.ts +2 -2
  83. package/src/create/templates.ts +43 -116
  84. package/src/create/types.ts +3 -0
  85. package/src/create/utils.ts +20 -7
  86. package/src/hooks/useRuntimeConfig.ts +4 -1
  87. package/src/indexer/index.ts +1 -0
  88. package/src/indexer/plugins.ts +1 -0
  89. package/src/indexer/testing.ts +1 -0
  90. package/src/indexer/vcr.ts +1 -0
  91. package/src/rolldown/config.ts +86 -0
  92. package/src/rolldown/index.ts +2 -0
  93. package/src/{rollup → rolldown}/plugins/indexers.ts +3 -3
  94. package/src/rolldown/plugins/instrumentation.ts +68 -0
  95. package/src/rolldown/plugins/static-config.ts +21 -0
  96. package/src/runtime/dev.ts +49 -19
  97. package/src/runtime/internal/app.ts +42 -29
  98. package/src/runtime/project-info.ts +90 -0
  99. package/src/runtime/start.ts +91 -11
  100. package/src/types/config.ts +27 -13
  101. package/src/types/hooks.ts +8 -5
  102. package/src/types/index.ts +1 -1
  103. package/src/types/rolldown.ts +5 -0
  104. package/src/types/virtual/indexers.d.ts +4 -1
  105. package/src/types/virtual/instrumentation.d.ts +4 -0
  106. package/src/types/virtual/static-config.d.ts +4 -0
  107. package/dist/rollup/index.d.mts +0 -6
  108. package/dist/rollup/index.d.ts +0 -6
  109. package/dist/rollup/index.mjs +0 -150
  110. package/dist/shared/apibara.1b515d04.mjs +0 -8
  111. package/src/cli/common.ts +0 -8
  112. package/src/core/config/resolvers/preset.resolver.ts +0 -9
  113. package/src/core/config/resolvers/runtime-config.resolver.ts +0 -6
  114. package/src/rollup/config.ts +0 -87
  115. package/src/rollup/index.ts +0 -2
  116. package/src/rollup/plugins/config.ts +0 -12
  117. package/src/rollup/plugins/esm-shim.ts +0 -69
  118. package/src/types/rollup.ts +0 -8
  119. package/src/types/virtual/config.d.ts +0 -3
@@ -1,24 +1,11 @@
1
1
  import path, { basename } from 'node:path';
2
2
  import consola$1, { consola } from 'consola';
3
3
  import prompts from 'prompts';
4
- import colors from 'picocolors';
4
+ import { a as blue, y as yellow, c as green, r as red, d as cyan, m as magenta, e as reset } from '../shared/apibara.730bb1e4.mjs';
5
5
  import fs from 'node:fs';
6
6
  import { Project, SyntaxKind } from 'ts-morph';
7
7
  import * as prettier from 'prettier';
8
-
9
- const {
10
- blue,
11
- blueBright,
12
- cyan,
13
- gray,
14
- green,
15
- greenBright,
16
- magenta,
17
- red,
18
- redBright,
19
- reset,
20
- yellow
21
- } = colors;
8
+ import 'picocolors';
22
9
 
23
10
  const chains = [
24
11
  {
@@ -58,7 +45,6 @@ const storages = [
58
45
  const packageVersions = {
59
46
  // Required Dependencies
60
47
  apibara: "next",
61
- "@apibara/indexer": "next",
62
48
  "@apibara/protocol": "next",
63
49
  // Chain Dependencies
64
50
  "@apibara/evm": "next",
@@ -70,21 +56,20 @@ const packageVersions = {
70
56
  "@apibara/plugin-sqlite": "next",
71
57
  // Postgres Dependencies
72
58
  "@electric-sql/pglite": "^0.2.17",
73
- "drizzle-orm": "^0.37.0",
59
+ "drizzle-orm": "^0.40.1",
74
60
  pg: "^8.13.1",
75
61
  "@types/pg": "^8.11.10",
76
62
  "drizzle-kit": "^0.29.0",
77
63
  // Typescript Dependencies
78
64
  typescript: "^5.6.2",
79
- "@rollup/plugin-typescript": "^11.1.6",
80
65
  "@types/node": "^20.5.2"
81
66
  };
82
67
  const dnaUrls = {
83
- ethereum: "https://ethereum.preview.apibara.org",
84
- ethereumSepolia: "https://ethereum-sepolia.preview.apibara.org",
68
+ ethereum: "https://mainnet.ethereum.a5a.ch",
69
+ ethereumSepolia: "https://sepolia.ethereum.a5a.ch",
85
70
  beaconchain: "https://beaconchain.preview.apibara.org",
86
- starknet: "https://starknet.preview.apibara.org",
87
- starknetSepolia: "https://starknet-sepolia.preview.apibara.org"
71
+ starknet: "https://mainnet.starknet.a5a.ch",
72
+ starknetSepolia: "https://sepolia.starknet.a5a.ch"
88
73
  };
89
74
 
90
75
  function isEmpty(path2) {
@@ -106,7 +91,7 @@ function validateLanguage(language, throwError = false) {
106
91
  if (!language) {
107
92
  return false;
108
93
  }
109
- if (language === "typescript" || language === "ts" || language === "javascript" || language === "js") {
94
+ if (language === "typescript" || language === "ts" || language === "javascript" || language === "js" || language === "mjs") {
110
95
  return true;
111
96
  }
112
97
  if (throwError) {
@@ -120,7 +105,7 @@ function getLanguageFromAlias(alias) {
120
105
  if (alias === "ts" || alias === "typescript") {
121
106
  return "typescript";
122
107
  }
123
- if (alias === "js" || alias === "javascript") {
108
+ if (alias === "js" || alias === "javascript" || alias === "mjs") {
124
109
  return "javascript";
125
110
  }
126
111
  throw new Error(
@@ -240,16 +225,21 @@ function validateDnaUrl(dnaUrl, throwError = false) {
240
225
  function hasApibaraConfig(cwd) {
241
226
  const configPathJS = path.join(cwd, "apibara.config.js");
242
227
  const configPathTS = path.join(cwd, "apibara.config.ts");
243
- return fs.existsSync(configPathJS) || fs.existsSync(configPathTS);
228
+ const configPathMJS = path.join(cwd, "apibara.config.mjs");
229
+ return fs.existsSync(configPathJS) || fs.existsSync(configPathTS) || fs.existsSync(configPathMJS);
244
230
  }
245
231
  function getApibaraConfigLanguage(cwd) {
246
232
  const configPathJS = path.join(cwd, "apibara.config.js");
247
233
  const configPathTS = path.join(cwd, "apibara.config.ts");
234
+ const configPathMJS = path.join(cwd, "apibara.config.mjs");
235
+ if (fs.existsSync(configPathMJS)) {
236
+ return { language: "javascript", extension: "mjs" };
237
+ }
248
238
  if (fs.existsSync(configPathJS)) {
249
- return "javascript";
239
+ return { language: "javascript", extension: "js" };
250
240
  }
251
241
  if (fs.existsSync(configPathTS)) {
252
- return "typescript";
242
+ return { language: "typescript", extension: "ts" };
253
243
  }
254
244
  throw new Error(red("\u2716") + " No apibara.config found");
255
245
  }
@@ -386,20 +376,18 @@ function generatePackageJson(isTypeScript) {
386
376
  private: true,
387
377
  type: "module",
388
378
  scripts: {
389
- prepare: "apibara prepare",
379
+ ...isTypeScript && { prepare: "apibara prepare" },
390
380
  dev: "apibara dev",
391
381
  start: "apibara start",
392
382
  build: "apibara build",
393
383
  ...isTypeScript && { typecheck: "tsc --noEmit" }
394
384
  },
395
385
  dependencies: {
396
- "@apibara/indexer": packageVersions["@apibara/indexer"],
397
386
  "@apibara/protocol": packageVersions["@apibara/protocol"],
398
387
  apibara: packageVersions.apibara
399
388
  },
400
389
  devDependencies: {
401
390
  ...isTypeScript && {
402
- "@rollup/plugin-typescript": packageVersions["@rollup/plugin-typescript"],
403
391
  "@types/node": packageVersions["@types/node"],
404
392
  typescript: packageVersions.typescript
405
393
  }
@@ -427,13 +415,10 @@ function generateTsConfig() {
427
415
  };
428
416
  }
429
417
  function generateApibaraConfig(isTypeScript) {
430
- return `${isTypeScript ? 'import typescript from "@rollup/plugin-typescript";\nimport type { Plugin } from "apibara/rollup";\n' : ""}import { defineConfig } from "apibara/config";
418
+ return `import { defineConfig } from "apibara/config";
431
419
 
432
420
  export default defineConfig({
433
- runtimeConfig: {},${isTypeScript ? `
434
- rollupConfig: {
435
- plugins: [typescript()${isTypeScript ? " as Plugin" : ""}],
436
- },` : ""}
421
+ runtimeConfig: {},
437
422
  });
438
423
  `;
439
424
  }
@@ -443,27 +428,29 @@ function generateIndexer({
443
428
  chain,
444
429
  language
445
430
  }) {
446
- return `import { defineIndexer } from "@apibara/indexer";
447
- import { useLogger } from "@apibara/indexer/plugins";
431
+ return `import { defineIndexer } from "apibara/indexer";
432
+ import { useLogger } from "apibara/plugins";
448
433
  ${storage === "postgres" ? `import { drizzleStorage } from "@apibara/plugin-drizzle";` : ""}
434
+ ${storage === "postgres" ? `import { drizzle } from "@apibara/plugin-drizzle";` : ""}
449
435
  ${chain === "ethereum" ? `import { EvmStream } from "@apibara/evm";` : chain === "beaconchain" ? `import { BeaconChainStream } from "@apibara/beaconchain";` : chain === "starknet" ? `import { StarknetStream } from "@apibara/starknet";` : ""}
450
436
  ${language === "typescript" ? `import type { ApibaraRuntimeConfig } from "apibara/types";` : ""}
451
- ${storage === "postgres" ? `import { getDrizzlePgDatabase } from "../lib/db";` : ""}
437
+ ${storage === "postgres" ? `import * as schema from "../lib/schema";` : ""}
452
438
 
453
439
 
454
440
  export default function (runtimeConfig${language === "typescript" ? ": ApibaraRuntimeConfig" : ""}) {
455
- const indexerId = "${indexerId}";
456
- const { startingBlock, streamUrl${storage === "postgres" ? ", postgresConnectionString" : ""} } = runtimeConfig[indexerId];
457
- ${storage === "postgres" ? "const { db } = getDrizzlePgDatabase(postgresConnectionString);" : ""}
441
+ const { startingBlock, streamUrl } = runtimeConfig["${indexerId}"];
442
+ ${storage === "postgres" ? `const db = drizzle({
443
+ schema,
444
+ });` : ""}
458
445
 
459
446
  return defineIndexer(${chain === "ethereum" ? "EvmStream" : chain === "beaconchain" ? "BeaconChainStream" : chain === "starknet" ? "StarknetStream" : ""})({
460
447
  streamUrl,
461
448
  finality: "accepted",
462
449
  startingBlock: BigInt(startingBlock),
463
450
  filter: {
464
- header: "always",
451
+ ${chain === "ethereum" ? "logs: []," : chain === "starknet" ? "events: []," : ""}
465
452
  },
466
- plugins: [${storage === "postgres" ? "drizzleStorage({ db, persistState: true })" : ""}],
453
+ plugins: [${storage === "postgres" ? "drizzleStorage({ db, migrate: { migrationsFolder: './drizzle' } })" : ""}],
467
454
  async transform({ endCursor, finality }) {
468
455
  const logger = useLogger();
469
456
 
@@ -475,14 +462,12 @@ export default function (runtimeConfig${language === "typescript" ? ": ApibaraRu
475
462
  );
476
463
 
477
464
  ${storage === "postgres" ? `// Example snippet to insert data into db using drizzle with postgres
478
- // const { db } = useDrizzleStorage();
479
- // const { logs } = block;
480
- // for (const log of logs) {
481
- // await db.insert(exampleTable).values({
482
- // number: Number(endCursor?.orderKey),
483
- // hash: log.transactionHash,
484
- // });
485
- // }` : ""}
465
+ // const { db: database } = useDrizzleStorage();
466
+
467
+ // await database.insert(schema.cursorTable).values({
468
+ // endCursor: Number(endCursor?.orderKey),
469
+ // uniqueKey: \`\${endCursor?.uniqueKey}\`,
470
+ // });` : ""}
486
471
  },
487
472
  });
488
473
  }
@@ -492,7 +477,7 @@ async function createIndexerFile(options) {
492
477
  const indexerFilePath = path.join(
493
478
  options.cwd,
494
479
  "indexers",
495
- `${options.indexerFileId}.indexer.${options.language === "typescript" ? "ts" : "js"}`
480
+ `${options.indexerFileId}.indexer.${options.extension}`
496
481
  );
497
482
  const { exists, overwrite } = await checkFileExists(indexerFilePath, {
498
483
  askPrompt: true
@@ -541,16 +526,14 @@ async function updateApibaraConfigFile({
541
526
  storage,
542
527
  language,
543
528
  network,
544
- dnaUrl
529
+ dnaUrl,
530
+ extension
545
531
  }) {
546
- const pathToConfig = path.join(
547
- cwd,
548
- `apibara.config.${language === "typescript" ? "ts" : "js"}`
549
- );
532
+ const pathToConfig = path.join(cwd, `apibara.config.${extension}`);
550
533
  const runtimeConfigString = `{
551
534
  startingBlock: 0,
552
- streamUrl: "${dnaUrl ?? getDnaUrl(chain, network)}"${storage === "postgres" ? `,
553
- postgresConnectionString: process.env["POSTGRES_CONNECTION_STRING"] ?? "memory://${indexerId}"` : ""}}`;
535
+ streamUrl: "${dnaUrl ?? getDnaUrl(chain, network)}"
536
+ }`;
554
537
  const project = new Project();
555
538
  const sourceFile = project.addSourceFileAtPath(pathToConfig);
556
539
  const defineConfigCall = sourceFile.getFirstDescendantByKind(
@@ -581,10 +564,15 @@ async function updateApibaraConfigFile({
581
564
  await formatFile(pathToConfig);
582
565
  }
583
566
  async function createDrizzleStorageFiles(options) {
584
- const { cwd, language, storage } = options;
567
+ const {
568
+ cwd,
569
+ language,
570
+ storage,
571
+ indexerId,
572
+ extension: fileExtension
573
+ } = options;
585
574
  if (storage !== "postgres")
586
575
  return;
587
- const fileExtension = language === "typescript" ? "ts" : "js";
588
576
  const drizzleConfigFileName = `drizzle.config.${fileExtension}`;
589
577
  const drizzleConfigPath = path.join(cwd, drizzleConfigFileName);
590
578
  const { exists, overwrite } = await checkFileExists(drizzleConfigPath, {
@@ -595,11 +583,11 @@ async function createDrizzleStorageFiles(options) {
595
583
  const drizzleConfigContent = `${language === "typescript" ? 'import type { Config } from "drizzle-kit";' : ""}
596
584
 
597
585
  export default {
598
- schema: "./lib/schema.ts",
586
+ schema: "./lib/schema.${fileExtension}",
599
587
  out: "./drizzle",
600
588
  dialect: "postgresql",
601
589
  dbCredentials: {
602
- url: process.env["POSTGRES_CONNECTION_STRING"] ?? "",
590
+ url: process.env["POSTGRES_CONNECTION_STRING"] ?? "memory://${indexerId}",
603
591
  },
604
592
  }${language === "typescript" ? " satisfies Config" : ""};`;
605
593
  fs.writeFileSync(drizzleConfigPath, drizzleConfigContent);
@@ -614,14 +602,14 @@ export default {
614
602
  fileName: `lib/${schemaFileName}`
615
603
  });
616
604
  if (!schemaExists || schemaOverwrite) {
617
- const schemaContent = `// --- Add your pg table schemas here ----
605
+ const schemaContent = `// --- Add your pg table schemas here ----
618
606
 
619
607
  // import { bigint, pgTable, text, uuid } from "drizzle-orm/pg-core";
620
608
 
621
- // export const exampleTable = pgTable("example_table", {
609
+ // export const cursorTable = pgTable("cursor_table", {
622
610
  // id: uuid("id").primaryKey().defaultRandom(),
623
- // number: bigint("number", { mode: "number" }),
624
- // hash: text("hash"),
611
+ // endCursor: bigint("end_cursor", { mode: "number" }),
612
+ // uniqueKey: text("unique_key"),
625
613
  // });
626
614
 
627
615
  export {};
@@ -629,49 +617,7 @@ export {};
629
617
  fs.mkdirSync(path.dirname(schemaPath), { recursive: true });
630
618
  fs.writeFileSync(schemaPath, schemaContent);
631
619
  await formatFile(schemaPath);
632
- consola.success(`Created ${cyan("lib/schema.ts")}`);
633
- }
634
- const dbFileName = `db.${fileExtension}`;
635
- const dbPath = path.join(cwd, "lib", dbFileName);
636
- const { exists: dbExists, overwrite: dbOverwrite } = await checkFileExists(
637
- dbPath,
638
- {
639
- askPrompt: true,
640
- fileName: `lib/${dbFileName}`,
641
- allowIgnore: true
642
- }
643
- );
644
- if (!dbExists || dbOverwrite) {
645
- const dbContent = `import * as schema from "./schema";
646
- import { drizzle as nodePgDrizzle } from "drizzle-orm/node-postgres";
647
- import { drizzle as pgLiteDrizzle } from "drizzle-orm/pglite";
648
- import pg from "pg";
649
-
650
-
651
- export function getDrizzlePgDatabase(connectionString${language === "typescript" ? ": string" : ""}) {
652
- // Create pglite instance
653
- if (connectionString.includes("memory")) {
654
- return {
655
- db: pgLiteDrizzle({
656
- schema,
657
- connection: {
658
- dataDir: connectionString,
659
- },
660
- }),
661
- };
662
- }
663
-
664
- // Create node-postgres instance
665
- const pool = new pg.Pool({
666
- connectionString,
667
- });
668
-
669
- return { db: nodePgDrizzle(pool, { schema }) };
670
- }`;
671
- fs.mkdirSync(path.dirname(dbPath), { recursive: true });
672
- fs.writeFileSync(dbPath, dbContent);
673
- await formatFile(dbPath);
674
- consola.success(`Created ${cyan(`lib/${dbFileName}`)}`);
620
+ consola.success(`Created ${cyan(`lib/${schemaFileName}`)}`);
675
621
  }
676
622
  console.log("\n");
677
623
  if (!schemaExists || schemaOverwrite) {
@@ -683,20 +629,20 @@ export function getDrizzlePgDatabase(connectionString${language === "typescript"
683
629
 
684
630
  ${yellow(`
685
631
  \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510
686
- \u2502 lib/schema.ts \u2502
632
+ \u2502 lib/schema \u2502
687
633
  \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518
688
634
 
689
635
  import { bigint, pgTable, text, uuid } from "drizzle-orm/pg-core";
690
636
 
691
- export const exampleTable = pgTable("example_table", {
637
+ export const cursorTable = pgTable("cursor_table", {
692
638
  id: uuid("id").primaryKey().defaultRandom(),
693
- number: bigint("number", { mode: "number" }),
694
- hash: text("hash"),
639
+ endCursor: bigint("end_cursor", { mode: "number" }),
640
+ uniqueKey: text("unique_key"),
695
641
  });`)}`);
696
642
  console.log("\n");
697
643
  }
698
644
  consola.info(
699
- `Run ${green(`${options.packageManager} run drizzle:generate`)} & ${green(`${options.packageManager} run drizzle:migrate`)} to generate and apply migrations.`
645
+ `Run ${green(`${options.packageManager}${options.packageManager === "npm" ? " run" : ""} drizzle:generate`)} & ${green(`${options.packageManager}${options.packageManager === "npm" ? " run" : ""} drizzle:migrate`)} to generate and apply migrations.`
700
646
  );
701
647
  }
702
648
  async function createStorageRelatedFiles(options) {
@@ -882,7 +828,7 @@ async function initializeProject({
882
828
  consola$1.success("Created", cyan("tsconfig.json"));
883
829
  }
884
830
  const apibaraConfigPath = path.join(root, `apibara.config.${configExt}`);
885
- const apibaraConfig = generateApibaraConfig(isTs);
831
+ const apibaraConfig = generateApibaraConfig();
886
832
  fs.writeFileSync(apibaraConfigPath, apibaraConfig);
887
833
  await formatFile(apibaraConfigPath);
888
834
  consola$1.success("Created", cyan(`apibara.config.${configExt}`));
@@ -897,12 +843,12 @@ async function initializeProject({
897
843
  console.log();
898
844
  if (!argNoCreateIndexer) {
899
845
  consola$1.info("Let's create an indexer\n");
900
- await addIndexer({});
846
+ await addIndexer({ argRootDir: argTargetDir });
901
847
  } else {
902
848
  const pkgManager = getPackageManager();
903
849
  consola$1.info(
904
850
  "Run ",
905
- green(`${pkgManager.name} run install`),
851
+ green(`${pkgManager.name} install`),
906
852
  " to install all dependencies"
907
853
  );
908
854
  }
@@ -913,9 +859,11 @@ async function addIndexer({
913
859
  argChain,
914
860
  argNetwork,
915
861
  argStorage,
916
- argDnaUrl
862
+ argDnaUrl,
863
+ argRootDir
917
864
  }) {
918
- const configExists = hasApibaraConfig(process.cwd());
865
+ const cwd = path.join(process.cwd(), argRootDir ?? ".");
866
+ const configExists = hasApibaraConfig(cwd);
919
867
  if (!configExists) {
920
868
  consola$1.error("No apibara.config found in the current directory.");
921
869
  const prompt_initialize = await prompts({
@@ -939,7 +887,7 @@ async function addIndexer({
939
887
  );
940
888
  }
941
889
  }
942
- const language = getApibaraConfigLanguage(process.cwd());
890
+ const { language, extension } = getApibaraConfigLanguage(cwd);
943
891
  validateIndexerId(argIndexerId, true);
944
892
  validateChain(argChain, true);
945
893
  validateNetwork(argChain, argNetwork, true);
@@ -953,13 +901,9 @@ async function addIndexer({
953
901
  message: reset("Indexer ID:"),
954
902
  initial: argIndexerId ?? "my-indexer",
955
903
  validate: (id) => validateIndexerId(id) ? checkFileExists(
956
- path.join(
957
- process.cwd(),
958
- "indexers",
959
- `${id}.indexer.${language === "typescript" ? "ts" : "js"}`
960
- )
904
+ path.join(cwd, "indexers", `${id}.indexer.${extension}`)
961
905
  ).then(
962
- ({ exists }) => exists ? `Indexer ${cyan(`${id}.indexer.${language === "typescript" ? "ts" : "js"}`)} already exists` : true
906
+ ({ exists }) => exists ? `Indexer ${cyan(`${id}.indexer.${extension}`)} already exists` : true
963
907
  ) : "Invalid indexer ID, it cannot be empty and must be in kebab-case format"
964
908
  },
965
909
  {
@@ -1036,7 +980,7 @@ async function addIndexer({
1036
980
  const indexerFileId = argIndexerId ?? prompt_indexerId;
1037
981
  const pkgManager = getPackageManager();
1038
982
  const options = {
1039
- cwd: process.cwd(),
983
+ cwd,
1040
984
  indexerFileId,
1041
985
  indexerId: convertKebabToCamelCase(indexerFileId),
1042
986
  chain: argChain ?? prompt_chain?.name,
@@ -1044,23 +988,23 @@ async function addIndexer({
1044
988
  storage: argStorage ?? prompt_storage?.name,
1045
989
  dnaUrl: argDnaUrl ?? prompt_dnaUrl,
1046
990
  language,
1047
- packageManager: pkgManager.name
991
+ packageManager: pkgManager.name,
992
+ extension
1048
993
  };
1049
994
  await updateApibaraConfigFile(options);
1050
- consola$1.success(
1051
- `Updated ${cyan("apibara.config." + (language === "typescript" ? "ts" : "js"))}`
1052
- );
995
+ consola$1.success(`Updated ${cyan(`apibara.config.${extension}`)}`);
1053
996
  await updatePackageJson(options);
1054
997
  consola$1.success(`Updated ${cyan("package.json")}`);
1055
998
  await createIndexerFile(options);
1056
- consola$1.success(
1057
- `Created ${cyan(`${indexerFileId}.indexer.${language === "typescript" ? "ts" : "js"}`)}`
1058
- );
999
+ consola$1.success(`Created ${cyan(`${indexerFileId}.indexer.${extension}`)}`);
1059
1000
  await createStorageRelatedFiles(options);
1060
1001
  console.log();
1002
+ const baseCommand = `${options.packageManager} install`;
1003
+ const tsCommand = `${baseCommand} && ${options.packageManager} run prepare`;
1061
1004
  consola$1.info(
1062
- `Before running the indexer, run ${cyan(`${options.packageManager} run install`)}${language === "typescript" ? " & " + cyan(`${options.packageManager} run prepare`) : ""}`
1005
+ `Before running the indexer, run ${cyan(language === "typescript" ? tsCommand : baseCommand)}`
1063
1006
  );
1064
1007
  }
1065
1008
 
1066
1009
  export { addIndexer, initializeProject };
1010
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../src/create/constants.ts","../../src/create/utils.ts","../../src/create/templates.ts","../../src/create/init.ts","../../src/create/add.ts"],"sourcesContent":["import { blue, green, red, yellow } from \"./colors\";\nimport type { Chain, ColorFunc, Network } from \"./types\";\n\nexport type ChainDataType = {\n name: Chain;\n display: string;\n color: ColorFunc;\n networks: NetworkDataType[];\n};\n\nexport type NetworkDataType = {\n name: Network;\n display: string;\n color: ColorFunc;\n};\n\nexport type LanguageDataType = {\n name: \"typescript\" | \"javascript\";\n display: string;\n color: ColorFunc;\n};\n\nexport type StorageDataType = {\n name: \"postgres\" | \"none\";\n display: string;\n color: ColorFunc;\n};\n\nexport const chains: ChainDataType[] = [\n {\n name: \"starknet\",\n display: \"Starknet\",\n color: blue,\n networks: [\n { name: \"mainnet\", display: \"Mainnet\", color: blue },\n { name: \"sepolia\", display: \"Sepolia\", color: yellow },\n ],\n },\n {\n name: \"ethereum\",\n display: \"Ethereum\",\n color: green,\n networks: [\n { name: \"mainnet\", display: \"Mainnet\", color: blue },\n { name: \"sepolia\", display: \"Sepolia\", color: yellow },\n ],\n },\n {\n name: \"beaconchain\",\n display: \"Beacon Chain\",\n color: yellow,\n networks: [{ name: \"mainnet\", display: \"Mainnet\", color: yellow }],\n },\n];\n\nexport const networks: NetworkDataType[] = [\n { name: \"mainnet\", display: \"Mainnet\", color: blue },\n { name: \"sepolia\", display: \"Sepolia\", color: green },\n { name: \"other\", display: \"Other\", color: red },\n];\n\nexport const storages: StorageDataType[] = [\n { name: \"postgres\", display: \"Postgres\", color: green },\n { name: \"none\", display: \"None\", color: red },\n];\n\nexport const packageVersions = {\n // Required Dependencies\n apibara: \"next\",\n \"@apibara/protocol\": \"next\",\n // Chain Dependencies\n \"@apibara/evm\": \"next\",\n \"@apibara/beaconchain\": \"next\",\n \"@apibara/starknet\": \"next\",\n // Storage Dependencies\n \"@apibara/plugin-drizzle\": \"next\",\n \"@apibara/plugin-mongo\": \"next\",\n \"@apibara/plugin-sqlite\": \"next\",\n // Postgres Dependencies\n \"@electric-sql/pglite\": \"^0.2.17\",\n \"drizzle-orm\": \"^0.40.1\",\n pg: \"^8.13.1\",\n \"@types/pg\": \"^8.11.10\",\n \"drizzle-kit\": \"^0.29.0\",\n // Typescript Dependencies\n typescript: \"^5.6.2\",\n \"@types/node\": \"^20.5.2\",\n};\n\nexport const dnaUrls = {\n ethereum: \"https://mainnet.ethereum.a5a.ch\",\n ethereumSepolia: \"https://sepolia.ethereum.a5a.ch\",\n beaconchain: \"https://beaconchain.preview.apibara.org\",\n starknet: \"https://mainnet.starknet.a5a.ch\",\n starknetSepolia: \"https://sepolia.starknet.a5a.ch\",\n};\n","import fs from \"node:fs\";\nimport path, { basename } from \"node:path\";\nimport * as prettier from \"prettier\";\nimport prompts from \"prompts\";\nimport { blue, cyan, red, yellow } from \"./colors\";\nimport { dnaUrls, networks } from \"./constants\";\nimport type { Chain, FileExtension, Language, Network, PkgInfo } from \"./types\";\n\nexport function isEmpty(path: string) {\n const files = fs.readdirSync(path);\n return files.length === 0 || (files.length === 1 && files[0] === \".git\");\n}\nexport function emptyDir(dir: string) {\n if (!fs.existsSync(dir)) {\n return;\n }\n for (const file of fs.readdirSync(dir)) {\n if (file === \".git\") {\n continue;\n }\n fs.rmSync(path.resolve(dir, file), { recursive: true, force: true });\n }\n}\n\nexport function validateLanguage(language?: string, throwError = false) {\n if (!language) {\n return false;\n }\n\n if (\n language === \"typescript\" ||\n language === \"ts\" ||\n language === \"javascript\" ||\n language === \"js\" ||\n language === \"mjs\"\n ) {\n return true;\n }\n\n if (throwError) {\n throw new Error(\n `Invalid language ${cyan(\"(--language | -l)\")}: ${red(language)}. Options: ${blue(\"typescript, ts\")} or ${yellow(\"javascript, js\")} | default: ${cyan(\"typescript\")}`,\n );\n }\n\n return false;\n}\n\nexport function getLanguageFromAlias(alias: string): Language {\n if (alias === \"ts\" || alias === \"typescript\") {\n return \"typescript\";\n }\n if (alias === \"js\" || alias === \"javascript\" || alias === \"mjs\") {\n return \"javascript\";\n }\n\n throw new Error(\n `Invalid language ${cyan(\"(--language | -l)\")}: ${red(alias)}. Options: ${blue(\"typescript, ts\")} or ${yellow(\"javascript, js\")}`,\n );\n}\n\nexport function validateIndexerId(indexerId?: string, throwError = false) {\n if (!indexerId) {\n return false;\n }\n if (!/^[a-z0-9-]+$/.test(indexerId)) {\n if (throwError) {\n throw new Error(\n `Invalid indexer ID ${cyan(\"(--indexer-id)\")}: ${red(indexerId)}. Indexer ID must contain only lowercase letters, numbers, and hyphens.`,\n );\n }\n return false;\n }\n return true;\n}\n\nexport function validateChain(chain?: string, throwError = false) {\n if (!chain) {\n return false;\n }\n if (chain) {\n if (chain === \"starknet\" || chain === \"ethereum\" || chain === \"beaconchain\")\n return true;\n if (throwError) {\n throw new Error(\n `Invalid chain ${cyan(\"(--chain)\")}: ${red(chain)}. Chain must be one of ${blue(\"starknet, ethereum, beaconchain\")}.`,\n );\n }\n return false;\n }\n return true;\n}\n\nexport function validateNetwork(\n chain?: string,\n network?: string,\n throwError = false,\n) {\n if (!network) {\n return false;\n }\n\n if (network === \"other\") {\n return true;\n }\n\n if (chain) {\n if (chain === \"starknet\") {\n if (network === \"mainnet\" || network === \"sepolia\") {\n return true;\n }\n if (throwError) {\n throw new Error(\n `Invalid network ${cyan(\"(--network)\")}: ${red(network)}. For chain ${blue(\"starknet\")}, network must be one of ${blue(\"mainnet, sepolia, other\")}.`,\n );\n }\n return false;\n }\n if (chain === \"ethereum\") {\n if (network === \"mainnet\" || network === \"goerli\") {\n return true;\n }\n if (throwError) {\n throw new Error(\n `Invalid network ${cyan(\"(--network)\")}: ${red(network)}. For chain ${blue(\"ethereum\")}, network must be one of ${blue(\"mainnet, goerli, other\")}.`,\n );\n }\n return false;\n }\n if (chain === \"beaconchain\") {\n if (network === \"mainnet\") {\n return true;\n }\n if (throwError) {\n throw new Error(\n `Invalid network ${cyan(\"(--network)\")}: ${red(network)}. For chain ${blue(\"beaconchain\")}, network must be ${blue(\"mainnet, other\")}.`,\n );\n }\n return false;\n }\n }\n\n if (networks.find((n) => n.name === network)) {\n return true;\n }\n\n if (throwError) {\n throw new Error(\n `Invalid network ${cyan(\"(--network)\")}: ${red(network)}. Network must be one of ${blue(\"mainnet, sepolia, goerli, other\")}.`,\n );\n }\n return false;\n}\n\nexport function validateStorage(storage?: string, throwError = false) {\n if (!storage) {\n return false;\n }\n if (storage === \"postgres\" || storage === \"none\") {\n return true;\n }\n if (throwError) {\n throw new Error(\n `Invalid storage ${cyan(\"(--storage)\")}: ${red(storage)}. Storage must be one of ${blue(\"postgres, none\")}.`,\n );\n }\n return false;\n}\n\nexport function validateDnaUrl(dnaUrl?: string, throwError = false) {\n if (!dnaUrl) {\n return false;\n }\n if (!dnaUrl.startsWith(\"https://\") && !dnaUrl.startsWith(\"http://\")) {\n if (throwError) {\n throw new Error(\n `Invalid DNA URL ${cyan(\"(--dna-url)\")}: ${red(dnaUrl)}. DNA URL must start with ${blue(\"https:// or http://\")}.`,\n );\n }\n return false;\n }\n return true;\n}\n\nexport function hasApibaraConfig(cwd: string): boolean {\n const configPathJS = path.join(cwd, \"apibara.config.js\");\n const configPathTS = path.join(cwd, \"apibara.config.ts\");\n const configPathMJS = path.join(cwd, \"apibara.config.mjs\");\n\n return (\n fs.existsSync(configPathJS) ||\n fs.existsSync(configPathTS) ||\n fs.existsSync(configPathMJS)\n );\n}\n\nexport function getApibaraConfigLanguage(cwd: string): {\n language: Language;\n extension: FileExtension;\n} {\n const configPathJS = path.join(cwd, \"apibara.config.js\");\n const configPathTS = path.join(cwd, \"apibara.config.ts\");\n const configPathMJS = path.join(cwd, \"apibara.config.mjs\");\n\n if (fs.existsSync(configPathMJS)) {\n return { language: \"javascript\", extension: \"mjs\" };\n }\n if (fs.existsSync(configPathJS)) {\n return { language: \"javascript\", extension: \"js\" };\n }\n if (fs.existsSync(configPathTS)) {\n return { language: \"typescript\", extension: \"ts\" };\n }\n\n throw new Error(red(\"✖\") + \" No apibara.config found\");\n}\n\nexport function getDnaUrl(chain: Chain, network: Network) {\n if (chain === \"ethereum\") {\n if (network === \"mainnet\") {\n return dnaUrls.ethereum;\n }\n if (network === \"sepolia\") {\n return dnaUrls.ethereumSepolia;\n }\n }\n\n if (chain === \"beaconchain\") {\n if (network === \"mainnet\") {\n return dnaUrls.beaconchain;\n }\n }\n\n if (chain === \"starknet\") {\n if (network === \"mainnet\") {\n return dnaUrls.starknet;\n }\n if (network === \"sepolia\") {\n return dnaUrls.starknetSepolia;\n }\n }\n\n throw new Error(red(\"✖\") + \" Invalid chain or network\");\n}\n\n/**\n * Converts a kebab-case string to camelCase.\n *\n * Examples:\n * - \"hello-world\" → \"helloWorld\"\n * - \"my-long-variable-name\" → \"myLongVariableName\"\n * - \"MY-CAPS\" → \"myCaps\"\n * - \"-leading-dash\" → \"leadingDash\"\n * - \"trailing-dash-\" → \"trailingDash\"\n * - \"double--dash\" → \"doubleDash\"\n * - \"hello---world\" → \"helloWorld\"\n * - \"mixed_dash-and_underscore\" → \"mixedDashAndUnderscore\"\n *\n * @param str The kebab-case string to convert\n * @returns The camelCase version of the string\n */\nexport function convertKebabToCamelCase(_str: string): string {\n let str = _str;\n\n // Handle empty or invalid input\n if (!str || typeof str !== \"string\") {\n return \"\";\n }\n\n // Check if already camelCase\n if (/^[a-z][a-zA-Z0-9]*$/.test(str)) {\n return str;\n }\n\n // Trim leading/trailing dashes and spaces\n str = str.trim().replace(/^-+|-+$/g, \"\");\n\n // Handle empty string after trim\n if (!str) {\n return \"\";\n }\n\n return (\n str\n // Replace multiple consecutive dashes/underscores with a single dash\n .replace(/[-_]+/g, \"-\")\n // Split on dash\n .split(\"-\")\n // Filter out empty strings (from consecutive dashes)\n .filter(Boolean)\n // Convert each word\n .map((word, index) => {\n // Convert word to lowercase\n const _word = word.toLowerCase();\n\n // Capitalize first letter if not the first word\n if (index > 0) {\n return _word.charAt(0).toUpperCase() + _word.slice(1);\n }\n\n return _word;\n })\n .join(\"\")\n );\n}\n\nexport async function checkFileExists(\n path: string,\n options?: {\n askPrompt?: boolean;\n fileName?: string;\n allowIgnore?: boolean;\n },\n): Promise<{\n exists: boolean;\n overwrite: boolean;\n}> {\n const { askPrompt = false, fileName, allowIgnore = false } = options ?? {};\n\n if (!fs.existsSync(path)) {\n return {\n exists: false,\n overwrite: false,\n };\n }\n\n if (askPrompt) {\n const { overwrite } = await prompts({\n type: \"select\",\n name: \"overwrite\",\n message: `${fileName ?? basename(path)} already exists. Please choose how to proceed:`,\n initial: 0,\n choices: [\n ...(allowIgnore\n ? [\n {\n title: \"Keep original file\",\n value: \"ignore\",\n },\n ]\n : []),\n {\n title: \"Cancel operation\",\n value: \"no\",\n },\n {\n title: \"Overwrite file\",\n value: \"yes\",\n },\n ],\n });\n\n if (overwrite === \"no\") {\n cancelOperation();\n }\n\n if (overwrite === \"ignore\") {\n return {\n exists: true,\n overwrite: false,\n };\n }\n\n return {\n exists: true,\n overwrite: true,\n };\n }\n\n return {\n exists: true,\n overwrite: false,\n };\n}\n\nexport function cancelOperation(message?: string) {\n throw new Error(red(\"✖\") + (message ?? \" Operation cancelled\"));\n}\n\nexport function getPackageManager(): PkgInfo {\n const userAgent = process.env.npm_config_user_agent;\n const pkgInfo = pkgFromUserAgent(userAgent);\n if (pkgInfo) {\n return pkgInfo;\n }\n return {\n name: \"npm\",\n };\n}\n\n/**\n \nhttps://github.com/vitejs/vite/blob/07091a1e804e5934208ef0b6324a04317dd0d815/packages/create-vite/src/index.ts#L585\n\nMIT License\n\nCopyright (c) 2019-present, VoidZero Inc. and Vite contributors\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n */\nfunction pkgFromUserAgent(userAgent: string | undefined): PkgInfo | undefined {\n if (!userAgent) return undefined;\n const pkgSpec = userAgent.split(\" \")[0];\n const pkgSpecArr = pkgSpec.split(\"/\");\n return {\n name: pkgSpecArr[0],\n version: pkgSpecArr[1],\n };\n}\n\nexport async function formatFile(path: string) {\n const file = fs.readFileSync(path, \"utf8\");\n const formatted = await prettier.format(file, {\n filepath: path,\n tabWidth: 2,\n });\n fs.writeFileSync(path, formatted);\n}\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { consola } from \"consola\";\nimport prompts from \"prompts\";\nimport { type ObjectLiteralExpression, Project, SyntaxKind } from \"ts-morph\";\nimport { cyan, green, magenta, yellow } from \"./colors\";\nimport { packageVersions } from \"./constants\";\nimport type { IndexerOptions } from \"./types\";\nimport { checkFileExists, formatFile, getDnaUrl } from \"./utils\";\n\nexport function generatePackageJson(isTypeScript: boolean) {\n return {\n name: \"apibara-app\",\n version: \"0.1.0\",\n private: true,\n type: \"module\",\n scripts: {\n ...(isTypeScript && { prepare: \"apibara prepare\" }),\n dev: \"apibara dev\",\n start: \"apibara start\",\n build: \"apibara build\",\n ...(isTypeScript && { typecheck: \"tsc --noEmit\" }),\n },\n dependencies: {\n \"@apibara/protocol\": packageVersions[\"@apibara/protocol\"],\n apibara: packageVersions.apibara,\n },\n devDependencies: {\n ...(isTypeScript && {\n \"@types/node\": packageVersions[\"@types/node\"],\n typescript: packageVersions.typescript,\n }),\n },\n };\n}\n\nexport function generateTsConfig() {\n return {\n $schema: \"https://json.schemastore.org/tsconfig\",\n display: \"Default\",\n compilerOptions: {\n forceConsistentCasingInFileNames: true,\n target: \"ES2022\",\n lib: [\"ESNext\"],\n module: \"ESNext\",\n moduleResolution: \"bundler\",\n skipLibCheck: true,\n types: [\"node\"],\n noEmit: true,\n strict: true,\n baseUrl: \".\",\n },\n include: [\".\", \"./.apibara/types\"],\n exclude: [\"node_modules\"],\n };\n}\n\nexport function generateApibaraConfig(isTypeScript: boolean) {\n return `import { defineConfig } from \"apibara/config\";\n\nexport default defineConfig({\n runtimeConfig: {},\n});\\n`;\n}\n\nexport function generateIndexer({\n indexerId,\n storage,\n chain,\n language,\n}: IndexerOptions) {\n return `import { defineIndexer } from \"apibara/indexer\";\nimport { useLogger } from \"apibara/plugins\";\n${storage === \"postgres\" ? `import { drizzleStorage } from \"@apibara/plugin-drizzle\";` : \"\"}\n${storage === \"postgres\" ? `import { drizzle } from \"@apibara/plugin-drizzle\";` : \"\"}\n${\n chain === \"ethereum\"\n ? `import { EvmStream } from \"@apibara/evm\";`\n : chain === \"beaconchain\"\n ? `import { BeaconChainStream } from \"@apibara/beaconchain\";`\n : chain === \"starknet\"\n ? `import { StarknetStream } from \"@apibara/starknet\";`\n : \"\"\n}\n${language === \"typescript\" ? `import type { ApibaraRuntimeConfig } from \"apibara/types\";` : \"\"}\n${storage === \"postgres\" ? `import * as schema from \"../lib/schema\";` : \"\"}\n\n\nexport default function (runtimeConfig${language === \"typescript\" ? \": ApibaraRuntimeConfig\" : \"\"}) {\n const { startingBlock, streamUrl } = runtimeConfig[\"${indexerId}\"];\n ${\n storage === \"postgres\"\n ? `const db = drizzle({\n schema,\n });`\n : \"\"\n }\n\n return defineIndexer(${\n chain === \"ethereum\"\n ? \"EvmStream\"\n : chain === \"beaconchain\"\n ? \"BeaconChainStream\"\n : chain === \"starknet\"\n ? \"StarknetStream\"\n : \"\"\n })({\n streamUrl,\n finality: \"accepted\",\n startingBlock: BigInt(startingBlock),\n filter: {\n ${chain === \"ethereum\" ? \"logs: [],\" : chain === \"starknet\" ? \"events: [],\" : \"\"}\n },\n plugins: [${storage === \"postgres\" ? \"drizzleStorage({ db, migrate: { migrationsFolder: './drizzle' } })\" : \"\"}],\n async transform({ endCursor, finality }) {\n const logger = useLogger();\n\n logger.info(\n \"Transforming block | orderKey: \",\n endCursor?.orderKey,\n \" | finality: \",\n finality\n );\n\n ${\n storage === \"postgres\"\n ? `// Example snippet to insert data into db using drizzle with postgres\n // const { db: database } = useDrizzleStorage();\n\n // await database.insert(schema.cursorTable).values({\n // endCursor: Number(endCursor?.orderKey),\n // uniqueKey: \\`\\${endCursor?.uniqueKey}\\`,\n // });`\n : \"\"\n }\n },\n });\n} \n`;\n}\n\nexport async function createIndexerFile(options: IndexerOptions) {\n const indexerFilePath = path.join(\n options.cwd,\n \"indexers\",\n `${options.indexerFileId}.indexer.${options.extension}`,\n );\n\n const { exists, overwrite } = await checkFileExists(indexerFilePath, {\n askPrompt: true,\n });\n\n if (exists && !overwrite) return;\n\n const indexerContent = generateIndexer(options);\n\n fs.mkdirSync(path.dirname(indexerFilePath), { recursive: true });\n fs.writeFileSync(indexerFilePath, indexerContent);\n\n await formatFile(indexerFilePath);\n}\n\nexport async function updatePackageJson({\n cwd,\n chain,\n storage,\n language,\n}: IndexerOptions) {\n const packageJsonPath = path.join(cwd, \"package.json\");\n\n const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf8\"));\n\n if (chain === \"ethereum\") {\n packageJson.dependencies[\"@apibara/evm\"] = packageVersions[\"@apibara/evm\"];\n } else if (chain === \"beaconchain\") {\n packageJson.dependencies[\"@apibara/beaconchain\"] =\n packageVersions[\"@apibara/beaconchain\"];\n } else if (chain === \"starknet\") {\n packageJson.dependencies[\"@apibara/starknet\"] =\n packageVersions[\"@apibara/starknet\"];\n }\n\n if (storage === \"postgres\") {\n packageJson.scripts[\"drizzle:generate\"] = \"drizzle-kit generate\";\n packageJson.scripts[\"drizzle:migrate\"] = \"drizzle-kit migrate\";\n\n packageJson.dependencies[\"@apibara/plugin-drizzle\"] =\n packageVersions[\"@apibara/plugin-drizzle\"];\n\n packageJson.dependencies[\"drizzle-orm\"] = packageVersions[\"drizzle-orm\"];\n\n packageJson.dependencies[\"@electric-sql/pglite\"] =\n packageVersions[\"@electric-sql/pglite\"];\n\n packageJson.dependencies[\"drizzle-kit\"] = packageVersions[\"drizzle-kit\"];\n\n packageJson.dependencies[\"pg\"] = packageVersions[\"pg\"];\n\n if (language === \"typescript\") {\n packageJson.devDependencies[\"@types/pg\"] = packageVersions[\"@types/pg\"];\n }\n }\n\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2));\n\n await formatFile(packageJsonPath);\n}\n\nexport async function updateApibaraConfigFile({\n indexerId,\n cwd,\n chain,\n storage,\n language,\n network,\n dnaUrl,\n extension,\n}: IndexerOptions) {\n const pathToConfig = path.join(cwd, `apibara.config.${extension}`);\n\n const runtimeConfigString = `{\n startingBlock: 0,\n streamUrl: \"${dnaUrl ?? getDnaUrl(chain, network)}\" \n}`;\n\n const project = new Project();\n const sourceFile = project.addSourceFileAtPath(pathToConfig);\n\n // Find the defineConfig call expression\n const defineConfigCall = sourceFile.getFirstDescendantByKind(\n SyntaxKind.CallExpression,\n );\n if (!defineConfigCall) return;\n\n const configObjectExpression =\n defineConfigCall.getArguments()[0] as ObjectLiteralExpression;\n\n const runtimeConfigObject =\n configObjectExpression.getProperty(\"runtimeConfig\");\n\n if (!runtimeConfigObject) {\n configObjectExpression.addPropertyAssignment({\n name: \"runtimeConfig\",\n initializer: `{\n \"${indexerId}\": ${runtimeConfigString}\n}`,\n });\n } else {\n const runtimeConfigProp = runtimeConfigObject.asKindOrThrow(\n SyntaxKind.PropertyAssignment,\n );\n const runtimeConfigObj = runtimeConfigProp\n .getInitializerOrThrow()\n .asKindOrThrow(SyntaxKind.ObjectLiteralExpression);\n\n runtimeConfigObj.addPropertyAssignment({\n name: `\"${indexerId}\"`,\n initializer: runtimeConfigString,\n });\n }\n // Save the changes\n sourceFile.saveSync();\n\n await formatFile(pathToConfig);\n}\n\nexport async function createDrizzleStorageFiles(options: IndexerOptions) {\n const {\n cwd,\n language,\n storage,\n indexerId,\n extension: fileExtension,\n } = options;\n\n if (storage !== \"postgres\") return;\n\n /**\n *\n *\n * Drizzle Config File\n *\n *\n */\n\n const drizzleConfigFileName = `drizzle.config.${fileExtension}`;\n\n // create drizzle.config.ts\n const drizzleConfigPath = path.join(cwd, drizzleConfigFileName);\n\n const { exists, overwrite } = await checkFileExists(drizzleConfigPath, {\n askPrompt: true,\n allowIgnore: true,\n });\n\n if (!exists || overwrite) {\n const drizzleConfigContent = `${language === \"typescript\" ? 'import type { Config } from \"drizzle-kit\";' : \"\"}\n\nexport default {\n schema: \"./lib/schema.${fileExtension}\",\n out: \"./drizzle\",\n dialect: \"postgresql\",\n dbCredentials: {\n url: process.env[\"POSTGRES_CONNECTION_STRING\"] ?? \"memory://${indexerId}\",\n },\n}${language === \"typescript\" ? \" satisfies Config\" : \"\"};`;\n\n fs.writeFileSync(drizzleConfigPath, drizzleConfigContent);\n\n await formatFile(drizzleConfigPath);\n\n consola.success(`Created ${cyan(drizzleConfigFileName)}`);\n }\n\n /**\n *\n *\n * Schema File\n *\n *\n */\n\n const schemaFileName = `schema.${fileExtension}`;\n\n const schemaPath = path.join(cwd, \"lib\", schemaFileName);\n\n const { exists: schemaExists, overwrite: schemaOverwrite } =\n await checkFileExists(schemaPath, {\n askPrompt: true,\n allowIgnore: true,\n fileName: `lib/${schemaFileName}`,\n });\n\n if (!schemaExists || schemaOverwrite) {\n const schemaContent = `// --- Add your pg table schemas here ----\n\n// import { bigint, pgTable, text, uuid } from \"drizzle-orm/pg-core\";\n\n// export const cursorTable = pgTable(\"cursor_table\", {\n// id: uuid(\"id\").primaryKey().defaultRandom(),\n// endCursor: bigint(\"end_cursor\", { mode: \"number\" }),\n// uniqueKey: text(\"unique_key\"),\n// });\n\nexport {};\n `;\n\n // create directory if it doesn't exist\n fs.mkdirSync(path.dirname(schemaPath), { recursive: true });\n fs.writeFileSync(schemaPath, schemaContent);\n\n await formatFile(schemaPath);\n\n consola.success(`Created ${cyan(`lib/${schemaFileName}`)}`);\n }\n\n console.log(\"\\n\");\n\n // If schema file is created, show the example\n if (!schemaExists || schemaOverwrite) {\n consola.info(\n `Make sure to export your pgTables in ${cyan(`lib/${schemaFileName}`)}`,\n );\n\n console.log();\n\n consola.info(`${magenta(\"Example:\")}\n \n${yellow(`\n┌──────────────────────────────────────────┐\n│ lib/schema │\n└──────────────────────────────────────────┘\n\nimport { bigint, pgTable, text, uuid } from \"drizzle-orm/pg-core\";\n\nexport const cursorTable = pgTable(\"cursor_table\", {\n id: uuid(\"id\").primaryKey().defaultRandom(),\n endCursor: bigint(\"end_cursor\", { mode: \"number\" }),\n uniqueKey: text(\"unique_key\"),\n});`)}`);\n\n console.log(\"\\n\");\n }\n\n consola.info(\n `Run ${green(`${options.packageManager}${options.packageManager === \"npm\" ? \" run\" : \"\"} drizzle:generate`)} & ${green(`${options.packageManager}${options.packageManager === \"npm\" ? \" run\" : \"\"} drizzle:migrate`)} to generate and apply migrations.`,\n );\n}\n\nexport async function createStorageRelatedFiles(options: IndexerOptions) {\n const { storage } = options;\n\n if (storage === \"postgres\") {\n await createDrizzleStorageFiles(options);\n }\n}\n\nconst gitIgnoreItems: {\n isRecommended: boolean;\n description?: string;\n value: string;\n}[] = [\n {\n isRecommended: false,\n value: \"node_modules\",\n },\n {\n isRecommended: false,\n value: \"dist\",\n },\n {\n isRecommended: true,\n description: \"build and dev files of apibara\",\n value: \".apibara\",\n },\n {\n isRecommended: false,\n value: \".env\",\n },\n {\n isRecommended: false,\n description: \"for mac users\",\n value: \".DS_Store\",\n },\n];\n\nexport async function createGitIgnoreFile(cwd: string) {\n const gitIgnorePath = path.join(cwd, \".gitignore\");\n\n if (fs.existsSync(gitIgnorePath)) {\n const result = await prompts([\n {\n type: \"select\",\n name: \"overwrite\",\n message: `${cyan(\".gitignore\")} already exists. Please choose how to proceed:`,\n initial: 0,\n choices: [\n {\n title: \"Choose items to append in your .gitignore\",\n value: \"append\",\n },\n {\n title: \"Keep original\",\n value: \"ignore\",\n },\n {\n title: \"Overwrite\",\n value: \"overwrite\",\n },\n ],\n },\n {\n type: (overwrite: \"append\" | \"ignore\" | \"overwrite\") =>\n overwrite === \"append\" ? \"multiselect\" : null,\n name: \"ignoreItems\",\n message: \"Choose items to append in your .gitignore\",\n choices: gitIgnoreItems.map((item) => ({\n title: `${yellow(item.value)}${\n item.description ? ` - ${item.description}` : \"\"\n }${item.isRecommended ? ` ${green(\"(recommended)\")}` : \"\"}`,\n value: item.value,\n })),\n },\n ]);\n\n const { overwrite, ignoreItems } = result as {\n overwrite: \"append\" | \"ignore\" | \"overwrite\";\n ignoreItems: string[];\n };\n\n if (overwrite === \"append\" && ignoreItems.length > 0) {\n const gitIgnoreContent = fs.readFileSync(gitIgnorePath, \"utf8\");\n fs.writeFileSync(\n gitIgnorePath,\n `${gitIgnoreContent}\\n${result.ignoreItems.join(\"\\n\")}`,\n );\n consola.success(`Updated ${cyan(\".gitignore\")}`);\n return;\n }\n\n if (overwrite === \"overwrite\") {\n fs.writeFileSync(\n gitIgnorePath,\n gitIgnoreItems.map((item) => item.value).join(\"\\n\"),\n );\n consola.success(`Updated ${cyan(\".gitignore\")}`);\n return;\n }\n }\n\n fs.writeFileSync(\n gitIgnorePath,\n gitIgnoreItems.map((item) => item.value).join(\"\\n\"),\n );\n consola.success(`Created ${cyan(\".gitignore\")}`);\n}\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport consola from \"consola\";\nimport prompts from \"prompts\";\nimport { addIndexer } from \"./add\";\nimport { cyan, green } from \"./colors\";\nimport {\n createGitIgnoreFile,\n generateApibaraConfig,\n generatePackageJson,\n generateTsConfig,\n} from \"./templates\";\nimport type { Language } from \"./types\";\nimport {\n cancelOperation,\n emptyDir,\n formatFile,\n getLanguageFromAlias,\n getPackageManager,\n isEmpty,\n validateLanguage,\n} from \"./utils\";\n\ntype Options = {\n argTargetDir: string;\n argLanguage?: string;\n argNoCreateIndexer?: boolean;\n};\n\nexport async function initializeProject({\n argTargetDir,\n argLanguage,\n argNoCreateIndexer,\n}: Options) {\n const cwd = process.cwd();\n validateLanguage(argLanguage, true);\n\n console.log();\n\n const result = await prompts(\n [\n {\n type: () =>\n argTargetDir &&\n (!fs.existsSync(argTargetDir) || isEmpty(argTargetDir))\n ? null\n : \"select\",\n name: \"overwrite\",\n message: () =>\n (argTargetDir === \".\"\n ? \"Current directory\"\n : `Target directory \"${argTargetDir}\"`) +\n \" is not empty. Please choose how to proceed:\",\n initial: 0,\n choices: [\n {\n title: \"Cancel operation\",\n value: \"no\",\n },\n {\n title: \"Remove existing files and continue\",\n value: \"yes\",\n },\n {\n title: \"Ignore files and continue\",\n value: \"ignore\",\n },\n ],\n hint: \"\\nCurrent Working Directory: \" + cwd,\n },\n {\n type: (_, { overwrite }: { overwrite?: string }) => {\n if (overwrite === \"no\") {\n cancelOperation();\n }\n return null;\n },\n name: \"overwriteChecker\",\n },\n {\n type: argLanguage ? null : \"select\",\n name: \"prompt_language\",\n message: \"Select a language:\",\n choices: [\n {\n title: \"Typescript\",\n value: \"typescript\",\n },\n {\n title: \"Javascript\",\n value: \"javascript\",\n },\n ],\n },\n ],\n {\n onCancel: () => {\n cancelOperation();\n },\n },\n );\n\n const { overwrite, prompt_language } = result as {\n overwrite: \"no\" | \"yes\" | \"ignore\";\n prompt_language: \"typescript\" | \"javascript\";\n };\n\n const root = path.join(cwd, argTargetDir);\n if (overwrite === \"yes\") {\n emptyDir(root);\n } else if (!fs.existsSync(root)) {\n fs.mkdirSync(root, { recursive: true });\n }\n\n const lang: Language = argLanguage\n ? getLanguageFromAlias(argLanguage)\n : prompt_language;\n\n const isTs = lang === \"typescript\";\n const configExt = isTs ? \"ts\" : \"js\";\n\n console.log(\"\\n\");\n consola.info(`Initializing project in ${argTargetDir}\\n\\n`);\n\n // Generate package.json\n const packageJsonPath = path.join(root, \"package.json\");\n const packageJson = generatePackageJson(isTs);\n fs.writeFileSync(\n packageJsonPath,\n JSON.stringify(packageJson, null, 2) + \"\\n\",\n );\n await formatFile(packageJsonPath);\n consola.success(\"Created\", cyan(\"package.json\"));\n\n // Generate tsconfig.json if TypeScript\n if (isTs) {\n const tsConfigPath = path.join(root, \"tsconfig.json\");\n const tsConfig = generateTsConfig();\n fs.writeFileSync(tsConfigPath, JSON.stringify(tsConfig, null, 2) + \"\\n\");\n await formatFile(tsConfigPath);\n consola.success(\"Created\", cyan(\"tsconfig.json\"));\n }\n\n const apibaraConfigPath = path.join(root, `apibara.config.${configExt}`);\n // Generate apibara.config\n const apibaraConfig = generateApibaraConfig(isTs);\n fs.writeFileSync(apibaraConfigPath, apibaraConfig);\n await formatFile(apibaraConfigPath);\n consola.success(\"Created\", cyan(`apibara.config.${configExt}`));\n\n // Create \"indexers\" directory if not exists\n const indexersDir = path.join(root, \"indexers\");\n if (!fs.existsSync(indexersDir)) {\n fs.mkdirSync(indexersDir, { recursive: true });\n consola.success(`Created ${cyan(\"indexers\")} directory`);\n }\n\n await createGitIgnoreFile(root);\n\n console.log(\"\\n\");\n\n consola.ready(green(\"Project initialized successfully\"));\n\n console.log();\n\n if (!argNoCreateIndexer) {\n consola.info(\"Let's create an indexer\\n\");\n\n await addIndexer({ argRootDir: argTargetDir });\n } else {\n const pkgManager = getPackageManager();\n consola.info(\n \"Run \",\n green(`${pkgManager.name} install`),\n \" to install all dependencies\",\n );\n }\n}\n","import path from \"node:path\";\nimport consola from \"consola\";\nimport prompts from \"prompts\";\nimport { cyan, red, reset } from \"./colors\";\nimport {\n type ChainDataType,\n type NetworkDataType,\n type StorageDataType,\n chains,\n storages,\n} from \"./constants\";\nimport { initializeProject } from \"./init\";\nimport {\n createIndexerFile,\n createStorageRelatedFiles,\n updateApibaraConfigFile,\n updatePackageJson,\n} from \"./templates\";\nimport type { Chain, IndexerOptions, Network, Storage } from \"./types\";\nimport {\n cancelOperation,\n checkFileExists,\n convertKebabToCamelCase,\n getApibaraConfigLanguage,\n getPackageManager,\n hasApibaraConfig,\n validateChain,\n validateDnaUrl,\n validateIndexerId,\n validateNetwork,\n validateStorage,\n} from \"./utils\";\n\ntype Options = {\n argIndexerId?: string;\n argChain?: string;\n argNetwork?: string;\n argStorage?: string;\n argDnaUrl?: string;\n argRootDir?: string;\n};\n\nexport async function addIndexer({\n argIndexerId,\n argChain,\n argNetwork,\n argStorage,\n argDnaUrl,\n argRootDir,\n}: Options) {\n const cwd = path.join(process.cwd(), argRootDir ?? \".\");\n const configExists = hasApibaraConfig(cwd);\n\n if (!configExists) {\n consola.error(\"No apibara.config found in the current directory.\");\n\n const prompt_initialize = await prompts({\n type: \"confirm\",\n name: \"prompt_initialize\",\n message: reset(\n \"Do you want to initialize a apibara project here before adding an indexer?\",\n ),\n });\n\n if (prompt_initialize.prompt_initialize) {\n await initializeProject({\n argTargetDir: process.cwd(),\n argNoCreateIndexer: true,\n });\n } else {\n consola.info(\n `Initialize a project with ${cyan(\"apibara init\")} before adding an indexer`,\n );\n throw new Error(\n red(\"✖\") + \" Operation cancelled: No apibara.config found\",\n );\n }\n }\n\n const { language, extension } = getApibaraConfigLanguage(cwd);\n\n validateIndexerId(argIndexerId, true);\n validateChain(argChain, true);\n validateNetwork(argChain, argNetwork, true);\n validateStorage(argStorage, true);\n validateDnaUrl(argDnaUrl, true);\n\n const result = await prompts(\n [\n {\n type: argIndexerId ? null : \"text\",\n name: \"prompt_indexerId\",\n message: reset(\"Indexer ID:\"),\n initial: argIndexerId ?? \"my-indexer\",\n validate: (id) =>\n validateIndexerId(id)\n ? checkFileExists(\n path.join(cwd, \"indexers\", `${id}.indexer.${extension}`),\n ).then(({ exists }) =>\n exists\n ? `Indexer ${cyan(`${id}.indexer.${extension}`)} already exists`\n : true,\n )\n : \"Invalid indexer ID, it cannot be empty and must be in kebab-case format\",\n },\n {\n type: argChain ? null : \"select\",\n name: \"prompt_chain\",\n message: reset(\"Select a chain:\"),\n choices: chains.map((chain) => ({\n title: chain.color(chain.display),\n value: chain,\n })),\n },\n {\n type: argNetwork ? null : \"select\",\n name: \"prompt_network\",\n message: reset(\"Select a network:\"),\n choices: (chain: ChainDataType | undefined) => [\n ...(\n chain?.networks ??\n chains.find((c) => c.name === argChain)?.networks ??\n []\n ).map((network) => ({\n title: network.color(network.display),\n value: network,\n })),\n {\n title: cyan(\"Other\"),\n value: {\n color: cyan,\n display: \"Other\",\n name: \"other\",\n } as NetworkDataType,\n },\n ],\n },\n {\n type: (network: NetworkDataType | undefined) => {\n if (network || argNetwork) {\n return network?.name === \"other\" || argNetwork === \"other\"\n ? \"text\"\n : null;\n }\n return null;\n },\n name: \"prompt_dnaUrl\",\n message: reset(\"Enter a DNA URL:\"),\n validate: (url) => validateDnaUrl(url) || \"Provide a valid DNA Url\",\n },\n {\n type: argStorage ? null : \"select\",\n name: \"prompt_storage\",\n message: reset(\"Select a storage:\"),\n choices: storages.map((storage) => ({\n title: storage.color(storage.display),\n value: storage,\n })),\n },\n ],\n {\n onCancel: () => {\n cancelOperation();\n },\n },\n );\n\n const {\n prompt_indexerId,\n prompt_chain,\n prompt_network,\n prompt_storage,\n prompt_dnaUrl,\n } = result as {\n prompt_indexerId: string | undefined;\n prompt_chain: ChainDataType | undefined;\n prompt_network: NetworkDataType | undefined;\n prompt_storage: StorageDataType | undefined;\n prompt_dnaUrl: string | undefined;\n };\n\n if (!argIndexerId && !prompt_indexerId) {\n throw new Error(red(\"✖\") + \" Indexer ID is required\");\n }\n\n if (!argChain && !prompt_chain) {\n throw new Error(red(\"✖\") + \" Chain is required\");\n }\n\n if (!argNetwork && !prompt_network) {\n throw new Error(red(\"✖\") + \" Network is required\");\n }\n\n const indexerFileId = argIndexerId! ?? prompt_indexerId!;\n\n const pkgManager = getPackageManager();\n\n const options: IndexerOptions = {\n cwd: cwd,\n indexerFileId,\n indexerId: convertKebabToCamelCase(indexerFileId),\n chain: (argChain as Chain) ?? prompt_chain?.name!,\n network: (argNetwork as Network) ?? prompt_network?.name!,\n storage: (argStorage as Storage) ?? prompt_storage?.name!,\n dnaUrl: argDnaUrl ?? prompt_dnaUrl,\n language,\n packageManager: pkgManager.name,\n extension,\n };\n\n await updateApibaraConfigFile(options);\n\n consola.success(`Updated ${cyan(`apibara.config.${extension}`)}`);\n\n await updatePackageJson(options);\n\n consola.success(`Updated ${cyan(\"package.json\")}`);\n\n await createIndexerFile(options);\n\n consola.success(`Created ${cyan(`${indexerFileId}.indexer.${extension}`)}`);\n\n await createStorageRelatedFiles(options);\n\n console.log();\n\n const baseCommand = `${options.packageManager} install`;\n const tsCommand = `${baseCommand} && ${options.packageManager} run prepare`;\n consola.info(\n `Before running the indexer, run ${cyan(language === \"typescript\" ? tsCommand : baseCommand)}`,\n );\n}\n"],"names":["path","overwrite","consola"],"mappings":"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"}