apibara 2.1.0-beta.36 → 2.1.0-beta.38

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.
@@ -112,7 +112,7 @@ async function updateApibaraConfig(apibara, newConfig) {
112
112
  await apibara.hooks.callHook("dev:reload");
113
113
  }
114
114
 
115
- const INDEXER_EXTENSIONS = [".indexer.ts", ".indexer.js"];
115
+ const INDEXER_EXTENSIONS = [".indexer.ts", ".indexer.js", ".indexer.mjs"];
116
116
  async function scanIndexers(apibara) {
117
117
  apibara.logger.debug("Scanning indexers");
118
118
  const indexersDir = join(
@@ -257,7 +257,7 @@ const getIgnorePatterns = (apibara) => [
257
257
  "**/dist/**",
258
258
  "**/.turbo/**",
259
259
  // changes to apibara.config is handled by c12 itself so we dont need rolldown to handle this
260
- "**/apibara.config?(.ts|.js)"
260
+ "**/apibara.config?(.ts|.js|.mjs)"
261
261
  ];
262
262
 
263
263
  async function buildProduction(apibara, rolldownConfig) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/core/config/defaults.ts","../../src/core/config/resolvers/paths.resolver.ts","../../src/core/config/resolvers/runtime.resolver.ts","../../src/core/config/loader.ts","../../src/core/config/update.ts","../../src/core/scan.ts","../../src/core/apibara.ts","../../src/core/build/error.ts","../../src/core/build/dev.ts","../../src/core/build/prod.ts","../../src/core/build/build.ts","../../src/core/path.ts","../../src/core/build/prepare.ts","../../src/core/build/types.ts"],"sourcesContent":["import type { ApibaraConfig } from \"apibara/types\";\n\nexport const ApibaraDefaults: ApibaraConfig = {\n rootDir: \".\",\n indexersDir: \"indexers\",\n\n runtimeConfig: {},\n hooks: {},\n\n buildDir: \".apibara\",\n\n typescript: {\n strict: false,\n generateRuntimeConfigTypes: true,\n internalPaths: false,\n },\n\n node: true,\n exportConditions: [\"node\"],\n};\n","import type { ApibaraOptions } from \"apibara/types\";\nimport { resolve } from \"pathe\";\n\nexport async function resolvePathOptions(options: ApibaraOptions) {\n options.rootDir = resolve(options.rootDir || \".\");\n\n for (const key of [\"buildDir\"] as const) {\n options[key] = resolve(options.rootDir, options[key]);\n }\n\n if (!options.outputDir) {\n options.outputDir = resolve(options.rootDir, \".apibara/build\");\n }\n}\n","import {\n ENV_INTERNAL_APIBARA_PRESET,\n ENV_INTERNAL_APIBARA_PRESETS,\n ENV_INTERNAL_APIBARA_PROCESSED_RUNTIME,\n ENV_INTERNAL_APIBARA_RUNTIME,\n USER_ENV_APIBARA_RUNTIME_CONFIG,\n getProcessedRuntimeConfig,\n} from \"apibara/common\";\nimport type { ApibaraOptions } from \"apibara/types\";\n\nexport function runtimeConfigResolver(options: Partial<ApibaraOptions>) {\n try {\n const { runtimeConfig, preset, presets } = options;\n\n if (runtimeConfig) {\n process.env[ENV_INTERNAL_APIBARA_RUNTIME] = JSON.stringify(runtimeConfig);\n }\n if (preset) {\n process.env[ENV_INTERNAL_APIBARA_PRESET] = preset;\n }\n\n if (presets) {\n process.env[ENV_INTERNAL_APIBARA_PRESETS] = JSON.stringify(presets);\n }\n\n const userEnvRuntimeConfig = JSON.parse(\n process.env[USER_ENV_APIBARA_RUNTIME_CONFIG] ?? \"{}\",\n );\n\n // This is final processed runtime config that will be used by the indexer and useRuntimeConfig hook\n process.env[ENV_INTERNAL_APIBARA_PROCESSED_RUNTIME] = JSON.stringify(\n getProcessedRuntimeConfig({\n preset,\n presets,\n runtimeConfig,\n userEnvRuntimeConfig,\n }),\n );\n } catch (error) {\n throw new Error(\"Failed to process & set runtime environment variables\", {\n cause: error,\n });\n }\n}\n","import type {\n ApibaraConfig,\n ApibaraOptions,\n LoadConfigOptions,\n} from \"apibara/types\";\nimport { loadConfig, watchConfig } from \"c12\";\nimport { klona } from \"klona/full\";\nimport { ApibaraDefaults } from \"./defaults\";\nimport { resolvePathOptions } from \"./resolvers/paths.resolver\";\nimport { runtimeConfigResolver } from \"./resolvers/runtime.resolver\";\n\n// runtimeConfigResolver handles assigning runtime values to env\nconst configResolvers = [resolvePathOptions, runtimeConfigResolver] as const;\n\nexport async function loadOptions(\n configOverrides: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<ApibaraOptions> {\n const options = await _loadUserConfig(configOverrides, opts, dev);\n\n // Check if the runtimeConfig is serializable\n try {\n JSON.stringify(options.runtimeConfig);\n } catch (error) {\n throw new Error(\n \"Non-serializable runtimeConfig. Please ensure the config is serializable.\",\n { cause: error },\n );\n }\n\n for (const resolver of configResolvers) {\n await resolver(options);\n }\n\n return options;\n}\n\nasync function _loadUserConfig(\n configOverrides: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<ApibaraOptions> {\n // biome-ignore lint: noParameterAssign\n configOverrides = klona(configOverrides);\n\n const loadedConfig = await (opts.watch\n ? watchConfig<ApibaraConfig>\n : loadConfig<ApibaraConfig>)({\n name: \"apibara\",\n dotenv: dev,\n cwd: configOverrides.rootDir,\n overrides: {\n ...configOverrides,\n },\n defaults: { ...ApibaraDefaults },\n ...opts.c12,\n });\n\n const options = klona(loadedConfig.config) as ApibaraOptions;\n\n options._config = configOverrides;\n options._c12 = loadedConfig;\n\n if (dev) {\n options.dev = dev;\n }\n\n return options;\n}\n","import type { Apibara, ApibaraDynamicConfig } from \"apibara/types\";\nimport { runtimeConfigResolver } from \"./resolvers/runtime.resolver\";\n\nexport async function updateApibaraConfig(\n apibara: Apibara,\n newConfig: ApibaraDynamicConfig,\n) {\n // applies new config values to env again during hot reload\n runtimeConfigResolver(newConfig);\n apibara.logger.success(\"Apibara config hot reloaded!\");\n // we simply stop indexers and restart them with updated runtime values\n await apibara.hooks.callHook(\"dev:reload\");\n}\n","import type { Apibara } from \"apibara/types\";\nimport fse from \"fs-extra\";\nimport { basename, join } from \"pathe\";\n\nconst INDEXER_EXTENSIONS = [\".indexer.ts\", \".indexer.js\"];\n\nexport async function scanIndexers(apibara: Apibara) {\n apibara.logger.debug(\"Scanning indexers\");\n\n const indexersDir = join(\n apibara.options.rootDir,\n apibara.options.indexersDir,\n );\n\n if (!fse.existsSync(indexersDir)) {\n throw new Error(`Indexers directory not found: ${indexersDir}`);\n }\n\n apibara.indexers = [];\n\n for (const file of fse.readdirSync(indexersDir)) {\n const indexerName = indexerNameFromFile(file);\n if (indexerName) {\n apibara.indexers.push({\n name: indexerName,\n indexer: join(indexersDir, file),\n });\n }\n }\n\n apibara.logger.debug(`Found ${apibara.indexers.length} indexers`);\n}\n\nfunction indexerNameFromFile(file: string) {\n for (const extension of INDEXER_EXTENSIONS) {\n if (file.endsWith(extension)) {\n return basename(file, extension);\n }\n }\n}\n","import type {\n Apibara,\n ApibaraConfig,\n ApibaraDynamicConfig,\n LoadConfigOptions,\n} from \"apibara/types\";\nimport consola from \"consola\";\nimport { createHooks } from \"hookable\";\nimport { loadOptions } from \"./config/loader\";\nimport { updateApibaraConfig } from \"./config/update\";\nimport { scanIndexers } from \"./scan\";\n\nexport async function createApibara(\n config: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<Apibara> {\n const options = await loadOptions(config, opts, dev);\n\n // Enable source map support in Node\n process.env.NODE_OPTIONS = process.env.NODE_OPTIONS\n ? `${process.env.NODE_OPTIONS} --enable-source-maps`\n : \"--enable-source-maps\";\n\n const apibara: Apibara = {\n options,\n indexers: [],\n hooks: createHooks(),\n close: () => apibara.hooks.callHook(\"close\"),\n logger: consola.withTag(\"apibara\"),\n async updateConfig(newConfig: ApibaraDynamicConfig) {\n updateApibaraConfig(apibara, newConfig);\n },\n };\n\n apibara.hooks.addHooks(apibara.options.hooks);\n\n await scanIndexers(apibara);\n\n return apibara;\n}\n","import { isAbsolute, relative } from \"pathe\";\nimport type * as rolldown from \"rolldown\";\n\nexport function formatRolldownError(_error: rolldown.RollupError) {\n try {\n const logs: string[] = [_error.toString()];\n // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n const errors = (_error as any)?.errors || [_error as rolldown.RollupError];\n for (const error of errors) {\n const id = error.path || error.id || (_error as rolldown.RollupError).id;\n let path = isAbsolute(id) ? relative(process.cwd(), id) : id;\n const location = (error as rolldown.RollupError).loc;\n if (location) {\n path += `:${location.line}:${location.column}`;\n }\n const text = (error as rolldown.RollupError).frame;\n\n logs.push(\n `Rolldown error while processing \\`${path}\\`` + text\n ? \"\\n\\n\" + text\n : \"\",\n );\n }\n return logs.join(\"\\n\");\n } catch {\n return _error?.toString();\n }\n}\n","import type { Apibara } from \"apibara/types\";\nimport { watch } from \"chokidar\";\nimport defu from \"defu\";\nimport { join } from \"pathe\";\nimport { debounce } from \"perfect-debounce\";\nimport * as rolldown from \"rolldown\";\nimport { formatRolldownError } from \"./error\";\n\nexport async function watchDev(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n let rolldownWatcher: rolldown.RolldownWatcher;\n async function load() {\n apibara.logger.start(\"Setting up a dev server\");\n if (rolldownWatcher) {\n await rolldownWatcher.close();\n }\n rolldownWatcher = startRolldownWatcher(apibara, rolldownConfig);\n }\n const reload = debounce(async () => await load());\n\n const watchPatterns = getWatchPatterns(apibara);\n\n const watchReloadEvents = new Set([\"add\", \"addDir\", \"unlink\", \"unlinkDir\"]);\n const reloadWatcher = watch(watchPatterns, { ignoreInitial: true }).on(\n \"all\",\n async (event) => {\n if (watchReloadEvents.has(event)) {\n await reload();\n }\n },\n );\n\n apibara.hooks.hook(\"close\", () => {\n rolldownWatcher.close();\n reloadWatcher.close();\n });\n\n apibara.hooks.hook(\"rolldown:reload\", async () => await reload());\n\n await load();\n}\n\nfunction startRolldownWatcher(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n const ignorePatterns = getIgnorePatterns(apibara);\n const watcher = rolldown.watch(\n defu(rolldownConfig, {\n watch: {\n exclude: ignorePatterns,\n ...((apibara.options.watchOptions ?? {}) as rolldown.WatchOptions),\n },\n }),\n );\n let start: number;\n\n watcher.on(\"event\", async (event) => {\n switch (event.code) {\n // The watcher is (re)starting\n case \"START\": {\n await apibara.hooks.callHook(\"dev:restart\");\n return;\n }\n\n // Building an individual bundle\n case \"BUNDLE_START\": {\n start = Date.now();\n return;\n }\n\n // Finished building all bundles\n case \"END\": {\n apibara.hooks.callHook(\"compiled\", apibara);\n apibara.logger.success(\n \"Indexers built\",\n start ? `in ${Date.now() - start} ms` : \"\",\n );\n await apibara.hooks.callHook(\"dev:reload\");\n return;\n }\n\n // Encountered an error while bundling\n case \"ERROR\": {\n apibara.logger.error(formatRolldownError(event.error));\n }\n }\n });\n return watcher;\n}\n\nconst getWatchPatterns = (apibara: Apibara) => [\n join(apibara.options.rootDir, \"indexers\"),\n];\n\nconst getIgnorePatterns = (apibara: Apibara) => [\n \"**/.apibara/**\",\n \"**/.git/**\",\n \"**/.DS_Store\",\n \"**/node_modules/**\",\n \"**/dist/**\",\n \"**/.turbo/**\",\n // changes to apibara.config is handled by c12 itself so we dont need rolldown to handle this\n \"**/apibara.config?(.ts|.js)\",\n];\n","import type { Apibara } from \"apibara/types\";\nimport { colors } from \"consola/utils\";\nimport * as rolldown from \"rolldown\";\n\nexport async function buildProduction(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n if (!apibara.options.disableLogs) {\n apibara.logger.start(\n `Building ${colors.cyan(apibara.indexers.length)} indexers`,\n );\n }\n\n const startTime = Date.now();\n\n try {\n const bundle = await rolldown.rolldown(rolldownConfig);\n\n if (Array.isArray(rolldownConfig.output)) {\n for (const outputOptions of rolldownConfig.output) {\n await bundle.write(outputOptions);\n }\n } else if (rolldownConfig.output) {\n await bundle.write(rolldownConfig.output as rolldown.OutputOptions);\n } else {\n throw new Error(\"No output options specified in Rolldown config\");\n }\n\n await bundle.close();\n\n const endTime = Date.now();\n const duration = endTime - startTime;\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(`Build succeeded in ${duration}ms`);\n apibara.logger.info(\n `You can start the indexers with ${colors.cyan(\"apibara start\")}`,\n );\n }\n } catch (error) {\n apibara.logger.error(\"Build failed\", error);\n throw error;\n }\n}\n","import { getRolldownConfig } from \"apibara/rolldown\";\nimport type { Apibara } from \"apibara/types\";\nimport { colors } from \"consola/utils\";\nimport { watchDev } from \"./dev\";\nimport { buildProduction } from \"./prod\";\n\nexport async function build(apibara: Apibara) {\n const rolldownConfig = getRolldownConfig(apibara);\n\n await apibara.hooks.callHook(\"rolldown:before\", apibara, rolldownConfig);\n\n if (apibara.options.rollupConfig) {\n apibara.logger.error(\n `\\n${colors.cyan(\"apibara.config:\")} rollupConfig is deprecated. Use rolldownConfig instead`,\n );\n process.exit(1);\n }\n\n return apibara.options.dev\n ? await watchDev(apibara, rolldownConfig)\n : await buildProduction(apibara, rolldownConfig);\n}\n","import { colors } from \"consola/utils\";\nimport { relative } from \"pathe\";\n\n/** Return a (possibly highlighted) path relative to the current working directory.\n *\n * From nitrojs/nitro.\n */\nexport function prettyPath(path: string, highlight = true) {\n const rel = relative(process.cwd(), path);\n return highlight ? colors.cyan(rel) : rel;\n}\n","import fsp from \"node:fs/promises\";\nimport type { Apibara } from \"apibara/types\";\nimport fse from \"fs-extra\";\nimport { prettyPath } from \"../path\";\n\nexport async function prepare(apibara: Apibara) {\n await prepareDir(apibara.options.buildDir);\n await prepareDir(apibara.options.outputDir);\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(\n `Output directory ${prettyPath(apibara.options.outputDir)} cleaned`,\n );\n }\n}\n\nasync function prepareDir(dir: string) {\n await fsp.mkdir(dir, { recursive: true });\n await fse.emptyDir(dir);\n}\n","import fsp from \"node:fs/promises\";\nimport type { Apibara } from \"apibara/types\";\nimport { dirname, join, resolve } from \"pathe\";\nimport { type JSValue, generateTypes, resolveSchema } from \"untyped\";\nimport { prettyPath } from \"../path\";\n\nexport async function writeTypes(apibara: Apibara) {\n // Check if the config file has a TypeScript extension so we assume it's a TypeScript project\n const isTypeScript = apibara.options._c12.configFile?.endsWith(\".ts\");\n\n if (!isTypeScript) {\n // If it's not a TypeScript project, we don't need to generate the types\n return;\n }\n\n const typesDir = resolve(apibara.options.buildDir, \"types\");\n\n const config = [\n \"// Generated by apibara\",\n `\ndeclare module \"apibara/types\" {`,\n apibara.options.typescript.generateRuntimeConfigTypes\n ? generateTypes(\n await resolveSchema(\n Object.fromEntries(\n Object.entries(apibara.options.runtimeConfig),\n ) as Record<string, JSValue>,\n ),\n {\n interfaceName: \"ApibaraRuntimeConfig\",\n addExport: false,\n addDefaults: false,\n allowExtraKeys: false,\n indentation: 2,\n },\n )\n : \"\",\n \"}\",\n // Makes this a module for augmentation purposes\n \"export type {};\",\n ];\n\n const buildFiles: { path: string; contents: string }[] = [];\n\n buildFiles.push({\n path: join(typesDir, \"apibara-config.d.ts\"),\n contents: config.join(\"\\n\"),\n });\n\n await Promise.all(\n buildFiles.map(async (file) => {\n const _file = resolve(apibara.options.buildDir, file.path);\n await fsp.mkdir(dirname(_file), { recursive: true });\n await fsp.writeFile(_file, file.contents);\n }),\n );\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(`Types written to ${prettyPath(typesDir)}`);\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/core/config/defaults.ts","../../src/core/config/resolvers/paths.resolver.ts","../../src/core/config/resolvers/runtime.resolver.ts","../../src/core/config/loader.ts","../../src/core/config/update.ts","../../src/core/scan.ts","../../src/core/apibara.ts","../../src/core/build/error.ts","../../src/core/build/dev.ts","../../src/core/build/prod.ts","../../src/core/build/build.ts","../../src/core/path.ts","../../src/core/build/prepare.ts","../../src/core/build/types.ts"],"sourcesContent":["import type { ApibaraConfig } from \"apibara/types\";\n\nexport const ApibaraDefaults: ApibaraConfig = {\n rootDir: \".\",\n indexersDir: \"indexers\",\n\n runtimeConfig: {},\n hooks: {},\n\n buildDir: \".apibara\",\n\n typescript: {\n strict: false,\n generateRuntimeConfigTypes: true,\n internalPaths: false,\n },\n\n node: true,\n exportConditions: [\"node\"],\n};\n","import type { ApibaraOptions } from \"apibara/types\";\nimport { resolve } from \"pathe\";\n\nexport async function resolvePathOptions(options: ApibaraOptions) {\n options.rootDir = resolve(options.rootDir || \".\");\n\n for (const key of [\"buildDir\"] as const) {\n options[key] = resolve(options.rootDir, options[key]);\n }\n\n if (!options.outputDir) {\n options.outputDir = resolve(options.rootDir, \".apibara/build\");\n }\n}\n","import {\n ENV_INTERNAL_APIBARA_PRESET,\n ENV_INTERNAL_APIBARA_PRESETS,\n ENV_INTERNAL_APIBARA_PROCESSED_RUNTIME,\n ENV_INTERNAL_APIBARA_RUNTIME,\n USER_ENV_APIBARA_RUNTIME_CONFIG,\n getProcessedRuntimeConfig,\n} from \"apibara/common\";\nimport type { ApibaraOptions } from \"apibara/types\";\n\nexport function runtimeConfigResolver(options: Partial<ApibaraOptions>) {\n try {\n const { runtimeConfig, preset, presets } = options;\n\n if (runtimeConfig) {\n process.env[ENV_INTERNAL_APIBARA_RUNTIME] = JSON.stringify(runtimeConfig);\n }\n if (preset) {\n process.env[ENV_INTERNAL_APIBARA_PRESET] = preset;\n }\n\n if (presets) {\n process.env[ENV_INTERNAL_APIBARA_PRESETS] = JSON.stringify(presets);\n }\n\n const userEnvRuntimeConfig = JSON.parse(\n process.env[USER_ENV_APIBARA_RUNTIME_CONFIG] ?? \"{}\",\n );\n\n // This is final processed runtime config that will be used by the indexer and useRuntimeConfig hook\n process.env[ENV_INTERNAL_APIBARA_PROCESSED_RUNTIME] = JSON.stringify(\n getProcessedRuntimeConfig({\n preset,\n presets,\n runtimeConfig,\n userEnvRuntimeConfig,\n }),\n );\n } catch (error) {\n throw new Error(\"Failed to process & set runtime environment variables\", {\n cause: error,\n });\n }\n}\n","import type {\n ApibaraConfig,\n ApibaraOptions,\n LoadConfigOptions,\n} from \"apibara/types\";\nimport { loadConfig, watchConfig } from \"c12\";\nimport { klona } from \"klona/full\";\nimport { ApibaraDefaults } from \"./defaults\";\nimport { resolvePathOptions } from \"./resolvers/paths.resolver\";\nimport { runtimeConfigResolver } from \"./resolvers/runtime.resolver\";\n\n// runtimeConfigResolver handles assigning runtime values to env\nconst configResolvers = [resolvePathOptions, runtimeConfigResolver] as const;\n\nexport async function loadOptions(\n configOverrides: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<ApibaraOptions> {\n const options = await _loadUserConfig(configOverrides, opts, dev);\n\n // Check if the runtimeConfig is serializable\n try {\n JSON.stringify(options.runtimeConfig);\n } catch (error) {\n throw new Error(\n \"Non-serializable runtimeConfig. Please ensure the config is serializable.\",\n { cause: error },\n );\n }\n\n for (const resolver of configResolvers) {\n await resolver(options);\n }\n\n return options;\n}\n\nasync function _loadUserConfig(\n configOverrides: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<ApibaraOptions> {\n // biome-ignore lint: noParameterAssign\n configOverrides = klona(configOverrides);\n\n const loadedConfig = await (opts.watch\n ? watchConfig<ApibaraConfig>\n : loadConfig<ApibaraConfig>)({\n name: \"apibara\",\n dotenv: dev,\n cwd: configOverrides.rootDir,\n overrides: {\n ...configOverrides,\n },\n defaults: { ...ApibaraDefaults },\n ...opts.c12,\n });\n\n const options = klona(loadedConfig.config) as ApibaraOptions;\n\n options._config = configOverrides;\n options._c12 = loadedConfig;\n\n if (dev) {\n options.dev = dev;\n }\n\n return options;\n}\n","import type { Apibara, ApibaraDynamicConfig } from \"apibara/types\";\nimport { runtimeConfigResolver } from \"./resolvers/runtime.resolver\";\n\nexport async function updateApibaraConfig(\n apibara: Apibara,\n newConfig: ApibaraDynamicConfig,\n) {\n // applies new config values to env again during hot reload\n runtimeConfigResolver(newConfig);\n apibara.logger.success(\"Apibara config hot reloaded!\");\n // we simply stop indexers and restart them with updated runtime values\n await apibara.hooks.callHook(\"dev:reload\");\n}\n","import type { Apibara } from \"apibara/types\";\nimport fse from \"fs-extra\";\nimport { basename, join } from \"pathe\";\n\nconst INDEXER_EXTENSIONS = [\".indexer.ts\", \".indexer.js\", \".indexer.mjs\"];\n\nexport async function scanIndexers(apibara: Apibara) {\n apibara.logger.debug(\"Scanning indexers\");\n\n const indexersDir = join(\n apibara.options.rootDir,\n apibara.options.indexersDir,\n );\n\n if (!fse.existsSync(indexersDir)) {\n throw new Error(`Indexers directory not found: ${indexersDir}`);\n }\n\n apibara.indexers = [];\n\n for (const file of fse.readdirSync(indexersDir)) {\n const indexerName = indexerNameFromFile(file);\n if (indexerName) {\n apibara.indexers.push({\n name: indexerName,\n indexer: join(indexersDir, file),\n });\n }\n }\n\n apibara.logger.debug(`Found ${apibara.indexers.length} indexers`);\n}\n\nfunction indexerNameFromFile(file: string) {\n for (const extension of INDEXER_EXTENSIONS) {\n if (file.endsWith(extension)) {\n return basename(file, extension);\n }\n }\n}\n","import type {\n Apibara,\n ApibaraConfig,\n ApibaraDynamicConfig,\n LoadConfigOptions,\n} from \"apibara/types\";\nimport consola from \"consola\";\nimport { createHooks } from \"hookable\";\nimport { loadOptions } from \"./config/loader\";\nimport { updateApibaraConfig } from \"./config/update\";\nimport { scanIndexers } from \"./scan\";\n\nexport async function createApibara(\n config: ApibaraConfig = {},\n opts: LoadConfigOptions = {},\n dev = false,\n): Promise<Apibara> {\n const options = await loadOptions(config, opts, dev);\n\n // Enable source map support in Node\n process.env.NODE_OPTIONS = process.env.NODE_OPTIONS\n ? `${process.env.NODE_OPTIONS} --enable-source-maps`\n : \"--enable-source-maps\";\n\n const apibara: Apibara = {\n options,\n indexers: [],\n hooks: createHooks(),\n close: () => apibara.hooks.callHook(\"close\"),\n logger: consola.withTag(\"apibara\"),\n async updateConfig(newConfig: ApibaraDynamicConfig) {\n updateApibaraConfig(apibara, newConfig);\n },\n };\n\n apibara.hooks.addHooks(apibara.options.hooks);\n\n await scanIndexers(apibara);\n\n return apibara;\n}\n","import { isAbsolute, relative } from \"pathe\";\nimport type * as rolldown from \"rolldown\";\n\nexport function formatRolldownError(_error: rolldown.RollupError) {\n try {\n const logs: string[] = [_error.toString()];\n // biome-ignore lint/suspicious/noExplicitAny: <explanation>\n const errors = (_error as any)?.errors || [_error as rolldown.RollupError];\n for (const error of errors) {\n const id = error.path || error.id || (_error as rolldown.RollupError).id;\n let path = isAbsolute(id) ? relative(process.cwd(), id) : id;\n const location = (error as rolldown.RollupError).loc;\n if (location) {\n path += `:${location.line}:${location.column}`;\n }\n const text = (error as rolldown.RollupError).frame;\n\n logs.push(\n `Rolldown error while processing \\`${path}\\`` + text\n ? \"\\n\\n\" + text\n : \"\",\n );\n }\n return logs.join(\"\\n\");\n } catch {\n return _error?.toString();\n }\n}\n","import type { Apibara } from \"apibara/types\";\nimport { watch } from \"chokidar\";\nimport defu from \"defu\";\nimport { join } from \"pathe\";\nimport { debounce } from \"perfect-debounce\";\nimport * as rolldown from \"rolldown\";\nimport { formatRolldownError } from \"./error\";\n\nexport async function watchDev(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n let rolldownWatcher: rolldown.RolldownWatcher;\n async function load() {\n apibara.logger.start(\"Setting up a dev server\");\n if (rolldownWatcher) {\n await rolldownWatcher.close();\n }\n rolldownWatcher = startRolldownWatcher(apibara, rolldownConfig);\n }\n const reload = debounce(async () => await load());\n\n const watchPatterns = getWatchPatterns(apibara);\n\n const watchReloadEvents = new Set([\"add\", \"addDir\", \"unlink\", \"unlinkDir\"]);\n const reloadWatcher = watch(watchPatterns, { ignoreInitial: true }).on(\n \"all\",\n async (event) => {\n if (watchReloadEvents.has(event)) {\n await reload();\n }\n },\n );\n\n apibara.hooks.hook(\"close\", () => {\n rolldownWatcher.close();\n reloadWatcher.close();\n });\n\n apibara.hooks.hook(\"rolldown:reload\", async () => await reload());\n\n await load();\n}\n\nfunction startRolldownWatcher(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n const ignorePatterns = getIgnorePatterns(apibara);\n const watcher = rolldown.watch(\n defu(rolldownConfig, {\n watch: {\n exclude: ignorePatterns,\n ...((apibara.options.watchOptions ?? {}) as rolldown.WatchOptions),\n },\n }),\n );\n let start: number;\n\n watcher.on(\"event\", async (event) => {\n switch (event.code) {\n // The watcher is (re)starting\n case \"START\": {\n await apibara.hooks.callHook(\"dev:restart\");\n return;\n }\n\n // Building an individual bundle\n case \"BUNDLE_START\": {\n start = Date.now();\n return;\n }\n\n // Finished building all bundles\n case \"END\": {\n apibara.hooks.callHook(\"compiled\", apibara);\n apibara.logger.success(\n \"Indexers built\",\n start ? `in ${Date.now() - start} ms` : \"\",\n );\n await apibara.hooks.callHook(\"dev:reload\");\n return;\n }\n\n // Encountered an error while bundling\n case \"ERROR\": {\n apibara.logger.error(formatRolldownError(event.error));\n }\n }\n });\n return watcher;\n}\n\nconst getWatchPatterns = (apibara: Apibara) => [\n join(apibara.options.rootDir, \"indexers\"),\n];\n\nconst getIgnorePatterns = (apibara: Apibara) => [\n \"**/.apibara/**\",\n \"**/.git/**\",\n \"**/.DS_Store\",\n \"**/node_modules/**\",\n \"**/dist/**\",\n \"**/.turbo/**\",\n // changes to apibara.config is handled by c12 itself so we dont need rolldown to handle this\n \"**/apibara.config?(.ts|.js|.mjs)\",\n];\n","import type { Apibara } from \"apibara/types\";\nimport { colors } from \"consola/utils\";\nimport * as rolldown from \"rolldown\";\n\nexport async function buildProduction(\n apibara: Apibara,\n rolldownConfig: rolldown.RolldownOptions,\n) {\n if (!apibara.options.disableLogs) {\n apibara.logger.start(\n `Building ${colors.cyan(apibara.indexers.length)} indexers`,\n );\n }\n\n const startTime = Date.now();\n\n try {\n const bundle = await rolldown.rolldown(rolldownConfig);\n\n if (Array.isArray(rolldownConfig.output)) {\n for (const outputOptions of rolldownConfig.output) {\n await bundle.write(outputOptions);\n }\n } else if (rolldownConfig.output) {\n await bundle.write(rolldownConfig.output as rolldown.OutputOptions);\n } else {\n throw new Error(\"No output options specified in Rolldown config\");\n }\n\n await bundle.close();\n\n const endTime = Date.now();\n const duration = endTime - startTime;\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(`Build succeeded in ${duration}ms`);\n apibara.logger.info(\n `You can start the indexers with ${colors.cyan(\"apibara start\")}`,\n );\n }\n } catch (error) {\n apibara.logger.error(\"Build failed\", error);\n throw error;\n }\n}\n","import { getRolldownConfig } from \"apibara/rolldown\";\nimport type { Apibara } from \"apibara/types\";\nimport { colors } from \"consola/utils\";\nimport { watchDev } from \"./dev\";\nimport { buildProduction } from \"./prod\";\n\nexport async function build(apibara: Apibara) {\n const rolldownConfig = getRolldownConfig(apibara);\n\n await apibara.hooks.callHook(\"rolldown:before\", apibara, rolldownConfig);\n\n if (apibara.options.rollupConfig) {\n apibara.logger.error(\n `\\n${colors.cyan(\"apibara.config:\")} rollupConfig is deprecated. Use rolldownConfig instead`,\n );\n process.exit(1);\n }\n\n return apibara.options.dev\n ? await watchDev(apibara, rolldownConfig)\n : await buildProduction(apibara, rolldownConfig);\n}\n","import { colors } from \"consola/utils\";\nimport { relative } from \"pathe\";\n\n/** Return a (possibly highlighted) path relative to the current working directory.\n *\n * From nitrojs/nitro.\n */\nexport function prettyPath(path: string, highlight = true) {\n const rel = relative(process.cwd(), path);\n return highlight ? colors.cyan(rel) : rel;\n}\n","import fsp from \"node:fs/promises\";\nimport type { Apibara } from \"apibara/types\";\nimport fse from \"fs-extra\";\nimport { prettyPath } from \"../path\";\n\nexport async function prepare(apibara: Apibara) {\n await prepareDir(apibara.options.buildDir);\n await prepareDir(apibara.options.outputDir);\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(\n `Output directory ${prettyPath(apibara.options.outputDir)} cleaned`,\n );\n }\n}\n\nasync function prepareDir(dir: string) {\n await fsp.mkdir(dir, { recursive: true });\n await fse.emptyDir(dir);\n}\n","import fsp from \"node:fs/promises\";\nimport type { Apibara } from \"apibara/types\";\nimport { dirname, join, resolve } from \"pathe\";\nimport { type JSValue, generateTypes, resolveSchema } from \"untyped\";\nimport { prettyPath } from \"../path\";\n\nexport async function writeTypes(apibara: Apibara) {\n // Check if the config file has a TypeScript extension so we assume it's a TypeScript project\n const isTypeScript = apibara.options._c12.configFile?.endsWith(\".ts\");\n\n if (!isTypeScript) {\n // If it's not a TypeScript project, we don't need to generate the types\n return;\n }\n\n const typesDir = resolve(apibara.options.buildDir, \"types\");\n\n const config = [\n \"// Generated by apibara\",\n `\ndeclare module \"apibara/types\" {`,\n apibara.options.typescript.generateRuntimeConfigTypes\n ? generateTypes(\n await resolveSchema(\n Object.fromEntries(\n Object.entries(apibara.options.runtimeConfig),\n ) as Record<string, JSValue>,\n ),\n {\n interfaceName: \"ApibaraRuntimeConfig\",\n addExport: false,\n addDefaults: false,\n allowExtraKeys: false,\n indentation: 2,\n },\n )\n : \"\",\n \"}\",\n // Makes this a module for augmentation purposes\n \"export type {};\",\n ];\n\n const buildFiles: { path: string; contents: string }[] = [];\n\n buildFiles.push({\n path: join(typesDir, \"apibara-config.d.ts\"),\n contents: config.join(\"\\n\"),\n });\n\n await Promise.all(\n buildFiles.map(async (file) => {\n const _file = resolve(apibara.options.buildDir, file.path);\n await fsp.mkdir(dirname(_file), { recursive: true });\n await fsp.writeFile(_file, file.contents);\n }),\n );\n\n if (!apibara.options.disableLogs) {\n apibara.logger.success(`Types written to ${prettyPath(typesDir)}`);\n }\n}\n"],"names":[],"mappings":"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"}
@@ -91,7 +91,7 @@ function validateLanguage(language, throwError = false) {
91
91
  if (!language) {
92
92
  return false;
93
93
  }
94
- if (language === "typescript" || language === "ts" || language === "javascript" || language === "js") {
94
+ if (language === "typescript" || language === "ts" || language === "javascript" || language === "js" || language === "mjs") {
95
95
  return true;
96
96
  }
97
97
  if (throwError) {
@@ -105,7 +105,7 @@ function getLanguageFromAlias(alias) {
105
105
  if (alias === "ts" || alias === "typescript") {
106
106
  return "typescript";
107
107
  }
108
- if (alias === "js" || alias === "javascript") {
108
+ if (alias === "js" || alias === "javascript" || alias === "mjs") {
109
109
  return "javascript";
110
110
  }
111
111
  throw new Error(
@@ -225,16 +225,21 @@ function validateDnaUrl(dnaUrl, throwError = false) {
225
225
  function hasApibaraConfig(cwd) {
226
226
  const configPathJS = path.join(cwd, "apibara.config.js");
227
227
  const configPathTS = path.join(cwd, "apibara.config.ts");
228
- 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);
229
230
  }
230
231
  function getApibaraConfigLanguage(cwd) {
231
232
  const configPathJS = path.join(cwd, "apibara.config.js");
232
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
+ }
233
238
  if (fs.existsSync(configPathJS)) {
234
- return "javascript";
239
+ return { language: "javascript", extension: "js" };
235
240
  }
236
241
  if (fs.existsSync(configPathTS)) {
237
- return "typescript";
242
+ return { language: "typescript", extension: "ts" };
238
243
  }
239
244
  throw new Error(red("\u2716") + " No apibara.config found");
240
245
  }
@@ -472,7 +477,7 @@ async function createIndexerFile(options) {
472
477
  const indexerFilePath = path.join(
473
478
  options.cwd,
474
479
  "indexers",
475
- `${options.indexerFileId}.indexer.${options.language === "typescript" ? "ts" : "js"}`
480
+ `${options.indexerFileId}.indexer.${options.extension}`
476
481
  );
477
482
  const { exists, overwrite } = await checkFileExists(indexerFilePath, {
478
483
  askPrompt: true
@@ -521,12 +526,10 @@ async function updateApibaraConfigFile({
521
526
  storage,
522
527
  language,
523
528
  network,
524
- dnaUrl
529
+ dnaUrl,
530
+ extension
525
531
  }) {
526
- const pathToConfig = path.join(
527
- cwd,
528
- `apibara.config.${language === "typescript" ? "ts" : "js"}`
529
- );
532
+ const pathToConfig = path.join(cwd, `apibara.config.${extension}`);
530
533
  const runtimeConfigString = `{
531
534
  startingBlock: 0,
532
535
  streamUrl: "${dnaUrl ?? getDnaUrl(chain, network)}"
@@ -561,10 +564,15 @@ async function updateApibaraConfigFile({
561
564
  await formatFile(pathToConfig);
562
565
  }
563
566
  async function createDrizzleStorageFiles(options) {
564
- const { cwd, language, storage, indexerId } = options;
567
+ const {
568
+ cwd,
569
+ language,
570
+ storage,
571
+ indexerId,
572
+ extension: fileExtension
573
+ } = options;
565
574
  if (storage !== "postgres")
566
575
  return;
567
- const fileExtension = language === "typescript" ? "ts" : "js";
568
576
  const drizzleConfigFileName = `drizzle.config.${fileExtension}`;
569
577
  const drizzleConfigPath = path.join(cwd, drizzleConfigFileName);
570
578
  const { exists, overwrite } = await checkFileExists(drizzleConfigPath, {
@@ -609,7 +617,7 @@ export {};
609
617
  fs.mkdirSync(path.dirname(schemaPath), { recursive: true });
610
618
  fs.writeFileSync(schemaPath, schemaContent);
611
619
  await formatFile(schemaPath);
612
- consola.success(`Created ${cyan("lib/schema.ts")}`);
620
+ consola.success(`Created ${cyan(`lib/${schemaFileName}`)}`);
613
621
  }
614
622
  console.log("\n");
615
623
  if (!schemaExists || schemaOverwrite) {
@@ -621,7 +629,7 @@ export {};
621
629
 
622
630
  ${yellow(`
623
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
624
- \u2502 lib/schema.ts \u2502
632
+ \u2502 lib/schema \u2502
625
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
626
634
 
627
635
  import { bigint, pgTable, text, uuid } from "drizzle-orm/pg-core";
@@ -879,7 +887,7 @@ async function addIndexer({
879
887
  );
880
888
  }
881
889
  }
882
- const language = getApibaraConfigLanguage(cwd);
890
+ const { language, extension } = getApibaraConfigLanguage(cwd);
883
891
  validateIndexerId(argIndexerId, true);
884
892
  validateChain(argChain, true);
885
893
  validateNetwork(argChain, argNetwork, true);
@@ -893,13 +901,9 @@ async function addIndexer({
893
901
  message: reset("Indexer ID:"),
894
902
  initial: argIndexerId ?? "my-indexer",
895
903
  validate: (id) => validateIndexerId(id) ? checkFileExists(
896
- path.join(
897
- cwd,
898
- "indexers",
899
- `${id}.indexer.${language === "typescript" ? "ts" : "js"}`
900
- )
904
+ path.join(cwd, "indexers", `${id}.indexer.${extension}`)
901
905
  ).then(
902
- ({ exists }) => exists ? `Indexer ${cyan(`${id}.indexer.${language === "typescript" ? "ts" : "js"}`)} already exists` : true
906
+ ({ exists }) => exists ? `Indexer ${cyan(`${id}.indexer.${extension}`)} already exists` : true
903
907
  ) : "Invalid indexer ID, it cannot be empty and must be in kebab-case format"
904
908
  },
905
909
  {
@@ -984,18 +988,15 @@ async function addIndexer({
984
988
  storage: argStorage ?? prompt_storage?.name,
985
989
  dnaUrl: argDnaUrl ?? prompt_dnaUrl,
986
990
  language,
987
- packageManager: pkgManager.name
991
+ packageManager: pkgManager.name,
992
+ extension
988
993
  };
989
994
  await updateApibaraConfigFile(options);
990
- consola$1.success(
991
- `Updated ${cyan("apibara.config." + (language === "typescript" ? "ts" : "js"))}`
992
- );
995
+ consola$1.success(`Updated ${cyan(`apibara.config.${extension}`)}`);
993
996
  await updatePackageJson(options);
994
997
  consola$1.success(`Updated ${cyan("package.json")}`);
995
998
  await createIndexerFile(options);
996
- consola$1.success(
997
- `Created ${cyan(`${indexerFileId}.indexer.${language === "typescript" ? "ts" : "js"}`)}`
998
- );
999
+ consola$1.success(`Created ${cyan(`${indexerFileId}.indexer.${extension}`)}`);
999
1000
  await createStorageRelatedFiles(options);
1000
1001
  console.log();
1001
1002
  const baseCommand = `${options.packageManager} install`;
@@ -1 +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, 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 ) {\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\") {\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\n return fs.existsSync(configPathJS) || fs.existsSync(configPathTS);\n}\n\nexport function getApibaraConfigLanguage(cwd: string): Language {\n const configPathJS = path.join(cwd, \"apibara.config.js\");\n const configPathTS = path.join(cwd, \"apibara.config.ts\");\n\n if (fs.existsSync(configPathJS)) {\n return \"javascript\";\n }\n if (fs.existsSync(configPathTS)) {\n return \"typescript\";\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.language === \"typescript\" ? \"ts\" : \"js\"}`,\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}: IndexerOptions) {\n const pathToConfig = path.join(\n cwd,\n `apibara.config.${language === \"typescript\" ? \"ts\" : \"js\"}`,\n );\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 { cwd, language, storage, indexerId } = options;\n\n if (storage !== \"postgres\") return;\n\n const fileExtension = language === \"typescript\" ? \"ts\" : \"js\";\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/schema.ts\")}`);\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.ts │\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 = 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(\n cwd,\n \"indexers\",\n `${id}.indexer.${language === \"typescript\" ? \"ts\" : \"js\"}`,\n ),\n ).then(({ exists }) =>\n exists\n ? `Indexer ${cyan(`${id}.indexer.${language === \"typescript\" ? \"ts\" : \"js\"}`)} 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 };\n\n await updateApibaraConfigFile(options);\n\n consola.success(\n `Updated ${cyan(\"apibara.config.\" + (language === \"typescript\" ? \"ts\" : \"js\"))}`,\n );\n\n await updatePackageJson(options);\n\n consola.success(`Updated ${cyan(\"package.json\")}`);\n\n await createIndexerFile(options);\n\n consola.success(\n `Created ${cyan(`${indexerFileId}.indexer.${language === \"typescript\" ? \"ts\" : \"js\"}`)}`,\n );\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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"}
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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"}
@@ -23,7 +23,7 @@ function indexers(apibara) {
23
23
  function instrumentation(apibara) {
24
24
  const instrumentationPath = join(
25
25
  apibara.options._c12.cwd,
26
- `instrumentation.${apibara.options._c12.configFile?.endsWith(".ts") ? "ts" : "js"}`
26
+ `instrumentation.${apibara.options._c12.configFile?.endsWith(".ts") ? "ts" : apibara.options._c12.configFile?.endsWith(".mjs") ? "mjs" : "js"}`
27
27
  );
28
28
  if (!existsSync(instrumentationPath)) {
29
29
  return virtual({
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/rolldown/plugins/indexers.ts","../../src/rolldown/plugins/instrumentation.ts","../../src/rolldown/plugins/static-config.ts","../../src/rolldown/config.ts"],"sourcesContent":["import virtual from \"@rollup/plugin-virtual\";\nimport type { Apibara } from \"apibara/types\";\nimport { hash } from \"ohash\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function indexers(apibara: Apibara) {\n const indexers = [...new Set(apibara.indexers)];\n return virtual({\n \"#apibara-internal-virtual/indexers\": `\n ${indexers.map((i) => `import * as _${hash(i)} from '${i.indexer}';`).join(\"\\n\")}\n\n export const indexers = [\n ${indexers.map((i) => `{ name: \"${i.name}\", indexer: _${hash(i)} }`).join(\",\\n\")}\n ];\n `,\n }) as RolldownPluginOption;\n}\n","import { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport virtual from \"@rollup/plugin-virtual\";\nimport type { Apibara } from \"apibara/types\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function instrumentation(apibara: Apibara) {\n const instrumentationPath = join(\n apibara.options._c12.cwd!,\n `instrumentation.${apibara.options._c12.configFile?.endsWith(\".ts\") ? \"ts\" : \"js\"}`,\n );\n\n if (!existsSync(instrumentationPath)) {\n return virtual({\n \"#apibara-internal-virtual/instrumentation\": `\n let register = undefined;\n let logger = undefined;\n \n export { register, logger };\n `,\n }) as RolldownPluginOption;\n }\n\n /**\n * We are importing the instrumentation file inline with \"require\" instead of \"import\" at the top of the file to avoid warnings from rolldown\n * when some methods are not defined in the instrumentation file.\n *\n * Example warning:\n * \n * [IMPORT_IS_UNDEFINED] Warning: Import `logger` will always be undefined because there is no matching export in 'instrumentation.ts'\n * ╭─[virtual:#apibara-internal-virtual/instrumentation:11:35]\n * │\n * 11 │ if (instrumentation && typeof instrumentation.logger === \"function\") {\n * │ ───────────┬────────── \n * │ ╰──────────── \n * ────╯\n\n * [IMPORT_IS_UNDEFINED] Warning: Import `logger` will always be undefined because there is no matching export in 'instrumentation.ts'\n * ╭─[virtual:#apibara-internal-virtual/instrumentation:12:16]\n * │\n * 12 │ logger = instrumentation.logger;\n * │ ───────────┬────────── \n * │ ╰──────────── \n * ────╯ \n */\n return virtual({\n \"#apibara-internal-virtual/instrumentation\": `\n let register = undefined;\n let logger = undefined;\n\n try {\n const instrumentation = require('${instrumentationPath}');\n \n if (instrumentation?.register && typeof instrumentation.register === \"function\") {\n register = instrumentation.register;\n }\n \n if (instrumentation?.logger && typeof instrumentation.logger === \"function\") {\n logger = instrumentation.logger;\n }\n } catch {\n // Silently handle any require errors\n }\n\n export { register, logger };\n `,\n }) as RolldownPluginOption;\n}\n","import virtual from \"@rollup/plugin-virtual\";\nimport { USER_ENV_APIBARA_RUNTIME_CONFIG } from \"apibara/common\";\nimport type { Apibara } from \"apibara/types\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function staticConfig(apibara: Apibara) {\n const presetString = apibara.options.preset ?? \"\";\n const presetsStringified = JSON.stringify(apibara.options.presets ?? {});\n const runtimeConfigStringified = JSON.stringify(\n apibara.options.runtimeConfig ?? {},\n );\n\n return virtual({\n \"#apibara-internal-virtual/static-config\": `\n export const preset = ${presetString ? `\"${presetString}\"` : \"undefined\"};\n export const presets = ${presetsStringified};\n export const runtimeConfig = ${runtimeConfigStringified};\n export const userEnvRuntimeConfig = JSON.parse(process.env.${USER_ENV_APIBARA_RUNTIME_CONFIG} ?? \"{}\");\n `,\n }) as RolldownPluginOption;\n}\n","import { existsSync } from \"node:fs\";\nimport { builtinModules } from \"node:module\";\nimport type { Apibara } from \"apibara/types\";\nimport defu from \"defu\";\nimport { join } from \"pathe\";\nimport type {\n ConfigExport,\n RolldownOptions,\n RolldownPluginOption,\n} from \"rolldown\";\nimport { indexers } from \"./plugins/indexers\";\nimport { instrumentation } from \"./plugins/instrumentation\";\nimport { staticConfig } from \"./plugins/static-config\";\n\nconst runtimeDependencies = [\n \"better-sqlite3\",\n \"@electric-sql/pglite\",\n \"pg\",\n // https://socket.io/docs/v4/server-installation/#additional-packages\n \"utf-8-validate\",\n \"bufferutil\",\n // was giving unresolved import warnings from `node-fetch` library.\n \"encoding\",\n];\n\nexport function getRolldownConfig(apibara: Apibara): RolldownOptions {\n const extensions: string[] = [\n \".ts\",\n \".mjs\",\n \".js\",\n \".json\",\n \".node\",\n \".tsx\",\n \".jsx\",\n ];\n\n const tsConfigExists = existsSync(\n join(apibara.options.rootDir, \"tsconfig.json\"),\n );\n\n const rolldownConfig: RolldownOptions & {\n plugins: RolldownPluginOption[];\n } = defu(\n // biome-ignore lint/suspicious/noExplicitAny: apibara.options.rolldownConfig is typed\n apibara.options.rolldownConfig as any,\n <ConfigExport>{\n platform: \"node\",\n input: apibara.options.entry,\n output: {\n dir: join(apibara.options.outputDir || \"./.apibara/build\"),\n format: \"esm\",\n entryFileNames: \"[name].mjs\",\n chunkFileNames: \"chunks/[name]-[hash].mjs\",\n sourcemap: true,\n },\n plugins: [],\n onwarn(warning, rolldownWarn) {\n if (\n ![\"CIRCULAR_DEPENDENCY\", \"EVAL\", \"THIS_IS_UNDEFINED\"].includes(\n warning.code || \"\",\n ) &&\n !warning.message.includes(\"Unsupported source map comment\") &&\n !warning.message.includes(\"@__PURE__\") &&\n !warning.message.includes(\"/*#__PURE__*/\")\n ) {\n rolldownWarn(warning);\n }\n },\n resolve: {\n extensions,\n preferBuiltins: !!apibara.options.node,\n mainFields: [\"main\"],\n exportConditions: apibara.options.exportConditions,\n tsconfigFilename: tsConfigExists ? \"tsconfig.json\" : undefined,\n },\n treeshake: true,\n external: [...builtinModules, ...runtimeDependencies],\n },\n );\n\n rolldownConfig.plugins?.push(staticConfig(apibara));\n rolldownConfig.plugins?.push(instrumentation(apibara));\n rolldownConfig.plugins?.push(indexers(apibara));\n return rolldownConfig;\n}\n"],"names":["indexers","join"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/rolldown/plugins/indexers.ts","../../src/rolldown/plugins/instrumentation.ts","../../src/rolldown/plugins/static-config.ts","../../src/rolldown/config.ts"],"sourcesContent":["import virtual from \"@rollup/plugin-virtual\";\nimport type { Apibara } from \"apibara/types\";\nimport { hash } from \"ohash\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function indexers(apibara: Apibara) {\n const indexers = [...new Set(apibara.indexers)];\n return virtual({\n \"#apibara-internal-virtual/indexers\": `\n ${indexers.map((i) => `import * as _${hash(i)} from '${i.indexer}';`).join(\"\\n\")}\n\n export const indexers = [\n ${indexers.map((i) => `{ name: \"${i.name}\", indexer: _${hash(i)} }`).join(\",\\n\")}\n ];\n `,\n }) as RolldownPluginOption;\n}\n","import { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport virtual from \"@rollup/plugin-virtual\";\nimport type { Apibara } from \"apibara/types\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function instrumentation(apibara: Apibara) {\n const instrumentationPath = join(\n apibara.options._c12.cwd!,\n `instrumentation.${apibara.options._c12.configFile?.endsWith(\".ts\") ? \"ts\" : apibara.options._c12.configFile?.endsWith(\".mjs\") ? \"mjs\" : \"js\"}`,\n );\n\n if (!existsSync(instrumentationPath)) {\n return virtual({\n \"#apibara-internal-virtual/instrumentation\": `\n let register = undefined;\n let logger = undefined;\n \n export { register, logger };\n `,\n }) as RolldownPluginOption;\n }\n\n /**\n * We are importing the instrumentation file inline with \"require\" instead of \"import\" at the top of the file to avoid warnings from rolldown\n * when some methods are not defined in the instrumentation file.\n *\n * Example warning:\n * \n * [IMPORT_IS_UNDEFINED] Warning: Import `logger` will always be undefined because there is no matching export in 'instrumentation.ts'\n * ╭─[virtual:#apibara-internal-virtual/instrumentation:11:35]\n * │\n * 11 │ if (instrumentation && typeof instrumentation.logger === \"function\") {\n * │ ───────────┬────────── \n * │ ╰──────────── \n * ────╯\n\n * [IMPORT_IS_UNDEFINED] Warning: Import `logger` will always be undefined because there is no matching export in 'instrumentation.ts'\n * ╭─[virtual:#apibara-internal-virtual/instrumentation:12:16]\n * │\n * 12 │ logger = instrumentation.logger;\n * │ ───────────┬────────── \n * │ ╰──────────── \n * ────╯ \n */\n return virtual({\n \"#apibara-internal-virtual/instrumentation\": `\n let register = undefined;\n let logger = undefined;\n\n try {\n const instrumentation = require('${instrumentationPath}');\n \n if (instrumentation?.register && typeof instrumentation.register === \"function\") {\n register = instrumentation.register;\n }\n \n if (instrumentation?.logger && typeof instrumentation.logger === \"function\") {\n logger = instrumentation.logger;\n }\n } catch {\n // Silently handle any require errors\n }\n\n export { register, logger };\n `,\n }) as RolldownPluginOption;\n}\n","import virtual from \"@rollup/plugin-virtual\";\nimport { USER_ENV_APIBARA_RUNTIME_CONFIG } from \"apibara/common\";\nimport type { Apibara } from \"apibara/types\";\nimport type { RolldownPluginOption } from \"rolldown\";\n\nexport function staticConfig(apibara: Apibara) {\n const presetString = apibara.options.preset ?? \"\";\n const presetsStringified = JSON.stringify(apibara.options.presets ?? {});\n const runtimeConfigStringified = JSON.stringify(\n apibara.options.runtimeConfig ?? {},\n );\n\n return virtual({\n \"#apibara-internal-virtual/static-config\": `\n export const preset = ${presetString ? `\"${presetString}\"` : \"undefined\"};\n export const presets = ${presetsStringified};\n export const runtimeConfig = ${runtimeConfigStringified};\n export const userEnvRuntimeConfig = JSON.parse(process.env.${USER_ENV_APIBARA_RUNTIME_CONFIG} ?? \"{}\");\n `,\n }) as RolldownPluginOption;\n}\n","import { existsSync } from \"node:fs\";\nimport { builtinModules } from \"node:module\";\nimport type { Apibara } from \"apibara/types\";\nimport defu from \"defu\";\nimport { join } from \"pathe\";\nimport type {\n ConfigExport,\n RolldownOptions,\n RolldownPluginOption,\n} from \"rolldown\";\nimport { indexers } from \"./plugins/indexers\";\nimport { instrumentation } from \"./plugins/instrumentation\";\nimport { staticConfig } from \"./plugins/static-config\";\n\nconst runtimeDependencies = [\n \"better-sqlite3\",\n \"@electric-sql/pglite\",\n \"pg\",\n // https://socket.io/docs/v4/server-installation/#additional-packages\n \"utf-8-validate\",\n \"bufferutil\",\n // was giving unresolved import warnings from `node-fetch` library.\n \"encoding\",\n];\n\nexport function getRolldownConfig(apibara: Apibara): RolldownOptions {\n const extensions: string[] = [\n \".ts\",\n \".mjs\",\n \".js\",\n \".json\",\n \".node\",\n \".tsx\",\n \".jsx\",\n ];\n\n const tsConfigExists = existsSync(\n join(apibara.options.rootDir, \"tsconfig.json\"),\n );\n\n const rolldownConfig: RolldownOptions & {\n plugins: RolldownPluginOption[];\n } = defu(\n // biome-ignore lint/suspicious/noExplicitAny: apibara.options.rolldownConfig is typed\n apibara.options.rolldownConfig as any,\n <ConfigExport>{\n platform: \"node\",\n input: apibara.options.entry,\n output: {\n dir: join(apibara.options.outputDir || \"./.apibara/build\"),\n format: \"esm\",\n entryFileNames: \"[name].mjs\",\n chunkFileNames: \"chunks/[name]-[hash].mjs\",\n sourcemap: true,\n },\n plugins: [],\n onwarn(warning, rolldownWarn) {\n if (\n ![\"CIRCULAR_DEPENDENCY\", \"EVAL\", \"THIS_IS_UNDEFINED\"].includes(\n warning.code || \"\",\n ) &&\n !warning.message.includes(\"Unsupported source map comment\") &&\n !warning.message.includes(\"@__PURE__\") &&\n !warning.message.includes(\"/*#__PURE__*/\")\n ) {\n rolldownWarn(warning);\n }\n },\n resolve: {\n extensions,\n preferBuiltins: !!apibara.options.node,\n mainFields: [\"main\"],\n exportConditions: apibara.options.exportConditions,\n tsconfigFilename: tsConfigExists ? \"tsconfig.json\" : undefined,\n },\n treeshake: true,\n external: [...builtinModules, ...runtimeDependencies],\n },\n );\n\n rolldownConfig.plugins?.push(staticConfig(apibara));\n rolldownConfig.plugins?.push(instrumentation(apibara));\n rolldownConfig.plugins?.push(indexers(apibara));\n return rolldownConfig;\n}\n"],"names":["indexers","join"],"mappings":"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"}
@@ -1,12 +1,9 @@
1
1
  import { runWithReconnect } from "@apibara/indexer";
2
+ import { createAuthenticatedClient } from "@apibara/protocol";
2
3
  import { getRuntimeDataFromEnv } from "apibara/common";
3
4
  import { defineCommand, runMain } from "citty";
4
5
  import { blueBright } from "picocolors";
5
- import {
6
- availableIndexers,
7
- createAuthenticatedClient,
8
- createIndexer
9
- } from "./internal/app.mjs";
6
+ import { availableIndexers, createIndexer } from "./internal/app.mjs";
10
7
  const startCommand = defineCommand({
11
8
  meta: {
12
9
  name: "start",
@@ -1,4 +1,3 @@
1
- import { type CreateClientOptions, type StreamConfig } from "@apibara/protocol";
2
1
  export declare const availableIndexers: any;
3
2
  export declare function createIndexer({ indexerName, processedRuntimeConfig, preset, }: {
4
3
  indexerName: string;
@@ -14,4 +13,3 @@ export declare function createIndexer({ indexerName, processedRuntimeConfig, pre
14
13
  indexer: import("@apibara/indexer").Indexer<unknown, unknown>;
15
14
  logger: any;
16
15
  } | undefined;
17
- export declare function createAuthenticatedClient(config: StreamConfig<unknown, unknown>, streamUrl: string, options?: CreateClientOptions): import("@apibara/protocol").GrpcClient<unknown, unknown>;
@@ -6,10 +6,6 @@ import {
6
6
  inMemoryPersistence,
7
7
  logger
8
8
  } from "@apibara/indexer/plugins";
9
- import {
10
- Metadata,
11
- createClient
12
- } from "@apibara/protocol";
13
9
  import consola from "consola";
14
10
  import { indexers } from "#apibara-internal-virtual/indexers";
15
11
  import { logger as instrumentationLogger } from "#apibara-internal-virtual/instrumentation";
@@ -63,24 +59,3 @@ export function createIndexer({
63
59
  logger: consola.create({ reporters: [reporter] })
64
60
  };
65
61
  }
66
- export function createAuthenticatedClient(config, streamUrl, options) {
67
- const dnaToken = process.env.DNA_TOKEN;
68
- if (!dnaToken) {
69
- consola.warn(
70
- "DNA_TOKEN environment variable is not set. Trying to connect without authentication."
71
- );
72
- }
73
- return createClient(config, streamUrl, {
74
- ...options,
75
- defaultCallOptions: {
76
- ...options?.defaultCallOptions ?? {},
77
- "*": {
78
- metadata: Metadata({
79
- Authorization: `Bearer ${dnaToken}`
80
- }),
81
- // metadata cant be overrided with spread as its a class so we override it fully if user provided it.
82
- ...options?.defaultCallOptions?.["*"] ?? {}
83
- }
84
- }
85
- });
86
- }
@@ -1,4 +1,5 @@
1
1
  import { runWithReconnect } from "@apibara/indexer";
2
+ import { createAuthenticatedClient } from "@apibara/protocol";
2
3
  import {
3
4
  checkForUnknownArgs,
4
5
  getProcessedRuntimeConfig,
@@ -14,7 +15,7 @@ import {
14
15
  runtimeConfig,
15
16
  userEnvRuntimeConfig
16
17
  } from "#apibara-internal-virtual/static-config";
17
- import { createAuthenticatedClient, createIndexer } from "./internal/app.mjs";
18
+ import { createIndexer } from "./internal/app.mjs";
18
19
  const startCommand = defineCommand({
19
20
  meta: {
20
21
  name: "start",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "apibara",
3
- "version": "2.1.0-beta.36",
3
+ "version": "2.1.0-beta.38",
4
4
  "type": "module",
5
5
  "main": "./dist/core/index.mjs",
6
6
  "exports": {
@@ -98,7 +98,7 @@
98
98
  "playground:add": "pnpm playground add --dir playground"
99
99
  },
100
100
  "devDependencies": {
101
- "@apibara/starknet": "2.1.0-beta.36",
101
+ "@apibara/starknet": "2.1.0-beta.38",
102
102
  "@types/fs-extra": "^11.0.4",
103
103
  "@types/node": "^20.14.0",
104
104
  "@types/prompts": "^2.4.9",
@@ -109,8 +109,8 @@
109
109
  "vitest": "^1.6.0"
110
110
  },
111
111
  "dependencies": {
112
- "@apibara/indexer": "2.1.0-beta.36",
113
- "@apibara/protocol": "2.1.0-beta.36",
112
+ "@apibara/indexer": "2.1.0-beta.38",
113
+ "@apibara/protocol": "2.1.0-beta.38",
114
114
  "@rollup/plugin-replace": "^6.0.2",
115
115
  "@rollup/plugin-virtual": "^3.0.2",
116
116
  "c12": "^1.11.1",
@@ -103,5 +103,5 @@ const getIgnorePatterns = (apibara: Apibara) => [
103
103
  "**/dist/**",
104
104
  "**/.turbo/**",
105
105
  // changes to apibara.config is handled by c12 itself so we dont need rolldown to handle this
106
- "**/apibara.config?(.ts|.js)",
106
+ "**/apibara.config?(.ts|.js|.mjs)",
107
107
  ];
package/src/core/scan.ts CHANGED
@@ -2,7 +2,7 @@ import type { Apibara } from "apibara/types";
2
2
  import fse from "fs-extra";
3
3
  import { basename, join } from "pathe";
4
4
 
5
- const INDEXER_EXTENSIONS = [".indexer.ts", ".indexer.js"];
5
+ const INDEXER_EXTENSIONS = [".indexer.ts", ".indexer.js", ".indexer.mjs"];
6
6
 
7
7
  export async function scanIndexers(apibara: Apibara) {
8
8
  apibara.logger.debug("Scanning indexers");
package/src/create/add.ts CHANGED
@@ -77,7 +77,7 @@ export async function addIndexer({
77
77
  }
78
78
  }
79
79
 
80
- const language = getApibaraConfigLanguage(cwd);
80
+ const { language, extension } = getApibaraConfigLanguage(cwd);
81
81
 
82
82
  validateIndexerId(argIndexerId, true);
83
83
  validateChain(argChain, true);
@@ -95,14 +95,10 @@ export async function addIndexer({
95
95
  validate: (id) =>
96
96
  validateIndexerId(id)
97
97
  ? checkFileExists(
98
- path.join(
99
- cwd,
100
- "indexers",
101
- `${id}.indexer.${language === "typescript" ? "ts" : "js"}`,
102
- ),
98
+ path.join(cwd, "indexers", `${id}.indexer.${extension}`),
103
99
  ).then(({ exists }) =>
104
100
  exists
105
- ? `Indexer ${cyan(`${id}.indexer.${language === "typescript" ? "ts" : "js"}`)} already exists`
101
+ ? `Indexer ${cyan(`${id}.indexer.${extension}`)} already exists`
106
102
  : true,
107
103
  )
108
104
  : "Invalid indexer ID, it cannot be empty and must be in kebab-case format",
@@ -209,13 +205,12 @@ export async function addIndexer({
209
205
  dnaUrl: argDnaUrl ?? prompt_dnaUrl,
210
206
  language,
211
207
  packageManager: pkgManager.name,
208
+ extension,
212
209
  };
213
210
 
214
211
  await updateApibaraConfigFile(options);
215
212
 
216
- consola.success(
217
- `Updated ${cyan("apibara.config." + (language === "typescript" ? "ts" : "js"))}`,
218
- );
213
+ consola.success(`Updated ${cyan(`apibara.config.${extension}`)}`);
219
214
 
220
215
  await updatePackageJson(options);
221
216
 
@@ -223,9 +218,7 @@ export async function addIndexer({
223
218
 
224
219
  await createIndexerFile(options);
225
220
 
226
- consola.success(
227
- `Created ${cyan(`${indexerFileId}.indexer.${language === "typescript" ? "ts" : "js"}`)}`,
228
- );
221
+ consola.success(`Created ${cyan(`${indexerFileId}.indexer.${extension}`)}`);
229
222
 
230
223
  await createStorageRelatedFiles(options);
231
224
 
@@ -143,7 +143,7 @@ export async function createIndexerFile(options: IndexerOptions) {
143
143
  const indexerFilePath = path.join(
144
144
  options.cwd,
145
145
  "indexers",
146
- `${options.indexerFileId}.indexer.${options.language === "typescript" ? "ts" : "js"}`,
146
+ `${options.indexerFileId}.indexer.${options.extension}`,
147
147
  );
148
148
 
149
149
  const { exists, overwrite } = await checkFileExists(indexerFilePath, {
@@ -214,11 +214,9 @@ export async function updateApibaraConfigFile({
214
214
  language,
215
215
  network,
216
216
  dnaUrl,
217
+ extension,
217
218
  }: IndexerOptions) {
218
- const pathToConfig = path.join(
219
- cwd,
220
- `apibara.config.${language === "typescript" ? "ts" : "js"}`,
221
- );
219
+ const pathToConfig = path.join(cwd, `apibara.config.${extension}`);
222
220
 
223
221
  const runtimeConfigString = `{
224
222
  startingBlock: 0,
@@ -267,12 +265,16 @@ export async function updateApibaraConfigFile({
267
265
  }
268
266
 
269
267
  export async function createDrizzleStorageFiles(options: IndexerOptions) {
270
- const { cwd, language, storage, indexerId } = options;
268
+ const {
269
+ cwd,
270
+ language,
271
+ storage,
272
+ indexerId,
273
+ extension: fileExtension,
274
+ } = options;
271
275
 
272
276
  if (storage !== "postgres") return;
273
277
 
274
- const fileExtension = language === "typescript" ? "ts" : "js";
275
-
276
278
  /**
277
279
  *
278
280
  *
@@ -349,7 +351,7 @@ export {};
349
351
 
350
352
  await formatFile(schemaPath);
351
353
 
352
- consola.success(`Created ${cyan("lib/schema.ts")}`);
354
+ consola.success(`Created ${cyan(`lib/${schemaFileName}`)}`);
353
355
  }
354
356
 
355
357
  console.log("\n");
@@ -366,7 +368,7 @@ export {};
366
368
 
367
369
  ${yellow(`
368
370
  ┌──────────────────────────────────────────┐
369
- │ lib/schema.ts
371
+ │ lib/schema
370
372
  └──────────────────────────────────────────┘
371
373
 
372
374
  import { bigint, pgTable, text, uuid } from "drizzle-orm/pg-core";
@@ -16,6 +16,8 @@ export type Network =
16
16
 
17
17
  export type Storage = "postgres" | "none";
18
18
 
19
+ export type FileExtension = "js" | "ts" | "mjs";
20
+
19
21
  export type IndexerOptions = {
20
22
  cwd: string;
21
23
  indexerFileId: string;
@@ -26,6 +28,7 @@ export type IndexerOptions = {
26
28
  dnaUrl?: string;
27
29
  packageManager: string;
28
30
  language: Language;
31
+ extension: FileExtension;
29
32
  };
30
33
 
31
34
  export type PkgInfo = {
@@ -4,7 +4,7 @@ import * as prettier from "prettier";
4
4
  import prompts from "prompts";
5
5
  import { blue, cyan, red, yellow } from "./colors";
6
6
  import { dnaUrls, networks } from "./constants";
7
- import type { Chain, Language, Network, PkgInfo } from "./types";
7
+ import type { Chain, FileExtension, Language, Network, PkgInfo } from "./types";
8
8
 
9
9
  export function isEmpty(path: string) {
10
10
  const files = fs.readdirSync(path);
@@ -31,7 +31,8 @@ export function validateLanguage(language?: string, throwError = false) {
31
31
  language === "typescript" ||
32
32
  language === "ts" ||
33
33
  language === "javascript" ||
34
- language === "js"
34
+ language === "js" ||
35
+ language === "mjs"
35
36
  ) {
36
37
  return true;
37
38
  }
@@ -49,7 +50,7 @@ export function getLanguageFromAlias(alias: string): Language {
49
50
  if (alias === "ts" || alias === "typescript") {
50
51
  return "typescript";
51
52
  }
52
- if (alias === "js" || alias === "javascript") {
53
+ if (alias === "js" || alias === "javascript" || alias === "mjs") {
53
54
  return "javascript";
54
55
  }
55
56
 
@@ -184,19 +185,31 @@ export function validateDnaUrl(dnaUrl?: string, throwError = false) {
184
185
  export function hasApibaraConfig(cwd: string): boolean {
185
186
  const configPathJS = path.join(cwd, "apibara.config.js");
186
187
  const configPathTS = path.join(cwd, "apibara.config.ts");
188
+ const configPathMJS = path.join(cwd, "apibara.config.mjs");
187
189
 
188
- return fs.existsSync(configPathJS) || fs.existsSync(configPathTS);
190
+ return (
191
+ fs.existsSync(configPathJS) ||
192
+ fs.existsSync(configPathTS) ||
193
+ fs.existsSync(configPathMJS)
194
+ );
189
195
  }
190
196
 
191
- export function getApibaraConfigLanguage(cwd: string): Language {
197
+ export function getApibaraConfigLanguage(cwd: string): {
198
+ language: Language;
199
+ extension: FileExtension;
200
+ } {
192
201
  const configPathJS = path.join(cwd, "apibara.config.js");
193
202
  const configPathTS = path.join(cwd, "apibara.config.ts");
203
+ const configPathMJS = path.join(cwd, "apibara.config.mjs");
194
204
 
205
+ if (fs.existsSync(configPathMJS)) {
206
+ return { language: "javascript", extension: "mjs" };
207
+ }
195
208
  if (fs.existsSync(configPathJS)) {
196
- return "javascript";
209
+ return { language: "javascript", extension: "js" };
197
210
  }
198
211
  if (fs.existsSync(configPathTS)) {
199
- return "typescript";
212
+ return { language: "typescript", extension: "ts" };
200
213
  }
201
214
 
202
215
  throw new Error(red("✖") + " No apibara.config found");
@@ -7,7 +7,7 @@ import type { RolldownPluginOption } from "rolldown";
7
7
  export function instrumentation(apibara: Apibara) {
8
8
  const instrumentationPath = join(
9
9
  apibara.options._c12.cwd!,
10
- `instrumentation.${apibara.options._c12.configFile?.endsWith(".ts") ? "ts" : "js"}`,
10
+ `instrumentation.${apibara.options._c12.configFile?.endsWith(".ts") ? "ts" : apibara.options._c12.configFile?.endsWith(".mjs") ? "mjs" : "js"}`,
11
11
  );
12
12
 
13
13
  if (!existsSync(instrumentationPath)) {
@@ -1,12 +1,9 @@
1
1
  import { runWithReconnect } from "@apibara/indexer";
2
+ import { createAuthenticatedClient } from "@apibara/protocol";
2
3
  import { getRuntimeDataFromEnv } from "apibara/common";
3
4
  import { defineCommand, runMain } from "citty";
4
5
  import { blueBright } from "picocolors";
5
- import {
6
- availableIndexers,
7
- createAuthenticatedClient,
8
- createIndexer,
9
- } from "./internal/app";
6
+ import { availableIndexers, createIndexer } from "./internal/app";
10
7
 
11
8
  const startCommand = defineCommand({
12
9
  meta: {
@@ -8,12 +8,6 @@ import {
8
8
  inMemoryPersistence,
9
9
  logger,
10
10
  } from "@apibara/indexer/plugins";
11
- import {
12
- type CreateClientOptions,
13
- Metadata,
14
- type StreamConfig,
15
- createClient,
16
- } from "@apibara/protocol";
17
11
  import consola from "consola";
18
12
  import { indexers } from "#apibara-internal-virtual/indexers";
19
13
  import { logger as instrumentationLogger } from "#apibara-internal-virtual/instrumentation";
@@ -95,30 +89,3 @@ export function createIndexer({
95
89
  logger: consola.create({ reporters: [reporter] }),
96
90
  };
97
91
  }
98
-
99
- export function createAuthenticatedClient(
100
- config: StreamConfig<unknown, unknown>,
101
- streamUrl: string,
102
- options?: CreateClientOptions,
103
- ) {
104
- const dnaToken = process.env.DNA_TOKEN;
105
- if (!dnaToken) {
106
- consola.warn(
107
- "DNA_TOKEN environment variable is not set. Trying to connect without authentication.",
108
- );
109
- }
110
-
111
- return createClient(config, streamUrl, {
112
- ...options,
113
- defaultCallOptions: {
114
- ...(options?.defaultCallOptions ?? {}),
115
- "*": {
116
- metadata: Metadata({
117
- Authorization: `Bearer ${dnaToken}`,
118
- }),
119
- // metadata cant be overrided with spread as its a class so we override it fully if user provided it.
120
- ...(options?.defaultCallOptions?.["*"] ?? {}),
121
- },
122
- },
123
- });
124
- }
@@ -1,4 +1,5 @@
1
1
  import { runWithReconnect } from "@apibara/indexer";
2
+ import { createAuthenticatedClient } from "@apibara/protocol";
2
3
  import {
3
4
  checkForUnknownArgs,
4
5
  getProcessedRuntimeConfig,
@@ -15,7 +16,7 @@ import {
15
16
  runtimeConfig,
16
17
  userEnvRuntimeConfig,
17
18
  } from "#apibara-internal-virtual/static-config";
18
- import { createAuthenticatedClient, createIndexer } from "./internal/app";
19
+ import { createIndexer } from "./internal/app";
19
20
 
20
21
  const startCommand = defineCommand({
21
22
  meta: {