@alepha/devtools 0.14.2 → 0.14.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (175) hide show
  1. package/assets/devtools/actions.html +37 -0
  2. package/assets/devtools/actions.html.br +0 -0
  3. package/assets/devtools/actions.html.gz +0 -0
  4. package/assets/devtools/asset.BZV40eAE.css.br +0 -0
  5. package/assets/devtools/asset.BZV40eAE.css.gz +0 -0
  6. package/assets/devtools/asset.DbJSgVPr.css.br +0 -0
  7. package/assets/devtools/asset.DbJSgVPr.css.gz +0 -0
  8. package/assets/devtools/atoms.html +37 -0
  9. package/assets/devtools/atoms.html.br +0 -0
  10. package/assets/devtools/atoms.html.gz +0 -0
  11. package/assets/devtools/caches.html +37 -0
  12. package/assets/devtools/caches.html.br +0 -0
  13. package/assets/devtools/caches.html.gz +0 -0
  14. package/assets/devtools/chunk.5EOPWu_h.js +9 -0
  15. package/assets/devtools/chunk.5EOPWu_h.js.br +0 -0
  16. package/assets/devtools/chunk.5EOPWu_h.js.gz +0 -0
  17. package/assets/devtools/chunk.B-FEo0lV.js +1 -0
  18. package/assets/devtools/chunk.B-FEo0lV.js.br +0 -0
  19. package/assets/devtools/chunk.B-FEo0lV.js.gz +0 -0
  20. package/assets/devtools/{chunk.C2Epljet.js → chunk.BCBZ1wAk.js} +1 -1
  21. package/assets/devtools/chunk.BCBZ1wAk.js.br +0 -0
  22. package/assets/devtools/chunk.BCBZ1wAk.js.gz +0 -0
  23. package/assets/devtools/{chunk.DRx03mgu.js → chunk.BKZ6YEV4.js} +1 -1
  24. package/assets/devtools/chunk.BKZ6YEV4.js.br +0 -0
  25. package/assets/devtools/chunk.BKZ6YEV4.js.gz +0 -0
  26. package/assets/devtools/{chunk.DUP1E40B.js → chunk.BQQ5nN1l.js} +1 -1
  27. package/assets/devtools/chunk.BQQ5nN1l.js.br +0 -0
  28. package/assets/devtools/chunk.BQQ5nN1l.js.gz +0 -0
  29. package/assets/devtools/{chunk.CcRPc1V0.js → chunk.BX7p74D8.js} +1 -1
  30. package/assets/devtools/chunk.BX7p74D8.js.br +0 -0
  31. package/assets/devtools/chunk.BX7p74D8.js.gz +0 -0
  32. package/assets/devtools/{chunk.QuY3UyEF.js → chunk.BZpSlmHc.js} +1 -1
  33. package/assets/devtools/chunk.BZpSlmHc.js.br +0 -0
  34. package/assets/devtools/chunk.BZpSlmHc.js.gz +0 -0
  35. package/assets/devtools/{chunk.BXj_XO3l.js → chunk.BgMi2Pqe.js} +1 -1
  36. package/assets/devtools/chunk.BgMi2Pqe.js.br +0 -0
  37. package/assets/devtools/chunk.BgMi2Pqe.js.gz +0 -0
  38. package/assets/devtools/chunk.BjFrJKj1.js.br +2 -0
  39. package/assets/devtools/chunk.BjFrJKj1.js.gz +0 -0
  40. package/assets/devtools/{chunk.D6vpaxPE.js → chunk.BjOMCPQ3.js} +1 -1
  41. package/assets/devtools/chunk.BjOMCPQ3.js.br +0 -0
  42. package/assets/devtools/chunk.BjOMCPQ3.js.gz +0 -0
  43. package/assets/devtools/chunk.BlqFPyLh.js.br +0 -0
  44. package/assets/devtools/chunk.BlqFPyLh.js.gz +0 -0
  45. package/assets/devtools/{chunk.CMrSghiM.js → chunk.BqEqrty9.js} +1 -1
  46. package/assets/devtools/chunk.BqEqrty9.js.br +0 -0
  47. package/assets/devtools/chunk.BqEqrty9.js.gz +0 -0
  48. package/assets/devtools/chunk.BuGWOypT.js +1 -0
  49. package/assets/devtools/chunk.BuGWOypT.js.br +0 -0
  50. package/assets/devtools/chunk.BuGWOypT.js.gz +0 -0
  51. package/assets/devtools/chunk.C3geCUq9.js +1 -0
  52. package/assets/devtools/chunk.C3geCUq9.js.br +0 -0
  53. package/assets/devtools/chunk.C3geCUq9.js.gz +0 -0
  54. package/assets/devtools/{chunk.BkQQhCPw.js → chunk.CEbDj1NR.js} +1 -1
  55. package/assets/devtools/chunk.CEbDj1NR.js.br +0 -0
  56. package/assets/devtools/chunk.CEbDj1NR.js.gz +0 -0
  57. package/assets/devtools/{chunk.Dwb-lFg8.js → chunk.CIYikik4.js} +1 -1
  58. package/assets/devtools/chunk.CIYikik4.js.br +0 -0
  59. package/assets/devtools/chunk.CIYikik4.js.gz +0 -0
  60. package/assets/devtools/chunk.CQO49DQF.js +1 -0
  61. package/assets/devtools/chunk.CQO49DQF.js.br +0 -0
  62. package/assets/devtools/chunk.CQO49DQF.js.gz +0 -0
  63. package/assets/devtools/chunk.CWwJDVEM.js +1 -0
  64. package/assets/devtools/chunk.CWwJDVEM.js.br +0 -0
  65. package/assets/devtools/chunk.CWwJDVEM.js.gz +0 -0
  66. package/assets/devtools/{chunk.B_-9nxHc.js → chunk.CZ4J9K5b.js} +1 -1
  67. package/assets/devtools/chunk.CZ4J9K5b.js.br +4 -0
  68. package/assets/devtools/chunk.CZ4J9K5b.js.gz +0 -0
  69. package/assets/devtools/chunk.CoD2sLa1.js +1 -0
  70. package/assets/devtools/chunk.CoD2sLa1.js.br +0 -0
  71. package/assets/devtools/chunk.CoD2sLa1.js.gz +0 -0
  72. package/assets/devtools/chunk.CsxSstrk.js +1 -0
  73. package/assets/devtools/chunk.CsxSstrk.js.br +0 -0
  74. package/assets/devtools/chunk.CsxSstrk.js.gz +0 -0
  75. package/assets/devtools/{chunk.BA8URMP8.js → chunk.D0jFBu2p.js} +1 -1
  76. package/assets/devtools/chunk.D0jFBu2p.js.br +0 -0
  77. package/assets/devtools/chunk.D0jFBu2p.js.gz +0 -0
  78. package/assets/devtools/chunk.D7ro5_n3.js +1 -0
  79. package/assets/devtools/chunk.D7ro5_n3.js.br +0 -0
  80. package/assets/devtools/chunk.D7ro5_n3.js.gz +0 -0
  81. package/assets/devtools/chunk.W-1mjDd7.js +7 -0
  82. package/assets/devtools/chunk.W-1mjDd7.js.br +0 -0
  83. package/assets/devtools/chunk.W-1mjDd7.js.gz +0 -0
  84. package/assets/devtools/chunk._3YEef80.js +1 -0
  85. package/assets/devtools/chunk._3YEef80.js.br +0 -0
  86. package/assets/devtools/chunk._3YEef80.js.gz +0 -0
  87. package/assets/devtools/{chunk.CD3lZA1D.js → chunk._t5z0lP9.js} +1 -1
  88. package/assets/devtools/chunk._t5z0lP9.js.br +0 -0
  89. package/assets/devtools/chunk._t5z0lP9.js.gz +0 -0
  90. package/assets/devtools/chunk.albVVSQX.js +1 -0
  91. package/assets/devtools/chunk.albVVSQX.js.br +0 -0
  92. package/assets/devtools/chunk.albVVSQX.js.gz +0 -0
  93. package/assets/devtools/{chunk.CSlinMdh.js → chunk.bPNpu2iW.js} +1 -1
  94. package/assets/devtools/chunk.bPNpu2iW.js.br +0 -0
  95. package/assets/devtools/chunk.bPNpu2iW.js.gz +0 -0
  96. package/assets/devtools/chunk.fWijEdcZ.js +2 -0
  97. package/assets/devtools/chunk.fWijEdcZ.js.br +0 -0
  98. package/assets/devtools/chunk.fWijEdcZ.js.gz +0 -0
  99. package/assets/devtools/chunk.ffYG67rk.js +1 -0
  100. package/assets/devtools/chunk.ffYG67rk.js.br +0 -0
  101. package/assets/devtools/chunk.ffYG67rk.js.gz +0 -0
  102. package/assets/devtools/chunk.lo8X57tY.js +1 -0
  103. package/assets/devtools/chunk.lo8X57tY.js.br +0 -0
  104. package/assets/devtools/chunk.lo8X57tY.js.gz +0 -0
  105. package/assets/devtools/{chunk.C2XzHl1-.js → chunk.rqjDVBSo.js} +1 -1
  106. package/assets/devtools/chunk.rqjDVBSo.js.br +0 -0
  107. package/assets/devtools/chunk.rqjDVBSo.js.gz +0 -0
  108. package/assets/devtools/chunk.u4exfSZ6.js +1 -0
  109. package/assets/devtools/chunk.u4exfSZ6.js.br +0 -0
  110. package/assets/devtools/chunk.u4exfSZ6.js.gz +0 -0
  111. package/assets/devtools/chunk.uyVen0u2.js.br +0 -0
  112. package/assets/devtools/chunk.uyVen0u2.js.gz +0 -0
  113. package/assets/devtools/chunk.xjh83uy1.js +1 -0
  114. package/assets/devtools/chunk.xjh83uy1.js.br +0 -0
  115. package/assets/devtools/chunk.xjh83uy1.js.gz +0 -0
  116. package/assets/devtools/chunk.yZM2qlCX.js +2 -0
  117. package/assets/devtools/chunk.yZM2qlCX.js.br +0 -0
  118. package/assets/devtools/chunk.yZM2qlCX.js.gz +0 -0
  119. package/assets/devtools/db.html +34 -0
  120. package/assets/devtools/db.html.br +0 -0
  121. package/assets/devtools/db.html.gz +0 -0
  122. package/assets/devtools/entry.BWhdC3SJ.js +79 -0
  123. package/assets/devtools/entry.BWhdC3SJ.js.br +0 -0
  124. package/assets/devtools/entry.BWhdC3SJ.js.gz +0 -0
  125. package/assets/devtools/env.html +35 -0
  126. package/assets/devtools/env.html.br +0 -0
  127. package/assets/devtools/env.html.gz +0 -0
  128. package/assets/devtools/graph.html +38 -0
  129. package/assets/devtools/graph.html.br +0 -0
  130. package/assets/devtools/graph.html.gz +0 -0
  131. package/assets/devtools/index.html +28 -8
  132. package/assets/devtools/index.html.br +0 -0
  133. package/assets/devtools/index.html.gz +0 -0
  134. package/assets/devtools/logs.html +38 -0
  135. package/assets/devtools/logs.html.br +0 -0
  136. package/assets/devtools/logs.html.gz +0 -0
  137. package/assets/devtools/queues.html +30 -0
  138. package/assets/devtools/queues.html.br +0 -0
  139. package/assets/devtools/queues.html.gz +0 -0
  140. package/assets/devtools/topics.html +38 -0
  141. package/assets/devtools/topics.html.br +0 -0
  142. package/assets/devtools/topics.html.gz +0 -0
  143. package/dist/index.d.ts +45 -1
  144. package/dist/index.js +15 -1
  145. package/dist/index.js.map +1 -1
  146. package/package.json +9 -9
  147. package/src/__tests__/DevCollectorProvider.spec.ts +7 -0
  148. package/src/api/providers/DevToolsDatabaseProvider.ts +16 -0
  149. package/src/index.ts +0 -4
  150. package/src/ui/components/DevDashboard.tsx +13 -163
  151. package/src/ui/components/DevLayout.tsx +26 -21
  152. package/src/ui/components/graph/DevDependencyGraph.tsx +123 -104
  153. package/src/ui/components/graph/GraphControls.tsx +31 -25
  154. package/assets/devtools/chunk.3mUAkkKN.js +0 -1
  155. package/assets/devtools/chunk.AVmV_XG3.js +0 -1
  156. package/assets/devtools/chunk.B9Nj9arT.js +0 -1
  157. package/assets/devtools/chunk.BZoA8zmc.js +0 -1
  158. package/assets/devtools/chunk.Bk_AzNdP.js +0 -7
  159. package/assets/devtools/chunk.BlCuAV4r.js +0 -2
  160. package/assets/devtools/chunk.BoKPUi4h.js +0 -2
  161. package/assets/devtools/chunk.CMPoj2S1.js +0 -1
  162. package/assets/devtools/chunk.CNyKXw81.js +0 -9
  163. package/assets/devtools/chunk.CUdeQBl0.js +0 -6
  164. package/assets/devtools/chunk.CqWgHz10.js +0 -1
  165. package/assets/devtools/chunk.DCS6fHH1.js +0 -1
  166. package/assets/devtools/chunk.DIbRzrh1.js +0 -1
  167. package/assets/devtools/chunk.DJdym_tE.js +0 -1
  168. package/assets/devtools/chunk.DhCpNWJE.js +0 -1
  169. package/assets/devtools/chunk.DojDQgy5.js +0 -1
  170. package/assets/devtools/chunk.DqX1betX.js +0 -1
  171. package/assets/devtools/chunk.OgXBCMJY.js +0 -1
  172. package/assets/devtools/chunk.VmKlHUok.js +0 -1
  173. package/assets/devtools/chunk.VyCl7mMj.js +0 -1
  174. package/assets/devtools/chunk.e9ZcH1yi.js +0 -1
  175. package/assets/devtools/entry.r_sixgJG.js +0 -75
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":[],"sources":["../src/api/entities/logs.ts","../src/api/providers/DevToolsMetadataProvider.ts","../src/api/providers/DevToolsDatabaseProvider.ts","../src/api/repositories/LogRepository.ts","../src/api/schemas/DevActionMetadata.ts","../src/api/schemas/DevAtomMetadata.ts","../src/api/schemas/DevBucketMetadata.ts","../src/api/schemas/DevCacheMetadata.ts","../src/api/schemas/DevCommandMetadata.ts","../src/api/schemas/DevEntityMetadata.ts","../src/api/schemas/DevEnvMetadata.ts","../src/api/schemas/DevModuleMetadata.ts","../src/api/schemas/DevPageMetadata.ts","../src/api/schemas/DevProviderMetadata.ts","../src/api/schemas/DevQueueMetadata.ts","../src/api/schemas/DevRealmMetadata.ts","../src/api/schemas/DevRouteMetadata.ts","../src/api/schemas/DevSchedulerMetadata.ts","../src/api/schemas/DevTopicMetadata.ts","../src/api/schemas/DevMetadata.ts","../src/api/DevToolsProvider.ts","../src/index.ts"],"sourcesContent":["import { type Static, t } from \"alepha\";\nimport { $entity, pg } from \"alepha/orm\";\n\nexport const logs = $entity({\n name: \"logs\",\n schema: t.object({\n id: pg.primaryKey(),\n level: t.enum([\"TRACE\", \"DEBUG\", \"INFO\", \"WARN\", \"ERROR\"]),\n message: t.text({\n size: \"rich\",\n }),\n service: t.text(),\n module: t.text(),\n context: t.optional(t.text()),\n app: t.optional(t.text()),\n data: t.optional(t.json()),\n timestamp: t.integer(),\n }),\n});\n\nexport type DevLogEntry = Static<typeof logs.schema>;\n","import { $inject, Alepha, type TObject, type TSchema, t } from \"alepha\";\nimport { $bucket } from \"alepha/bucket\";\nimport { $cache } from \"alepha/cache\";\nimport { $command } from \"alepha/command\";\nimport { $logger } from \"alepha/logger\";\nimport {\n PG_CREATED_AT,\n PG_DEFAULT,\n PG_DELETED_AT,\n PG_IDENTITY,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_SERIAL,\n PG_UPDATED_AT,\n PG_VERSION,\n RepositoryProvider,\n} from \"alepha/orm\";\nimport { $queue } from \"alepha/queue\";\nimport { $scheduler } from \"alepha/scheduler\";\nimport { $realm } from \"alepha/security\";\nimport { $action } from \"alepha/server\";\nimport { $topic } from \"alepha/topic\";\nimport type { DevActionMetadata } from \"../schemas/DevActionMetadata.ts\";\nimport type { DevAtomMetadata } from \"../schemas/DevAtomMetadata.ts\";\nimport type { DevBucketMetadata } from \"../schemas/DevBucketMetadata.ts\";\nimport type { DevCacheMetadata } from \"../schemas/DevCacheMetadata.ts\";\nimport type { DevCommandMetadata } from \"../schemas/DevCommandMetadata.ts\";\nimport type {\n DevEntityColumn,\n DevEntityConstraint,\n DevEntityForeignKey,\n DevEntityIndex,\n DevEntityMetadata,\n} from \"../schemas/DevEntityMetadata.ts\";\nimport type { DevEnvMetadata } from \"../schemas/DevEnvMetadata.ts\";\nimport type { DevMetadata } from \"../schemas/DevMetadata.ts\";\nimport type { DevModuleMetadata } from \"../schemas/DevModuleMetadata.ts\";\nimport type { DevPageMetadata } from \"../schemas/DevPageMetadata.ts\";\nimport type { DevProviderMetadata } from \"../schemas/DevProviderMetadata.ts\";\nimport type { DevQueueMetadata } from \"../schemas/DevQueueMetadata.ts\";\nimport type { DevRealmMetadata } from \"../schemas/DevRealmMetadata.ts\";\nimport type { DevRouteMetadata } from \"../schemas/DevRouteMetadata.ts\";\nimport type { DevSchedulerMetadata } from \"../schemas/DevSchedulerMetadata.ts\";\nimport type { DevTopicMetadata } from \"../schemas/DevTopicMetadata.ts\";\n\nexport class DevToolsMetadataProvider {\n protected readonly alepha = $inject(Alepha);\n protected readonly log = $logger();\n\n public getActions(): DevActionMetadata[] {\n const actionPrimitives = this.alepha.primitives($action);\n\n return actionPrimitives.map((action) => {\n const schema = action.schema;\n const options = action.options as any; // Allow accessing augmented properties\n\n return {\n name: action.name,\n group: action.group,\n method: action.method,\n path: action.path,\n prefix: action.prefix,\n fullPath: action.route.path,\n description: action.options.description,\n summary: options.summary,\n disabled: action.options.disabled,\n secure: options.secure,\n hide: options.hide,\n body: schema?.body,\n params: schema?.params,\n query: schema?.query,\n response: schema?.response,\n bodyContentType: action.getBodyContentType(),\n };\n });\n }\n\n public getQueues(): DevQueueMetadata[] {\n const queuePrimitives = this.alepha.primitives($queue);\n\n return queuePrimitives.map((queue) => ({\n name: queue.name,\n description: queue.options.description,\n schema: queue.options.schema,\n provider: this.getProviderName(queue.options.provider),\n }));\n }\n\n public getSchedulers(): DevSchedulerMetadata[] {\n const schedulerPrimitives = this.alepha.primitives($scheduler);\n\n return schedulerPrimitives.map((scheduler) => ({\n name: scheduler.name,\n description: scheduler.options.description,\n cron: scheduler.options.cron,\n interval: scheduler.options.interval,\n lock: scheduler.options.lock,\n }));\n }\n\n public getTopics(): DevTopicMetadata[] {\n const topicPrimitives = this.alepha.primitives($topic);\n\n return topicPrimitives.map((topic) => ({\n name: topic.name,\n description: topic.options.description,\n schema: topic.options.schema,\n provider: this.getProviderName(topic.options.provider),\n }));\n }\n\n public getBuckets(): DevBucketMetadata[] {\n const bucketPrimitives = this.alepha.primitives($bucket);\n\n return bucketPrimitives.map((bucket) => ({\n name: bucket.name,\n description: bucket.options.description,\n mimeTypes: bucket.options.mimeTypes,\n maxSize: bucket.options.maxSize,\n provider: this.getProviderName(bucket.options.provider),\n }));\n }\n\n public getRealms(): DevRealmMetadata[] {\n const realmPrimitives = this.alepha.primitives($realm);\n\n return realmPrimitives.map((realm) => ({\n name: realm.name,\n description: realm.options.description,\n roles: realm.options.roles,\n type: \"secret\" in realm.options ? \"internal\" : \"external\",\n settings: {\n accessTokenExpiration: realm.options.settings?.accessToken?.expiration,\n refreshTokenExpiration:\n realm.options.settings?.refreshToken?.expiration,\n hasOnCreateSession: !!realm.options.settings?.onCreateSession,\n hasOnRefreshSession: !!realm.options.settings?.onRefreshSession,\n hasOnDeleteSession: !!realm.options.settings?.onDeleteSession,\n },\n }));\n }\n\n public getCaches(): DevCacheMetadata[] {\n const cachePrimitives = this.alepha.primitives($cache);\n\n return cachePrimitives.map((cache) => ({\n name: cache.container,\n ttl: cache.options.ttl,\n disabled: cache.options.disabled,\n provider: this.getProviderName(cache.options.provider),\n }));\n }\n\n public getPages(): DevPageMetadata[] {\n // const pagePrimitives = this.alepha.primitives($page);\n //\n // return pagePrimitives.map((page) => ({\n // name: page.name,\n // description: page.options.description,\n // path: page.options.path,\n // params: page.options.schema?.params,\n // query: page.options.schema?.query,\n // hasComponent: !!page.options.component,\n // hasLazy: !!page.options.lazy,\n // hasResolve: !!page.options.resolve,\n // hasChildren: !!page.options.children,\n // hasParent: !!page.options.parent,\n // hasErrorHandler: !!page.options.errorHandler,\n // static:\n // typeof page.options.static === \"boolean\"\n // ? page.options.static\n // : !!page.options.static,\n // cache: page.options.cache,\n // client: page.options.client,\n // animation: page.options.animation,\n // }));\n\n return [];\n }\n\n public getProviders(): DevProviderMetadata[] {\n const graph = this.alepha.graph();\n\n return Object.entries(graph).map(([name, info]) => ({\n name,\n module: info.module ?? name,\n dependencies: info.from,\n aliases: info.as,\n }));\n }\n\n public getModules(): DevModuleMetadata[] {\n const graph = this.alepha.graph();\n const moduleMap = new Map<string, Set<string>>();\n\n // Group providers by module\n for (const [providerName, info] of Object.entries(graph)) {\n if (info.module) {\n if (!moduleMap.has(info.module)) {\n moduleMap.set(info.module, new Set());\n }\n moduleMap.get(info.module)!.add(providerName);\n }\n }\n\n return Array.from(moduleMap.entries()).map(([name, providers]) => ({\n name,\n providers: Array.from(providers),\n }));\n }\n\n public getEntities(): DevEntityMetadata[] {\n try {\n const repositoryProvider = this.alepha.inject(RepositoryProvider);\n const repositories = repositoryProvider.getRepositories();\n\n return repositories.map((repo) => {\n const entity = repo.entity;\n const schema = entity.schema as TObject;\n const options = entity.options;\n\n // Extract columns from schema\n const columns: DevEntityColumn[] = Object.entries(\n schema.properties,\n ).map(([name, field]) => {\n const fieldSchema = field as TSchema & Record<symbol, any>;\n const refData = fieldSchema[PG_REF];\n\n return {\n name,\n type: this.getColumnType(fieldSchema),\n nullable: this.isNullable(fieldSchema),\n primaryKey: PG_PRIMARY_KEY in fieldSchema,\n identity: PG_IDENTITY in fieldSchema || PG_SERIAL in fieldSchema,\n createdAt: PG_CREATED_AT in fieldSchema,\n updatedAt: PG_UPDATED_AT in fieldSchema,\n deletedAt: PG_DELETED_AT in fieldSchema,\n version: PG_VERSION in fieldSchema,\n hasDefault: PG_DEFAULT in fieldSchema,\n ref: refData\n ? {\n entity: refData.ref?.()?.entity?.name ?? \"unknown\",\n column: refData.ref?.()?.name ?? \"unknown\",\n onUpdate: refData.actions?.onUpdate,\n onDelete: refData.actions?.onDelete,\n }\n : undefined,\n };\n });\n\n // Extract indexes\n const indexes: DevEntityIndex[] = (options.indexes ?? []).map(\n (idx: any) => {\n if (typeof idx === \"string\") {\n return { columns: [idx], unique: false };\n }\n return {\n name: idx.name,\n columns: idx.column ? [idx.column] : (idx.columns ?? []),\n unique: idx.unique ?? false,\n };\n },\n );\n\n // Extract foreign keys\n const foreignKeys: DevEntityForeignKey[] = (\n options.foreignKeys ?? []\n ).map((fk: any) => ({\n name: fk.name,\n columns: fk.columns.map(String),\n foreignEntity: fk.foreignColumns?.[0]?.()?.entity?.name ?? \"unknown\",\n foreignColumns: fk.foreignColumns?.map(\n (fc: any) => fc?.()?.name ?? \"unknown\",\n ),\n }));\n\n // Extract constraints\n const constraints: DevEntityConstraint[] = (\n options.constraints ?? []\n ).map((c: any) => ({\n name: c.name,\n columns: c.columns.map(String),\n unique: !!c.unique,\n hasCheck: !!c.check,\n }));\n\n return {\n name: entity.name,\n provider: repo.provider.constructor.name,\n columns,\n indexes,\n foreignKeys,\n constraints,\n };\n });\n } catch {\n // RepositoryProvider not available (ORM not used)\n return [];\n }\n }\n\n protected getColumnType(field: TSchema): string {\n // Handle optional/nullable wrappers (unions with null)\n if (t.schema.isUnion(field) && (field as any).anyOf) {\n const types = (field as any).anyOf as TSchema[];\n const nonNull = types.find((type) => !t.schema.isNull(type));\n if (nonNull) {\n return this.getColumnType(nonNull);\n }\n }\n\n const f = field as any;\n\n // Check for enum (t.enum wraps in Unsafe with type=string and enum array)\n if (\n t.schema.isUnsafe(field) &&\n f.type === \"string\" &&\n Array.isArray(f.enum)\n ) {\n return \"enum\";\n }\n\n // Use TypeBox's type guards\n if (t.schema.isString(field)) {\n if (f.enum) return \"enum\";\n if (f.format === \"uuid\") return \"uuid\";\n if (f.format === \"date-time\") return \"datetime\";\n if (f.format === \"date\") return \"date\";\n if (f.format === \"bigint\") return \"bigint\";\n return \"text\";\n }\n if (t.schema.isInteger(field)) return \"integer\";\n if (t.schema.isNumber(field)) return \"number\";\n if (t.schema.isBoolean(field)) return \"boolean\";\n if (t.schema.isArray(field)) return \"array\";\n if (t.schema.isObject(field)) return \"json\";\n if (t.schema.isLiteral(field)) return \"literal\";\n\n return \"unknown\";\n }\n\n protected isNullable(field: TSchema): boolean {\n if (t.schema.isUnion(field) && (field as any).anyOf) {\n const types = (field as any).anyOf as TSchema[];\n return types.some((type) => t.schema.isNull(type));\n }\n return false;\n }\n\n public getCommands(): DevCommandMetadata[] {\n const commandPrimitives = this.alepha.primitives($command);\n\n return commandPrimitives\n .filter((cmd) => !cmd.options.hide)\n .map((command) => ({\n name: command.name,\n description: command.options.description,\n hidden: command.options.hide,\n }));\n }\n\n public getRoutes(): DevRouteMetadata[] {\n // Routes are the base primitive - actions and pages are routes\n // Showing them separately would be redundant with actions\n return [];\n }\n\n public getEnvs(): DevEnvMetadata[] {\n const envSchemas = this.alepha.getEnvSchemas();\n\n return envSchemas.map((item, index) => ({\n propertyKey: `env_${index}`,\n schema: item.schema,\n values: item.values,\n serviceName: undefined,\n }));\n }\n\n public getAtoms(): DevAtomMetadata[] {\n const atomsWithValues = this.alepha.store.getAtoms(false);\n\n return atomsWithValues.map(({ atom, value }) => ({\n name: atom.key,\n description: atom.options.description,\n schema: atom.schema,\n defaultValue: atom.options.default,\n currentValue: value,\n }));\n }\n\n public getMetadata(): DevMetadata {\n return {\n actions: this.getActions(),\n queues: this.getQueues(),\n schedulers: this.getSchedulers(),\n topics: this.getTopics(),\n buckets: this.getBuckets(),\n realms: this.getRealms(),\n caches: this.getCaches(),\n pages: this.getPages(),\n providers: this.getProviders(),\n modules: this.getModules(),\n entities: this.getEntities(),\n commands: this.getCommands(),\n routes: this.getRoutes(),\n envs: this.getEnvs(),\n atoms: this.getAtoms(),\n };\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n protected getProviderName(provider?: \"memory\" | any): string {\n if (!provider) {\n return \"default\";\n }\n if (provider === \"memory\") {\n return \"memory\";\n }\n return provider.name || \"custom\";\n }\n}\n","import { NodeSqliteProvider } from \"alepha/orm\";\n\nexport class DevToolsDatabaseProvider extends NodeSqliteProvider {\n public get name() {\n return \"devtools\";\n }\n\n protected readonly options = {\n path: \":memory:\",\n };\n}\n","import { Repository } from \"alepha/orm\";\nimport { logs } from \"../entities/logs.ts\";\nimport { DevToolsDatabaseProvider } from \"../providers/DevToolsDatabaseProvider.ts\";\n\nexport class LogRepository extends Repository<typeof logs.schema> {\n constructor() {\n super(logs, DevToolsDatabaseProvider);\n }\n}\n","import { type Static, t } from \"alepha\";\n\nexport const devActionMetadataSchema = t.object({\n name: t.text(),\n group: t.text(),\n method: t.text(),\n path: t.text(),\n prefix: t.text(),\n fullPath: t.text(),\n description: t.optional(t.text()),\n summary: t.optional(t.text()),\n disabled: t.optional(t.boolean()),\n secure: t.optional(t.boolean()),\n hide: t.optional(t.boolean()),\n body: t.optional(t.any()),\n params: t.optional(t.any()),\n query: t.optional(t.any()),\n response: t.optional(t.any()),\n bodyContentType: t.optional(t.text()),\n});\n\nexport type DevActionMetadata = Static<typeof devActionMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devAtomMetadataSchema = t.object({\n /**\n * The unique name/key of the atom\n */\n name: t.text(),\n /**\n * Optional description of the atom\n */\n description: t.optional(t.text()),\n /**\n * The schema for the atom value (TypeBox/JSON Schema)\n */\n schema: t.any(),\n /**\n * The default value defined for the atom\n */\n defaultValue: t.optional(t.any()),\n /**\n * The current value of the atom\n */\n currentValue: t.optional(t.any()),\n});\n\nexport type DevAtomMetadata = Static<typeof devAtomMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devBucketMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n mimeTypes: t.optional(t.array(t.text())),\n maxSize: t.optional(t.number()),\n provider: t.text(),\n});\n\nexport type DevBucketMetadata = Static<typeof devBucketMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devCacheMetadataSchema = t.object({\n name: t.text(),\n ttl: t.optional(t.any()),\n disabled: t.optional(t.boolean()),\n provider: t.text(),\n});\n\nexport type DevCacheMetadata = Static<typeof devCacheMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devCommandMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n hidden: t.optional(t.boolean()),\n});\n\nexport type DevCommandMetadata = Static<typeof devCommandMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devEntityColumnSchema = t.object({\n name: t.text(),\n type: t.text(),\n nullable: t.boolean(),\n primaryKey: t.boolean(),\n identity: t.boolean(),\n createdAt: t.boolean(),\n updatedAt: t.boolean(),\n deletedAt: t.boolean(),\n version: t.boolean(),\n hasDefault: t.boolean(),\n ref: t.optional(\n t.object({\n entity: t.text(),\n column: t.text(),\n onUpdate: t.optional(t.text()),\n onDelete: t.optional(t.text()),\n }),\n ),\n});\n\nexport const devEntityIndexSchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n unique: t.boolean(),\n});\n\nexport const devEntityForeignKeySchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n foreignEntity: t.text(),\n foreignColumns: t.array(t.text()),\n});\n\nexport const devEntityConstraintSchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n unique: t.boolean(),\n hasCheck: t.boolean(),\n});\n\nexport const devEntityMetadataSchema = t.object({\n name: t.text(),\n provider: t.text(),\n columns: t.array(devEntityColumnSchema),\n indexes: t.array(devEntityIndexSchema),\n foreignKeys: t.array(devEntityForeignKeySchema),\n constraints: t.array(devEntityConstraintSchema),\n});\n\nexport type DevEntityColumn = Static<typeof devEntityColumnSchema>;\nexport type DevEntityIndex = Static<typeof devEntityIndexSchema>;\nexport type DevEntityForeignKey = Static<typeof devEntityForeignKeySchema>;\nexport type DevEntityConstraint = Static<typeof devEntityConstraintSchema>;\nexport type DevEntityMetadata = Static<typeof devEntityMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devEnvMetadataSchema = t.object({\n /**\n * The property name in the service where $env is defined\n */\n propertyKey: t.text(),\n /**\n * The schema for the environment variables (TypeBox/JSON Schema)\n */\n schema: t.any(),\n /**\n * The parsed values from the environment\n */\n values: t.record(t.text(), t.any()),\n /**\n * The service class name where this $env is defined\n */\n serviceName: t.optional(t.text()),\n});\n\nexport type DevEnvMetadata = Static<typeof devEnvMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devModuleMetadataSchema = t.object({\n name: t.text(),\n providers: t.array(t.text()),\n});\n\nexport type DevModuleMetadata = Static<typeof devModuleMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devPageMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n path: t.optional(t.text()),\n params: t.optional(t.any()),\n query: t.optional(t.any()),\n hasComponent: t.boolean(),\n hasLazy: t.boolean(),\n hasResolve: t.boolean(),\n hasChildren: t.boolean(),\n hasParent: t.boolean(),\n hasErrorHandler: t.boolean(),\n static: t.optional(t.boolean()),\n cache: t.optional(t.any()),\n client: t.optional(t.any()),\n animation: t.optional(t.any()),\n});\n\nexport type DevPageMetadata = Static<typeof devPageMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devProviderMetadataSchema = t.object({\n name: t.text(),\n module: t.optional(t.text()),\n dependencies: t.array(t.text()),\n aliases: t.optional(t.array(t.text())),\n});\n\nexport type DevProviderMetadata = Static<typeof devProviderMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devQueueMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n schema: t.optional(t.any()),\n provider: t.text(),\n});\n\nexport type DevQueueMetadata = Static<typeof devQueueMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devRealmMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n roles: t.optional(t.array(t.any())),\n type: t.enum([\"internal\", \"external\"]),\n settings: t.optional(\n t.object({\n accessTokenExpiration: t.optional(t.any()),\n refreshTokenExpiration: t.optional(t.any()),\n hasOnCreateSession: t.boolean(),\n hasOnRefreshSession: t.boolean(),\n hasOnDeleteSession: t.boolean(),\n }),\n ),\n});\n\nexport type DevRealmMetadata = Static<typeof devRealmMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devRouteMetadataSchema = t.object({\n method: t.text(),\n path: t.text(),\n});\n\nexport type DevRouteMetadata = Static<typeof devRouteMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devSchedulerMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n cron: t.optional(t.text()),\n interval: t.optional(t.any()),\n lock: t.optional(t.boolean()),\n});\n\nexport type DevSchedulerMetadata = Static<typeof devSchedulerMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devTopicMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n schema: t.optional(t.any()),\n provider: t.text(),\n});\n\nexport type DevTopicMetadata = Static<typeof devTopicMetadataSchema>;\n","import { type Static, t } from \"alepha\";\nimport { devActionMetadataSchema } from \"./DevActionMetadata.ts\";\nimport { devAtomMetadataSchema } from \"./DevAtomMetadata.ts\";\nimport { devBucketMetadataSchema } from \"./DevBucketMetadata.ts\";\nimport { devCacheMetadataSchema } from \"./DevCacheMetadata.ts\";\nimport { devCommandMetadataSchema } from \"./DevCommandMetadata.ts\";\nimport { devEntityMetadataSchema } from \"./DevEntityMetadata.ts\";\nimport { devEnvMetadataSchema } from \"./DevEnvMetadata.ts\";\nimport { devModuleMetadataSchema } from \"./DevModuleMetadata.ts\";\nimport { devPageMetadataSchema } from \"./DevPageMetadata.ts\";\nimport { devProviderMetadataSchema } from \"./DevProviderMetadata.ts\";\nimport { devQueueMetadataSchema } from \"./DevQueueMetadata.ts\";\nimport { devRealmMetadataSchema } from \"./DevRealmMetadata.ts\";\nimport { devRouteMetadataSchema } from \"./DevRouteMetadata.ts\";\nimport { devSchedulerMetadataSchema } from \"./DevSchedulerMetadata.ts\";\nimport { devTopicMetadataSchema } from \"./DevTopicMetadata.ts\";\n\nexport const devMetadataSchema = t.object({\n actions: t.array(devActionMetadataSchema),\n queues: t.array(devQueueMetadataSchema),\n schedulers: t.array(devSchedulerMetadataSchema),\n topics: t.array(devTopicMetadataSchema),\n buckets: t.array(devBucketMetadataSchema),\n realms: t.array(devRealmMetadataSchema),\n caches: t.array(devCacheMetadataSchema),\n pages: t.array(devPageMetadataSchema),\n providers: t.array(devProviderMetadataSchema),\n modules: t.array(devModuleMetadataSchema),\n entities: t.array(devEntityMetadataSchema),\n commands: t.array(devCommandMetadataSchema),\n routes: t.array(devRouteMetadataSchema),\n envs: t.array(devEnvMetadataSchema),\n atoms: t.array(devAtomMetadataSchema),\n});\n\nexport type DevMetadata = Static<typeof devMetadataSchema>;\n","import { join } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { $hook, $inject, Alepha, pageQuerySchema, t } from \"alepha\";\nimport { $batch } from \"alepha/batch\";\nimport { $logger, JsonFormatterProvider, type LogEntry } from \"alepha/logger\";\nimport { parseQueryString } from \"alepha/orm\";\nimport { $route, ServerProvider } from \"alepha/server\";\nimport { $serve } from \"alepha/server/static\";\nimport { type DevLogEntry, logs } from \"./entities/logs.ts\";\nimport { DevToolsMetadataProvider } from \"./providers/DevToolsMetadataProvider.ts\";\nimport { LogRepository } from \"./repositories/LogRepository.ts\";\nimport { devMetadataSchema } from \"./schemas/DevMetadata.ts\";\n\nexport class DevToolsProvider {\n protected readonly log = $logger();\n protected readonly alepha = $inject(Alepha);\n protected readonly serverProvider = $inject(ServerProvider);\n protected readonly jsonFormatter = $inject(JsonFormatterProvider);\n protected readonly logs = $inject(LogRepository);\n protected readonly devCollectorProvider = $inject(DevToolsMetadataProvider);\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: () => {\n this.log.info(\n `Devtools available at ${this.serverProvider.hostname}/devtools/`,\n );\n },\n });\n\n protected batchLogs = $batch({\n maxSize: 50,\n maxDuration: [10, \"seconds\"],\n schema: logs.insertSchema,\n handler: async (entries) => {\n await this.logs.createMany(entries);\n },\n });\n\n protected readonly onLog = $hook({\n on: \"log\",\n handler: async (ev: { message?: string; entry: LogEntry }) => {\n // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n // CAUTION: It's very easy to create an infinite loop here.\n // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n\n try {\n if (!this.alepha.isStarted()) {\n return;\n }\n\n ev.entry.message = ev.entry.message?.slice(0, 2000); // limit message size\n\n if (ev.entry.module === \"alepha.devtools\") {\n // skip devtools logs to avoid infinite loop\n return;\n }\n\n if (ev.entry.level === \"TRACE\" && ev.entry.module === \"alepha.batch\") {\n // skip batch trace logs to avoid infinite loop\n return;\n }\n\n if (this.alepha.isProduction() && ev.entry.level === \"TRACE\") {\n // skip trace logs in production\n return;\n }\n\n const entry = {\n ...ev.entry,\n data:\n ev.entry.data instanceof Error\n ? this.jsonFormatter.formatJsonError(ev.entry.data)\n : typeof ev.entry.data === \"object\" &&\n !Array.isArray(ev.entry.data)\n ? ev.entry.data\n : { data: ev.entry.data },\n };\n\n await this.batchLogs.push(entry as DevLogEntry);\n } catch (error) {\n // DO TO NOT WITH THE LOGGER HERE TO AVOID INFINITE LOOP\n console.error(error, ev);\n }\n },\n });\n\n protected readonly uiRoute = $serve({\n path: \"/devtools\",\n root: join(fileURLToPath(import.meta.url), \"../../../assets/devtools\"),\n historyApiFallback: true,\n });\n\n protected readonly metadataRoute = $route({\n method: \"GET\",\n path: \"/devtools/api/metadata\",\n silent: true,\n schema: {\n response: devMetadataSchema,\n },\n handler: () => {\n return this.devCollectorProvider.getMetadata();\n },\n });\n\n protected readonly logsRoute = $route({\n method: \"GET\",\n path: \"/devtools/api/logs\",\n silent: true,\n schema: {\n query: t.extend(pageQuerySchema, {\n search: t.optional(t.string()),\n }),\n response: t.page(logs.schema),\n },\n handler: ({ query }) => {\n query.sort ??= \"-timestamp\";\n return this.logs.paginate(\n query,\n query.search\n ? {\n where: parseQueryString(query.search),\n }\n : {},\n {\n count: true,\n },\n );\n },\n });\n\n protected readonly updateAtomRoute = $route({\n method: \"POST\",\n path: \"/devtools/api/atoms\",\n silent: true,\n schema: {\n body: t.object({\n name: t.text(),\n value: t.any(),\n }),\n response: t.object({\n success: t.boolean(),\n }),\n },\n handler: ({ body }) => {\n const atoms = this.alepha.store.getAtoms(false);\n const atomEntry = atoms.find((a) => a.atom.key === body.name);\n\n if (atomEntry) {\n this.alepha.store.set(atomEntry.atom, body.value);\n return { success: true };\n }\n\n return { success: false };\n },\n });\n}\n","import { $module } from \"alepha\";\nimport { DevToolsProvider } from \"./api/DevToolsProvider.ts\";\nimport { DevToolsDatabaseProvider } from \"./api/providers/DevToolsDatabaseProvider.ts\";\nimport { DevToolsMetadataProvider } from \"./api/providers/DevToolsMetadataProvider.ts\";\nimport { LogRepository } from \"./api/repositories/LogRepository.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./api/providers/DevToolsMetadataProvider.ts\";\nexport * from \"./api/schemas/DevActionMetadata.ts\";\nexport * from \"./api/schemas/DevBucketMetadata.ts\";\nexport * from \"./api/schemas/DevCacheMetadata.ts\";\nexport * from \"./api/schemas/DevCommandMetadata.ts\";\nexport * from \"./api/schemas/DevEntityMetadata.ts\";\nexport * from \"./api/schemas/DevMetadata.ts\";\nexport * from \"./api/schemas/DevModuleMetadata.ts\";\nexport * from \"./api/schemas/DevPageMetadata.ts\";\nexport * from \"./api/schemas/DevProviderMetadata.ts\";\nexport * from \"./api/schemas/DevQueueMetadata.ts\";\nexport * from \"./api/schemas/DevRealmMetadata.ts\";\nexport * from \"./api/schemas/DevRouteMetadata.ts\";\nexport * from \"./api/schemas/DevSchedulerMetadata.ts\";\nexport * from \"./api/schemas/DevTopicMetadata.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Developer tools module for monitoring and debugging Alepha applications.\n *\n * This module provides comprehensive data collection capabilities for tracking application behavior,\n * performance metrics, and debugging information in real-time.\n *\n * @see {@link DevToolsMetadataProvider}\n * @module alepha.devtools\n */\nexport const AlephaDevtools = $module({\n name: \"alepha.devtools\",\n primitives: [],\n services: [\n DevToolsMetadataProvider,\n DevToolsProvider,\n DevToolsDatabaseProvider,\n LogRepository,\n ],\n register: (alepha) => {\n if (!alepha.isViteDev()) {\n return;\n }\n\n alepha.with(DevToolsProvider);\n alepha.with(DevToolsDatabaseProvider);\n alepha.with(DevToolsMetadataProvider);\n alepha.store.push(\"alepha.build.assets\", \"@alepha/devtools\");\n },\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":[],"sources":["../src/api/entities/logs.ts","../src/api/providers/DevToolsMetadataProvider.ts","../src/api/providers/DevToolsDatabaseProvider.ts","../src/api/repositories/LogRepository.ts","../src/api/schemas/DevActionMetadata.ts","../src/api/schemas/DevAtomMetadata.ts","../src/api/schemas/DevBucketMetadata.ts","../src/api/schemas/DevCacheMetadata.ts","../src/api/schemas/DevCommandMetadata.ts","../src/api/schemas/DevEntityMetadata.ts","../src/api/schemas/DevEnvMetadata.ts","../src/api/schemas/DevModuleMetadata.ts","../src/api/schemas/DevPageMetadata.ts","../src/api/schemas/DevProviderMetadata.ts","../src/api/schemas/DevQueueMetadata.ts","../src/api/schemas/DevRealmMetadata.ts","../src/api/schemas/DevRouteMetadata.ts","../src/api/schemas/DevSchedulerMetadata.ts","../src/api/schemas/DevTopicMetadata.ts","../src/api/schemas/DevMetadata.ts","../src/api/DevToolsProvider.ts","../src/index.ts"],"sourcesContent":["import { type Static, t } from \"alepha\";\nimport { $entity, pg } from \"alepha/orm\";\n\nexport const logs = $entity({\n name: \"logs\",\n schema: t.object({\n id: pg.primaryKey(),\n level: t.enum([\"TRACE\", \"DEBUG\", \"INFO\", \"WARN\", \"ERROR\"]),\n message: t.text({\n size: \"rich\",\n }),\n service: t.text(),\n module: t.text(),\n context: t.optional(t.text()),\n app: t.optional(t.text()),\n data: t.optional(t.json()),\n timestamp: t.integer(),\n }),\n});\n\nexport type DevLogEntry = Static<typeof logs.schema>;\n","import { $inject, Alepha, type TObject, type TSchema, t } from \"alepha\";\nimport { $bucket } from \"alepha/bucket\";\nimport { $cache } from \"alepha/cache\";\nimport { $command } from \"alepha/command\";\nimport { $logger } from \"alepha/logger\";\nimport {\n PG_CREATED_AT,\n PG_DEFAULT,\n PG_DELETED_AT,\n PG_IDENTITY,\n PG_PRIMARY_KEY,\n PG_REF,\n PG_SERIAL,\n PG_UPDATED_AT,\n PG_VERSION,\n RepositoryProvider,\n} from \"alepha/orm\";\nimport { $queue } from \"alepha/queue\";\nimport { $scheduler } from \"alepha/scheduler\";\nimport { $realm } from \"alepha/security\";\nimport { $action } from \"alepha/server\";\nimport { $topic } from \"alepha/topic\";\nimport type { DevActionMetadata } from \"../schemas/DevActionMetadata.ts\";\nimport type { DevAtomMetadata } from \"../schemas/DevAtomMetadata.ts\";\nimport type { DevBucketMetadata } from \"../schemas/DevBucketMetadata.ts\";\nimport type { DevCacheMetadata } from \"../schemas/DevCacheMetadata.ts\";\nimport type { DevCommandMetadata } from \"../schemas/DevCommandMetadata.ts\";\nimport type {\n DevEntityColumn,\n DevEntityConstraint,\n DevEntityForeignKey,\n DevEntityIndex,\n DevEntityMetadata,\n} from \"../schemas/DevEntityMetadata.ts\";\nimport type { DevEnvMetadata } from \"../schemas/DevEnvMetadata.ts\";\nimport type { DevMetadata } from \"../schemas/DevMetadata.ts\";\nimport type { DevModuleMetadata } from \"../schemas/DevModuleMetadata.ts\";\nimport type { DevPageMetadata } from \"../schemas/DevPageMetadata.ts\";\nimport type { DevProviderMetadata } from \"../schemas/DevProviderMetadata.ts\";\nimport type { DevQueueMetadata } from \"../schemas/DevQueueMetadata.ts\";\nimport type { DevRealmMetadata } from \"../schemas/DevRealmMetadata.ts\";\nimport type { DevRouteMetadata } from \"../schemas/DevRouteMetadata.ts\";\nimport type { DevSchedulerMetadata } from \"../schemas/DevSchedulerMetadata.ts\";\nimport type { DevTopicMetadata } from \"../schemas/DevTopicMetadata.ts\";\n\nexport class DevToolsMetadataProvider {\n protected readonly alepha = $inject(Alepha);\n protected readonly log = $logger();\n\n public getActions(): DevActionMetadata[] {\n const actionPrimitives = this.alepha.primitives($action);\n\n return actionPrimitives.map((action) => {\n const schema = action.schema;\n const options = action.options as any; // Allow accessing augmented properties\n\n return {\n name: action.name,\n group: action.group,\n method: action.method,\n path: action.path,\n prefix: action.prefix,\n fullPath: action.route.path,\n description: action.options.description,\n summary: options.summary,\n disabled: action.options.disabled,\n secure: options.secure,\n hide: options.hide,\n body: schema?.body,\n params: schema?.params,\n query: schema?.query,\n response: schema?.response,\n bodyContentType: action.getBodyContentType(),\n };\n });\n }\n\n public getQueues(): DevQueueMetadata[] {\n const queuePrimitives = this.alepha.primitives($queue);\n\n return queuePrimitives.map((queue) => ({\n name: queue.name,\n description: queue.options.description,\n schema: queue.options.schema,\n provider: this.getProviderName(queue.options.provider),\n }));\n }\n\n public getSchedulers(): DevSchedulerMetadata[] {\n const schedulerPrimitives = this.alepha.primitives($scheduler);\n\n return schedulerPrimitives.map((scheduler) => ({\n name: scheduler.name,\n description: scheduler.options.description,\n cron: scheduler.options.cron,\n interval: scheduler.options.interval,\n lock: scheduler.options.lock,\n }));\n }\n\n public getTopics(): DevTopicMetadata[] {\n const topicPrimitives = this.alepha.primitives($topic);\n\n return topicPrimitives.map((topic) => ({\n name: topic.name,\n description: topic.options.description,\n schema: topic.options.schema,\n provider: this.getProviderName(topic.options.provider),\n }));\n }\n\n public getBuckets(): DevBucketMetadata[] {\n const bucketPrimitives = this.alepha.primitives($bucket);\n\n return bucketPrimitives.map((bucket) => ({\n name: bucket.name,\n description: bucket.options.description,\n mimeTypes: bucket.options.mimeTypes,\n maxSize: bucket.options.maxSize,\n provider: this.getProviderName(bucket.options.provider),\n }));\n }\n\n public getRealms(): DevRealmMetadata[] {\n const realmPrimitives = this.alepha.primitives($realm);\n\n return realmPrimitives.map((realm) => ({\n name: realm.name,\n description: realm.options.description,\n roles: realm.options.roles,\n type: \"secret\" in realm.options ? \"internal\" : \"external\",\n settings: {\n accessTokenExpiration: realm.options.settings?.accessToken?.expiration,\n refreshTokenExpiration:\n realm.options.settings?.refreshToken?.expiration,\n hasOnCreateSession: !!realm.options.settings?.onCreateSession,\n hasOnRefreshSession: !!realm.options.settings?.onRefreshSession,\n hasOnDeleteSession: !!realm.options.settings?.onDeleteSession,\n },\n }));\n }\n\n public getCaches(): DevCacheMetadata[] {\n const cachePrimitives = this.alepha.primitives($cache);\n\n return cachePrimitives.map((cache) => ({\n name: cache.container,\n ttl: cache.options.ttl,\n disabled: cache.options.disabled,\n provider: this.getProviderName(cache.options.provider),\n }));\n }\n\n public getPages(): DevPageMetadata[] {\n // const pagePrimitives = this.alepha.primitives($page);\n //\n // return pagePrimitives.map((page) => ({\n // name: page.name,\n // description: page.options.description,\n // path: page.options.path,\n // params: page.options.schema?.params,\n // query: page.options.schema?.query,\n // hasComponent: !!page.options.component,\n // hasLazy: !!page.options.lazy,\n // hasResolve: !!page.options.resolve,\n // hasChildren: !!page.options.children,\n // hasParent: !!page.options.parent,\n // hasErrorHandler: !!page.options.errorHandler,\n // static:\n // typeof page.options.static === \"boolean\"\n // ? page.options.static\n // : !!page.options.static,\n // cache: page.options.cache,\n // client: page.options.client,\n // animation: page.options.animation,\n // }));\n\n return [];\n }\n\n public getProviders(): DevProviderMetadata[] {\n const graph = this.alepha.graph();\n\n return Object.entries(graph).map(([name, info]) => ({\n name,\n module: info.module ?? name,\n dependencies: info.from,\n aliases: info.as,\n }));\n }\n\n public getModules(): DevModuleMetadata[] {\n const graph = this.alepha.graph();\n const moduleMap = new Map<string, Set<string>>();\n\n // Group providers by module\n for (const [providerName, info] of Object.entries(graph)) {\n if (info.module) {\n if (!moduleMap.has(info.module)) {\n moduleMap.set(info.module, new Set());\n }\n moduleMap.get(info.module)!.add(providerName);\n }\n }\n\n return Array.from(moduleMap.entries()).map(([name, providers]) => ({\n name,\n providers: Array.from(providers),\n }));\n }\n\n public getEntities(): DevEntityMetadata[] {\n try {\n const repositoryProvider = this.alepha.inject(RepositoryProvider);\n const repositories = repositoryProvider.getRepositories();\n\n return repositories.map((repo) => {\n const entity = repo.entity;\n const schema = entity.schema as TObject;\n const options = entity.options;\n\n // Extract columns from schema\n const columns: DevEntityColumn[] = Object.entries(\n schema.properties,\n ).map(([name, field]) => {\n const fieldSchema = field as TSchema & Record<symbol, any>;\n const refData = fieldSchema[PG_REF];\n\n return {\n name,\n type: this.getColumnType(fieldSchema),\n nullable: this.isNullable(fieldSchema),\n primaryKey: PG_PRIMARY_KEY in fieldSchema,\n identity: PG_IDENTITY in fieldSchema || PG_SERIAL in fieldSchema,\n createdAt: PG_CREATED_AT in fieldSchema,\n updatedAt: PG_UPDATED_AT in fieldSchema,\n deletedAt: PG_DELETED_AT in fieldSchema,\n version: PG_VERSION in fieldSchema,\n hasDefault: PG_DEFAULT in fieldSchema,\n ref: refData\n ? {\n entity: refData.ref?.()?.entity?.name ?? \"unknown\",\n column: refData.ref?.()?.name ?? \"unknown\",\n onUpdate: refData.actions?.onUpdate,\n onDelete: refData.actions?.onDelete,\n }\n : undefined,\n };\n });\n\n // Extract indexes\n const indexes: DevEntityIndex[] = (options.indexes ?? []).map(\n (idx: any) => {\n if (typeof idx === \"string\") {\n return { columns: [idx], unique: false };\n }\n return {\n name: idx.name,\n columns: idx.column ? [idx.column] : (idx.columns ?? []),\n unique: idx.unique ?? false,\n };\n },\n );\n\n // Extract foreign keys\n const foreignKeys: DevEntityForeignKey[] = (\n options.foreignKeys ?? []\n ).map((fk: any) => ({\n name: fk.name,\n columns: fk.columns.map(String),\n foreignEntity: fk.foreignColumns?.[0]?.()?.entity?.name ?? \"unknown\",\n foreignColumns: fk.foreignColumns?.map(\n (fc: any) => fc?.()?.name ?? \"unknown\",\n ),\n }));\n\n // Extract constraints\n const constraints: DevEntityConstraint[] = (\n options.constraints ?? []\n ).map((c: any) => ({\n name: c.name,\n columns: c.columns.map(String),\n unique: !!c.unique,\n hasCheck: !!c.check,\n }));\n\n return {\n name: entity.name,\n provider: repo.provider.constructor.name,\n columns,\n indexes,\n foreignKeys,\n constraints,\n };\n });\n } catch {\n // RepositoryProvider not available (ORM not used)\n return [];\n }\n }\n\n protected getColumnType(field: TSchema): string {\n // Handle optional/nullable wrappers (unions with null)\n if (t.schema.isUnion(field) && (field as any).anyOf) {\n const types = (field as any).anyOf as TSchema[];\n const nonNull = types.find((type) => !t.schema.isNull(type));\n if (nonNull) {\n return this.getColumnType(nonNull);\n }\n }\n\n const f = field as any;\n\n // Check for enum (t.enum wraps in Unsafe with type=string and enum array)\n if (\n t.schema.isUnsafe(field) &&\n f.type === \"string\" &&\n Array.isArray(f.enum)\n ) {\n return \"enum\";\n }\n\n // Use TypeBox's type guards\n if (t.schema.isString(field)) {\n if (f.enum) return \"enum\";\n if (f.format === \"uuid\") return \"uuid\";\n if (f.format === \"date-time\") return \"datetime\";\n if (f.format === \"date\") return \"date\";\n if (f.format === \"bigint\") return \"bigint\";\n return \"text\";\n }\n if (t.schema.isInteger(field)) return \"integer\";\n if (t.schema.isNumber(field)) return \"number\";\n if (t.schema.isBoolean(field)) return \"boolean\";\n if (t.schema.isArray(field)) return \"array\";\n if (t.schema.isObject(field)) return \"json\";\n if (t.schema.isLiteral(field)) return \"literal\";\n\n return \"unknown\";\n }\n\n protected isNullable(field: TSchema): boolean {\n if (t.schema.isUnion(field) && (field as any).anyOf) {\n const types = (field as any).anyOf as TSchema[];\n return types.some((type) => t.schema.isNull(type));\n }\n return false;\n }\n\n public getCommands(): DevCommandMetadata[] {\n const commandPrimitives = this.alepha.primitives($command);\n\n return commandPrimitives\n .filter((cmd) => !cmd.options.hide)\n .map((command) => ({\n name: command.name,\n description: command.options.description,\n hidden: command.options.hide,\n }));\n }\n\n public getRoutes(): DevRouteMetadata[] {\n // Routes are the base primitive - actions and pages are routes\n // Showing them separately would be redundant with actions\n return [];\n }\n\n public getEnvs(): DevEnvMetadata[] {\n const envSchemas = this.alepha.getEnvSchemas();\n\n return envSchemas.map((item, index) => ({\n propertyKey: `env_${index}`,\n schema: item.schema,\n values: item.values,\n serviceName: undefined,\n }));\n }\n\n public getAtoms(): DevAtomMetadata[] {\n const atomsWithValues = this.alepha.store.getAtoms(false);\n\n return atomsWithValues.map(({ atom, value }) => ({\n name: atom.key,\n description: atom.options.description,\n schema: atom.schema,\n defaultValue: atom.options.default,\n currentValue: value,\n }));\n }\n\n public getMetadata(): DevMetadata {\n return {\n actions: this.getActions(),\n queues: this.getQueues(),\n schedulers: this.getSchedulers(),\n topics: this.getTopics(),\n buckets: this.getBuckets(),\n realms: this.getRealms(),\n caches: this.getCaches(),\n pages: this.getPages(),\n providers: this.getProviders(),\n modules: this.getModules(),\n entities: this.getEntities(),\n commands: this.getCommands(),\n routes: this.getRoutes(),\n envs: this.getEnvs(),\n atoms: this.getAtoms(),\n };\n }\n\n // -------------------------------------------------------------------------------------------------------------------\n\n protected getProviderName(provider?: \"memory\" | any): string {\n if (!provider) {\n return \"default\";\n }\n if (provider === \"memory\") {\n return \"memory\";\n }\n return provider.name || \"custom\";\n }\n}\n","import { NodeSqliteProvider } from \"alepha/orm\";\n\nexport class DevToolsDatabaseProvider extends NodeSqliteProvider {\n public get name() {\n return \"devtools\";\n }\n\n protected readonly options = {\n path: \":memory:\",\n };\n\n public override async migrate(): Promise<void> {\n this.sqlite.exec(`\n CREATE TABLE IF NOT EXISTS logs (\n id INTEGER PRIMARY KEY AUTOINCREMENT,\n level TEXT NOT NULL,\n message TEXT,\n service TEXT,\n module TEXT,\n context TEXT,\n app TEXT,\n data TEXT,\n timestamp INTEGER NOT NULL\n )\n `);\n }\n}\n","import { Repository } from \"alepha/orm\";\nimport { logs } from \"../entities/logs.ts\";\nimport { DevToolsDatabaseProvider } from \"../providers/DevToolsDatabaseProvider.ts\";\n\nexport class LogRepository extends Repository<typeof logs.schema> {\n constructor() {\n super(logs, DevToolsDatabaseProvider);\n }\n}\n","import { type Static, t } from \"alepha\";\n\nexport const devActionMetadataSchema = t.object({\n name: t.text(),\n group: t.text(),\n method: t.text(),\n path: t.text(),\n prefix: t.text(),\n fullPath: t.text(),\n description: t.optional(t.text()),\n summary: t.optional(t.text()),\n disabled: t.optional(t.boolean()),\n secure: t.optional(t.boolean()),\n hide: t.optional(t.boolean()),\n body: t.optional(t.any()),\n params: t.optional(t.any()),\n query: t.optional(t.any()),\n response: t.optional(t.any()),\n bodyContentType: t.optional(t.text()),\n});\n\nexport type DevActionMetadata = Static<typeof devActionMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devAtomMetadataSchema = t.object({\n /**\n * The unique name/key of the atom\n */\n name: t.text(),\n /**\n * Optional description of the atom\n */\n description: t.optional(t.text()),\n /**\n * The schema for the atom value (TypeBox/JSON Schema)\n */\n schema: t.any(),\n /**\n * The default value defined for the atom\n */\n defaultValue: t.optional(t.any()),\n /**\n * The current value of the atom\n */\n currentValue: t.optional(t.any()),\n});\n\nexport type DevAtomMetadata = Static<typeof devAtomMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devBucketMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n mimeTypes: t.optional(t.array(t.text())),\n maxSize: t.optional(t.number()),\n provider: t.text(),\n});\n\nexport type DevBucketMetadata = Static<typeof devBucketMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devCacheMetadataSchema = t.object({\n name: t.text(),\n ttl: t.optional(t.any()),\n disabled: t.optional(t.boolean()),\n provider: t.text(),\n});\n\nexport type DevCacheMetadata = Static<typeof devCacheMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devCommandMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n hidden: t.optional(t.boolean()),\n});\n\nexport type DevCommandMetadata = Static<typeof devCommandMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devEntityColumnSchema = t.object({\n name: t.text(),\n type: t.text(),\n nullable: t.boolean(),\n primaryKey: t.boolean(),\n identity: t.boolean(),\n createdAt: t.boolean(),\n updatedAt: t.boolean(),\n deletedAt: t.boolean(),\n version: t.boolean(),\n hasDefault: t.boolean(),\n ref: t.optional(\n t.object({\n entity: t.text(),\n column: t.text(),\n onUpdate: t.optional(t.text()),\n onDelete: t.optional(t.text()),\n }),\n ),\n});\n\nexport const devEntityIndexSchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n unique: t.boolean(),\n});\n\nexport const devEntityForeignKeySchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n foreignEntity: t.text(),\n foreignColumns: t.array(t.text()),\n});\n\nexport const devEntityConstraintSchema = t.object({\n name: t.optional(t.text()),\n columns: t.array(t.text()),\n unique: t.boolean(),\n hasCheck: t.boolean(),\n});\n\nexport const devEntityMetadataSchema = t.object({\n name: t.text(),\n provider: t.text(),\n columns: t.array(devEntityColumnSchema),\n indexes: t.array(devEntityIndexSchema),\n foreignKeys: t.array(devEntityForeignKeySchema),\n constraints: t.array(devEntityConstraintSchema),\n});\n\nexport type DevEntityColumn = Static<typeof devEntityColumnSchema>;\nexport type DevEntityIndex = Static<typeof devEntityIndexSchema>;\nexport type DevEntityForeignKey = Static<typeof devEntityForeignKeySchema>;\nexport type DevEntityConstraint = Static<typeof devEntityConstraintSchema>;\nexport type DevEntityMetadata = Static<typeof devEntityMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devEnvMetadataSchema = t.object({\n /**\n * The property name in the service where $env is defined\n */\n propertyKey: t.text(),\n /**\n * The schema for the environment variables (TypeBox/JSON Schema)\n */\n schema: t.any(),\n /**\n * The parsed values from the environment\n */\n values: t.record(t.text(), t.any()),\n /**\n * The service class name where this $env is defined\n */\n serviceName: t.optional(t.text()),\n});\n\nexport type DevEnvMetadata = Static<typeof devEnvMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devModuleMetadataSchema = t.object({\n name: t.text(),\n providers: t.array(t.text()),\n});\n\nexport type DevModuleMetadata = Static<typeof devModuleMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devPageMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n path: t.optional(t.text()),\n params: t.optional(t.any()),\n query: t.optional(t.any()),\n hasComponent: t.boolean(),\n hasLazy: t.boolean(),\n hasResolve: t.boolean(),\n hasChildren: t.boolean(),\n hasParent: t.boolean(),\n hasErrorHandler: t.boolean(),\n static: t.optional(t.boolean()),\n cache: t.optional(t.any()),\n client: t.optional(t.any()),\n animation: t.optional(t.any()),\n});\n\nexport type DevPageMetadata = Static<typeof devPageMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devProviderMetadataSchema = t.object({\n name: t.text(),\n module: t.optional(t.text()),\n dependencies: t.array(t.text()),\n aliases: t.optional(t.array(t.text())),\n});\n\nexport type DevProviderMetadata = Static<typeof devProviderMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devQueueMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n schema: t.optional(t.any()),\n provider: t.text(),\n});\n\nexport type DevQueueMetadata = Static<typeof devQueueMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devRealmMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n roles: t.optional(t.array(t.any())),\n type: t.enum([\"internal\", \"external\"]),\n settings: t.optional(\n t.object({\n accessTokenExpiration: t.optional(t.any()),\n refreshTokenExpiration: t.optional(t.any()),\n hasOnCreateSession: t.boolean(),\n hasOnRefreshSession: t.boolean(),\n hasOnDeleteSession: t.boolean(),\n }),\n ),\n});\n\nexport type DevRealmMetadata = Static<typeof devRealmMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devRouteMetadataSchema = t.object({\n method: t.text(),\n path: t.text(),\n});\n\nexport type DevRouteMetadata = Static<typeof devRouteMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devSchedulerMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n cron: t.optional(t.text()),\n interval: t.optional(t.any()),\n lock: t.optional(t.boolean()),\n});\n\nexport type DevSchedulerMetadata = Static<typeof devSchedulerMetadataSchema>;\n","import { type Static, t } from \"alepha\";\n\nexport const devTopicMetadataSchema = t.object({\n name: t.text(),\n description: t.optional(t.text()),\n schema: t.optional(t.any()),\n provider: t.text(),\n});\n\nexport type DevTopicMetadata = Static<typeof devTopicMetadataSchema>;\n","import { type Static, t } from \"alepha\";\nimport { devActionMetadataSchema } from \"./DevActionMetadata.ts\";\nimport { devAtomMetadataSchema } from \"./DevAtomMetadata.ts\";\nimport { devBucketMetadataSchema } from \"./DevBucketMetadata.ts\";\nimport { devCacheMetadataSchema } from \"./DevCacheMetadata.ts\";\nimport { devCommandMetadataSchema } from \"./DevCommandMetadata.ts\";\nimport { devEntityMetadataSchema } from \"./DevEntityMetadata.ts\";\nimport { devEnvMetadataSchema } from \"./DevEnvMetadata.ts\";\nimport { devModuleMetadataSchema } from \"./DevModuleMetadata.ts\";\nimport { devPageMetadataSchema } from \"./DevPageMetadata.ts\";\nimport { devProviderMetadataSchema } from \"./DevProviderMetadata.ts\";\nimport { devQueueMetadataSchema } from \"./DevQueueMetadata.ts\";\nimport { devRealmMetadataSchema } from \"./DevRealmMetadata.ts\";\nimport { devRouteMetadataSchema } from \"./DevRouteMetadata.ts\";\nimport { devSchedulerMetadataSchema } from \"./DevSchedulerMetadata.ts\";\nimport { devTopicMetadataSchema } from \"./DevTopicMetadata.ts\";\n\nexport const devMetadataSchema = t.object({\n actions: t.array(devActionMetadataSchema),\n queues: t.array(devQueueMetadataSchema),\n schedulers: t.array(devSchedulerMetadataSchema),\n topics: t.array(devTopicMetadataSchema),\n buckets: t.array(devBucketMetadataSchema),\n realms: t.array(devRealmMetadataSchema),\n caches: t.array(devCacheMetadataSchema),\n pages: t.array(devPageMetadataSchema),\n providers: t.array(devProviderMetadataSchema),\n modules: t.array(devModuleMetadataSchema),\n entities: t.array(devEntityMetadataSchema),\n commands: t.array(devCommandMetadataSchema),\n routes: t.array(devRouteMetadataSchema),\n envs: t.array(devEnvMetadataSchema),\n atoms: t.array(devAtomMetadataSchema),\n});\n\nexport type DevMetadata = Static<typeof devMetadataSchema>;\n","import { join } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { $hook, $inject, Alepha, pageQuerySchema, t } from \"alepha\";\nimport { $batch } from \"alepha/batch\";\nimport { $logger, JsonFormatterProvider, type LogEntry } from \"alepha/logger\";\nimport { parseQueryString } from \"alepha/orm\";\nimport { $route, ServerProvider } from \"alepha/server\";\nimport { $serve } from \"alepha/server/static\";\nimport { type DevLogEntry, logs } from \"./entities/logs.ts\";\nimport { DevToolsMetadataProvider } from \"./providers/DevToolsMetadataProvider.ts\";\nimport { LogRepository } from \"./repositories/LogRepository.ts\";\nimport { devMetadataSchema } from \"./schemas/DevMetadata.ts\";\n\nexport class DevToolsProvider {\n protected readonly log = $logger();\n protected readonly alepha = $inject(Alepha);\n protected readonly serverProvider = $inject(ServerProvider);\n protected readonly jsonFormatter = $inject(JsonFormatterProvider);\n protected readonly logs = $inject(LogRepository);\n protected readonly devCollectorProvider = $inject(DevToolsMetadataProvider);\n\n protected readonly onStart = $hook({\n on: \"start\",\n handler: () => {\n this.log.info(\n `Devtools available at ${this.serverProvider.hostname}/devtools/`,\n );\n },\n });\n\n protected batchLogs = $batch({\n maxSize: 50,\n maxDuration: [10, \"seconds\"],\n schema: logs.insertSchema,\n handler: async (entries) => {\n await this.logs.createMany(entries);\n },\n });\n\n protected readonly onLog = $hook({\n on: \"log\",\n handler: async (ev: { message?: string; entry: LogEntry }) => {\n // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n // CAUTION: It's very easy to create an infinite loop here.\n // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n\n try {\n if (!this.alepha.isStarted()) {\n return;\n }\n\n ev.entry.message = ev.entry.message?.slice(0, 2000); // limit message size\n\n if (ev.entry.module === \"alepha.devtools\") {\n // skip devtools logs to avoid infinite loop\n return;\n }\n\n if (ev.entry.level === \"TRACE\" && ev.entry.module === \"alepha.batch\") {\n // skip batch trace logs to avoid infinite loop\n return;\n }\n\n if (this.alepha.isProduction() && ev.entry.level === \"TRACE\") {\n // skip trace logs in production\n return;\n }\n\n const entry = {\n ...ev.entry,\n data:\n ev.entry.data instanceof Error\n ? this.jsonFormatter.formatJsonError(ev.entry.data)\n : typeof ev.entry.data === \"object\" &&\n !Array.isArray(ev.entry.data)\n ? ev.entry.data\n : { data: ev.entry.data },\n };\n\n await this.batchLogs.push(entry as DevLogEntry);\n } catch (error) {\n // DO TO NOT WITH THE LOGGER HERE TO AVOID INFINITE LOOP\n console.error(error, ev);\n }\n },\n });\n\n protected readonly uiRoute = $serve({\n path: \"/devtools\",\n root: join(fileURLToPath(import.meta.url), \"../../../assets/devtools\"),\n historyApiFallback: true,\n });\n\n protected readonly metadataRoute = $route({\n method: \"GET\",\n path: \"/devtools/api/metadata\",\n silent: true,\n schema: {\n response: devMetadataSchema,\n },\n handler: () => {\n return this.devCollectorProvider.getMetadata();\n },\n });\n\n protected readonly logsRoute = $route({\n method: \"GET\",\n path: \"/devtools/api/logs\",\n silent: true,\n schema: {\n query: t.extend(pageQuerySchema, {\n search: t.optional(t.string()),\n }),\n response: t.page(logs.schema),\n },\n handler: ({ query }) => {\n query.sort ??= \"-timestamp\";\n return this.logs.paginate(\n query,\n query.search\n ? {\n where: parseQueryString(query.search),\n }\n : {},\n {\n count: true,\n },\n );\n },\n });\n\n protected readonly updateAtomRoute = $route({\n method: \"POST\",\n path: \"/devtools/api/atoms\",\n silent: true,\n schema: {\n body: t.object({\n name: t.text(),\n value: t.any(),\n }),\n response: t.object({\n success: t.boolean(),\n }),\n },\n handler: ({ body }) => {\n const atoms = this.alepha.store.getAtoms(false);\n const atomEntry = atoms.find((a) => a.atom.key === body.name);\n\n if (atomEntry) {\n this.alepha.store.set(atomEntry.atom, body.value);\n return { success: true };\n }\n\n return { success: false };\n },\n });\n}\n","import { $module } from \"alepha\";\nimport { DevToolsProvider } from \"./api/DevToolsProvider.ts\";\nimport { DevToolsDatabaseProvider } from \"./api/providers/DevToolsDatabaseProvider.ts\";\nimport { DevToolsMetadataProvider } from \"./api/providers/DevToolsMetadataProvider.ts\";\nimport { LogRepository } from \"./api/repositories/LogRepository.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./api/providers/DevToolsMetadataProvider.ts\";\nexport * from \"./api/schemas/DevActionMetadata.ts\";\nexport * from \"./api/schemas/DevBucketMetadata.ts\";\nexport * from \"./api/schemas/DevCacheMetadata.ts\";\nexport * from \"./api/schemas/DevCommandMetadata.ts\";\nexport * from \"./api/schemas/DevEntityMetadata.ts\";\nexport * from \"./api/schemas/DevMetadata.ts\";\nexport * from \"./api/schemas/DevModuleMetadata.ts\";\nexport * from \"./api/schemas/DevPageMetadata.ts\";\nexport * from \"./api/schemas/DevProviderMetadata.ts\";\nexport * from \"./api/schemas/DevQueueMetadata.ts\";\nexport * from \"./api/schemas/DevRealmMetadata.ts\";\nexport * from \"./api/schemas/DevRouteMetadata.ts\";\nexport * from \"./api/schemas/DevSchedulerMetadata.ts\";\nexport * from \"./api/schemas/DevTopicMetadata.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Developer tools module for monitoring and debugging Alepha applications.\n *\n * This module provides comprehensive data collection capabilities for tracking application behavior,\n * performance metrics, and debugging information in real-time.\n *\n * @see {@link DevToolsMetadataProvider}\n * @module alepha.devtools\n */\nexport const AlephaDevtools = $module({\n name: \"alepha.devtools\",\n primitives: [],\n services: [\n DevToolsMetadataProvider,\n DevToolsProvider,\n DevToolsDatabaseProvider,\n LogRepository,\n ],\n register: (alepha) => {\n alepha.with(DevToolsProvider);\n alepha.with(DevToolsDatabaseProvider);\n alepha.with(DevToolsMetadataProvider);\n alepha.store.push(\"alepha.build.assets\", \"@alepha/devtools\");\n },\n});\n"],"mappings":"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"}
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@alepha/devtools",
3
3
  "description": "Developer tools for monitoring and debugging Alepha applications.",
4
4
  "author": "Nicolas Foures",
5
- "version": "0.14.2",
5
+ "version": "0.14.4",
6
6
  "type": "module",
7
7
  "engines": {
8
8
  "node": ">=22.0.0"
@@ -16,22 +16,22 @@
16
16
  "assets"
17
17
  ],
18
18
  "devDependencies": {
19
- "@alepha/react": "0.14.2",
20
- "@alepha/ui": "0.14.2",
19
+ "@alepha/react": "0.14.4",
20
+ "@alepha/ui": "0.14.4",
21
21
  "@biomejs/biome": "^2.3.11",
22
- "@mantine/core": "^8.3.10",
23
- "@mantine/hooks": "^8.3.10",
22
+ "@mantine/core": "^8.3.11",
23
+ "@mantine/hooks": "^8.3.11",
24
24
  "@tabler/icons-react": "^3.36.1",
25
25
  "@xyflow/react": "^12.10.0",
26
- "alepha": "0.14.2",
26
+ "alepha": "0.14.4",
27
27
  "react": "^19.2.3",
28
- "tsdown": "^0.19.0-beta.2",
28
+ "tsdown": "^0.19.0-beta.5",
29
29
  "typescript": "^5.9.3",
30
- "vite": "^7.3.0",
30
+ "vite": "^7.3.1",
31
31
  "vitest": "^4.0.16"
32
32
  },
33
33
  "peerDependencies": {
34
- "alepha": "0.14.2"
34
+ "alepha": "0.14.4"
35
35
  },
36
36
  "scripts": {
37
37
  "lint": "alepha lint",
@@ -0,0 +1,7 @@
1
+ import { describe, it } from "vitest";
2
+
3
+ describe("DevCollectorProvider", () => {
4
+ it("should collect logs", async () => {
5
+ // TODO: Implement tests for DevCollectorProvider
6
+ });
7
+ });
@@ -8,4 +8,20 @@ export class DevToolsDatabaseProvider extends NodeSqliteProvider {
8
8
  protected readonly options = {
9
9
  path: ":memory:",
10
10
  };
11
+
12
+ public override async migrate(): Promise<void> {
13
+ this.sqlite.exec(`
14
+ CREATE TABLE IF NOT EXISTS logs (
15
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
16
+ level TEXT NOT NULL,
17
+ message TEXT,
18
+ service TEXT,
19
+ module TEXT,
20
+ context TEXT,
21
+ app TEXT,
22
+ data TEXT,
23
+ timestamp INTEGER NOT NULL
24
+ )
25
+ `);
26
+ }
11
27
  }
package/src/index.ts CHANGED
@@ -43,10 +43,6 @@ export const AlephaDevtools = $module({
43
43
  LogRepository,
44
44
  ],
45
45
  register: (alepha) => {
46
- if (!alepha.isViteDev()) {
47
- return;
48
- }
49
-
50
46
  alepha.with(DevToolsProvider);
51
47
  alepha.with(DevToolsDatabaseProvider);
52
48
  alepha.with(DevToolsMetadataProvider);
@@ -1,151 +1,7 @@
1
- import { useInject } from "@alepha/react";
2
- import { ui } from "@alepha/ui";
3
- import { Box, Flex, SimpleGrid, Text } from "@mantine/core";
4
- import {
5
- IconApi,
6
- IconArchive,
7
- IconAtom,
8
- IconBucket,
9
- IconCalendarEvent,
10
- IconDatabase,
11
- IconLock,
12
- IconMessageCircle,
13
- IconPackages,
14
- IconServer,
15
- IconStack2,
16
- IconTerminal,
17
- IconTools,
18
- IconVariable,
19
- } from "@tabler/icons-react";
20
- import { HttpClient } from "alepha/server";
21
- import type { ReactNode } from "react";
22
- import { useEffect, useState } from "react";
23
- import {
24
- type DevMetadata,
25
- devMetadataSchema,
26
- } from "../../api/schemas/DevMetadata.ts";
27
-
28
- interface StatCardProps {
29
- label: string;
30
- count: number;
31
- icon: ReactNode;
32
- }
33
-
34
- const StatCard = ({ label, count, icon }: StatCardProps) => (
35
- <Flex
36
- direction="column"
37
- align="center"
38
- justify="center"
39
- p="xl"
40
- style={{
41
- borderRadius: 12,
42
- border: `1px solid ${ui.colors.border}`,
43
- cursor: "pointer",
44
- transition: "all 0.2s ease",
45
- }}
46
- bg={ui.colors.surface}
47
- className="devtools-card"
48
- >
49
- <Box opacity={0.5} mb="md">
50
- {icon}
51
- </Box>
52
- <Text size="sm" c="dimmed">
53
- <Text span fw={600} size="lg" c="var(--mantine-color-text)">
54
- {count}
55
- </Text>{" "}
56
- {label}
57
- </Text>
58
- </Flex>
59
- );
1
+ import { Alert, Flex, Text } from "@mantine/core";
2
+ import { IconInfoCircle, IconTools } from "@tabler/icons-react";
60
3
 
61
4
  export const DevDashboard = () => {
62
- const http = useInject(HttpClient);
63
- const [metadata, setMetadata] = useState<DevMetadata | null>(null);
64
-
65
- useEffect(() => {
66
- http
67
- .fetch("/devtools/api/metadata", {
68
- schema: { response: devMetadataSchema },
69
- })
70
- .then((res) => setMetadata(res.data));
71
- }, []);
72
-
73
- if (!metadata) {
74
- return (
75
- <Flex align="center" justify="center" h="100%">
76
- <Text c="dimmed">Loading...</Text>
77
- </Flex>
78
- );
79
- }
80
-
81
- const stats = [
82
- {
83
- label: "actions",
84
- count: metadata.actions.length,
85
- icon: <IconApi size={48} stroke={1.2} />,
86
- },
87
- {
88
- label: "entities",
89
- count: metadata.entities.length,
90
- icon: <IconDatabase size={48} stroke={1.2} />,
91
- },
92
- {
93
- label: "queues",
94
- count: metadata.queues.length,
95
- icon: <IconStack2 size={48} stroke={1.2} />,
96
- },
97
- {
98
- label: "schedulers",
99
- count: metadata.schedulers.length,
100
- icon: <IconCalendarEvent size={48} stroke={1.2} />,
101
- },
102
- {
103
- label: "topics",
104
- count: metadata.topics.length,
105
- icon: <IconMessageCircle size={48} stroke={1.2} />,
106
- },
107
- {
108
- label: "buckets",
109
- count: metadata.buckets.length,
110
- icon: <IconBucket size={48} stroke={1.2} />,
111
- },
112
- {
113
- label: "realms",
114
- count: metadata.realms.length,
115
- icon: <IconLock size={48} stroke={1.2} />,
116
- },
117
- {
118
- label: "caches",
119
- count: metadata.caches.length,
120
- icon: <IconArchive size={48} stroke={1.2} />,
121
- },
122
- {
123
- label: "commands",
124
- count: metadata.commands.length,
125
- icon: <IconTerminal size={48} stroke={1.2} />,
126
- },
127
- {
128
- label: "env schemas",
129
- count: metadata.envs.length,
130
- icon: <IconVariable size={48} stroke={1.2} />,
131
- },
132
- {
133
- label: "atoms",
134
- count: metadata.atoms.length,
135
- icon: <IconAtom size={48} stroke={1.2} />,
136
- },
137
- {
138
- label: "modules",
139
- count: metadata.modules.length,
140
- icon: <IconPackages size={48} stroke={1.2} />,
141
- },
142
- {
143
- label: "services",
144
- count: metadata.providers.length,
145
- icon: <IconServer size={48} stroke={1.2} />,
146
- },
147
- ].filter((stat) => stat.count > 0);
148
-
149
5
  return (
150
6
  <Flex
151
7
  direction="column"
@@ -155,15 +11,6 @@ export const DevDashboard = () => {
155
11
  w="100%"
156
12
  gap="xl"
157
13
  >
158
- <style>
159
- {`
160
- .devtools-card:hover {
161
- border-color: var(--mantine-color-dimmed);
162
- transform: translateY(-2px);
163
- }
164
- `}
165
- </style>
166
-
167
14
  <Flex direction="column" align="center" gap={4} mb="md">
168
15
  <Flex align="center" gap="sm">
169
16
  <IconTools size={40} stroke={1.5} opacity={0.8} />
@@ -171,16 +18,19 @@ export const DevDashboard = () => {
171
18
  Alepha DevTools
172
19
  </Text>
173
20
  </Flex>
174
- <Text size="xs" c="dimmed">
175
- Explore your Alepha application metadata
176
- </Text>
177
21
  </Flex>
178
22
 
179
- <SimpleGrid cols={{ base: 2, sm: 3, md: 4 }} spacing="md">
180
- {stats.map((stat) => (
181
- <StatCard key={stat.label} {...stat} />
182
- ))}
183
- </SimpleGrid>
23
+ <Alert
24
+ icon={<IconInfoCircle />}
25
+ title="Work In Progress"
26
+ color="blue"
27
+ variant="light"
28
+ maw={500}
29
+ >
30
+ DevTools is still in active development. New features and improvements
31
+ are being added regularly. Use the navigation to explore available
32
+ tools.
33
+ </Alert>
184
34
  </Flex>
185
35
  );
186
36
  };
@@ -1,10 +1,5 @@
1
- import { NestedView } from "@alepha/react/router";
2
- import {
3
- ActionButton,
4
- AdminShell,
5
- DarkModeButton,
6
- OmnibarButton,
7
- } from "@alepha/ui";
1
+ import { AdminShell, DarkModeButton, OmnibarButton, ui } from "@alepha/ui";
2
+ import { Flex } from "@mantine/core";
8
3
  import {
9
4
  IconApi,
10
5
  IconArchive,
@@ -14,7 +9,6 @@ import {
14
9
  IconLogs,
15
10
  IconMessageCircle,
16
11
  IconStack2,
17
- IconTools,
18
12
  IconTopologyRing,
19
13
  IconVariable,
20
14
  } from "@tabler/icons-react";
@@ -22,6 +16,12 @@ import {
22
16
  export const DevLayout = () => {
23
17
  return (
24
18
  <AdminShell
19
+ appShellHeaderProps={{
20
+ bg: ui.colors.background,
21
+ }}
22
+ appShellNavbarProps={{
23
+ bg: "transparent",
24
+ }}
25
25
  sidebarProps={{
26
26
  gap: 4,
27
27
  collapsed: true,
@@ -87,19 +87,26 @@ export const DevLayout = () => {
87
87
  {
88
88
  position: "left",
89
89
  element: (
90
- <ActionButton
91
- intent={"none"}
92
- icon={IconTools}
93
- href={"/"}
94
- active={false}
95
- >
96
- Devtools
97
- </ActionButton>
90
+ <Flex
91
+ h={"60px"}
92
+ w={"78px"}
93
+ style={{
94
+ marginLeft: "-32px",
95
+ borderRight: "1px solid var(--mantine-color-default-border)",
96
+ }}
97
+ />
98
98
  ),
99
99
  },
100
100
  {
101
- position: "center",
102
- element: <OmnibarButton />,
101
+ position: "left",
102
+ element: (
103
+ <OmnibarButton
104
+ actionProps={{
105
+ variant: "outline",
106
+ bd: "1px solid var(--mantine-color-default-border)",
107
+ }}
108
+ />
109
+ ),
103
110
  },
104
111
  {
105
112
  position: "right",
@@ -107,9 +114,7 @@ export const DevLayout = () => {
107
114
  },
108
115
  ],
109
116
  }}
110
- >
111
- <NestedView />
112
- </AdminShell>
117
+ />
113
118
  );
114
119
  };
115
120