monorise 0.0.4 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base/index.d.ts +48 -1
- package/dist/base/index.js.map +1 -1
- package/dist/cli/cli.js +85 -66
- package/dist/cli/cli.js.map +1 -1
- package/dist/core/index.d.ts +34 -0
- package/dist/core/index.js +191 -27
- package/dist/core/index.js.map +1 -1
- package/dist/react/actions/core.action.d.ts +9 -0
- package/dist/react/actions/core.action.d.ts.map +1 -1
- package/dist/react/index.d.ts +21 -2
- package/dist/react/index.d.ts.map +1 -1
- package/dist/react/index.js +75 -1
- package/dist/react/index.js.map +1 -1
- package/dist/react/lib/utils.d.ts +1 -1
- package/dist/react/lib/utils.d.ts.map +1 -1
- package/dist/react/services/core.service.d.ts +2 -1
- package/dist/react/services/core.service.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/base/index.d.ts
CHANGED
|
@@ -6,6 +6,9 @@ interface EntitySchemaMap {
|
|
|
6
6
|
[key: string]: Record<string, any>;
|
|
7
7
|
}
|
|
8
8
|
type DraftEntity<T extends Entity = Entity> = T extends keyof EntitySchemaMap ? EntitySchemaMap[T] : never;
|
|
9
|
+
type NumericFields<T> = {
|
|
10
|
+
[K in keyof T as T[K] extends number ? K : never]?: number;
|
|
11
|
+
};
|
|
9
12
|
type CreatedEntity<T extends Entity = Entity> = {
|
|
10
13
|
entityId: string;
|
|
11
14
|
entityType: string;
|
|
@@ -210,6 +213,42 @@ interface MonoriseEntityConfig<T extends Entity = Entity, B extends z.ZodRawShap
|
|
|
210
213
|
sortValue?: string;
|
|
211
214
|
}[];
|
|
212
215
|
}[];
|
|
216
|
+
/**
|
|
217
|
+
* @description (Optional) Constraints for `adjustEntity` operations.
|
|
218
|
+
* When adjusting numeric fields, these constraints are enforced at the database level.
|
|
219
|
+
* If an adjustment would violate a constraint, the operation is rejected.
|
|
220
|
+
*
|
|
221
|
+
* @example
|
|
222
|
+
* ```ts
|
|
223
|
+
* {
|
|
224
|
+
* adjustmentConstraints: {
|
|
225
|
+
* // Static: same for all entities of this type
|
|
226
|
+
* balance: { min: 0 },
|
|
227
|
+
* credits: { min: 0, max: 10000 },
|
|
228
|
+
*
|
|
229
|
+
* // Dynamic: reads constraint value from entity's own data
|
|
230
|
+
* balance: { minField: 'minBalance' },
|
|
231
|
+
* credits: { min: 0, maxField: 'creditLimit' },
|
|
232
|
+
* }
|
|
233
|
+
* }
|
|
234
|
+
* ```
|
|
235
|
+
*/
|
|
236
|
+
adjustmentConstraints?: {
|
|
237
|
+
[fieldName: string]: {
|
|
238
|
+
/** Static minimum value */
|
|
239
|
+
min?: number;
|
|
240
|
+
/** Static maximum value */
|
|
241
|
+
max?: number;
|
|
242
|
+
/** Field name on the entity whose value is used as the minimum (must be a numeric field) */
|
|
243
|
+
minField?: keyof {
|
|
244
|
+
[K in keyof B as B[K] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K : never]: K;
|
|
245
|
+
};
|
|
246
|
+
/** Field name on the entity whose value is used as the maximum (must be a numeric field) */
|
|
247
|
+
maxField?: keyof {
|
|
248
|
+
[K in keyof B as B[K] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K : never]: K;
|
|
249
|
+
};
|
|
250
|
+
};
|
|
251
|
+
};
|
|
213
252
|
}
|
|
214
253
|
|
|
215
254
|
declare const createEntityConfig: <T extends Entity, B extends z.ZodRawShape, C extends z.ZodRawShape, M extends z.ZodRawShape, CO extends z.ZodObject<C> | undefined = undefined, MO extends z.ZodObject<M> | undefined = undefined>(config: MonoriseEntityConfig<T, B, C, M, CO, MO>) => {
|
|
@@ -261,6 +300,14 @@ declare const createEntityConfig: <T extends Entity, B extends z.ZodRawShape, C
|
|
|
261
300
|
sortValue?: string;
|
|
262
301
|
}[];
|
|
263
302
|
}[];
|
|
303
|
+
adjustmentConstraints?: {
|
|
304
|
+
[fieldName: string]: {
|
|
305
|
+
min?: number;
|
|
306
|
+
max?: number;
|
|
307
|
+
minField?: keyof { [K in keyof B as B[K] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K : never]: K; } | undefined;
|
|
308
|
+
maxField?: keyof { [K_1 in keyof B as B[K_1] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K_1 : never]: K_1; } | undefined;
|
|
309
|
+
};
|
|
310
|
+
} | undefined;
|
|
264
311
|
};
|
|
265
312
|
|
|
266
|
-
export { type CreatedEntity, type DraftEntity, Entity, type EntitySchemaMap, type MonoriseEntityConfig, createEntityConfig };
|
|
313
|
+
export { type CreatedEntity, type DraftEntity, Entity, type EntitySchemaMap, type MonoriseEntityConfig, type NumericFields, createEntityConfig };
|
package/dist/base/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../types/monorise.type.ts","../utils/index.ts"],"sourcesContent":["import type { z } from 'zod';\n\nexport enum Entity {}\n\nexport interface EntitySchemaMap {\n [key: string]: Record<string, any>;\n}\n\nexport type DraftEntity<T extends Entity = Entity> =\n T extends keyof EntitySchemaMap ? EntitySchemaMap[T] : never;\n\nexport type CreatedEntity<T extends Entity = Entity> = {\n entityId: string;\n entityType: string;\n data: T extends keyof EntitySchemaMap ? EntitySchemaMap[T] : never;\n createdAt: string;\n updatedAt: string;\n};\n\n/**\n * @description Configuration for a monorise entity, a shared configuration that is used across frontend and backend.\n * This can be served as a single source of truth for the entity configuration.\n * It is used to define the schema, and mutual relationships between this entity and other entities.\n *\n * @example\n * ```ts\n * const baseSchema = z.object({\n * title: z.string(),\n * }).partial();\n *\n * const createSchema = baseSchema.extend({\n * title: z.string(),\n * })\n *\n * const config = createEntityConfig({\n * name: 'learner',\n * displayName: 'Learner',\n * baseSchema,\n * createSchema,\n * });\n * ```\n */\nexport interface MonoriseEntityConfig<\n T extends Entity = Entity,\n B extends z.ZodRawShape = z.ZodRawShape,\n C extends z.ZodRawShape = z.ZodRawShape,\n M extends z.ZodRawShape = z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n> {\n /**\n * @description Name of the entity. Must be in **lower-kebab-case** and **unique** across all entities\n *\n * @example `learner`, `learning-activity`\n */\n name: string | T;\n\n /**\n * @description Display name of the entity. It is not required to be unique\n */\n displayName: string;\n\n /**\n * @description (DEPRECATED) Use `uniqueFields` instead, Monorise should not handle auth mechanism\n * @description (Optional) Specify the authentication method to be used for the entity\n */\n authMethod?: {\n /**\n * @description Authentication method using email\n *\n * Note: The email used for authentication is unique per entity.\n * For example, if `johndoe@mail.com` is used for `learner` entity,\n * it can be reused again on `admin` entity. However, the same email\n * address cannot be repeated for the same entity.\n */\n email: {\n /**\n * @description Number of milliseconds before the token expires\n */\n tokenExpiresIn: number;\n };\n };\n\n /**\n * @description Base schema for the entity\n */\n baseSchema: z.ZodObject<B>;\n\n /**\n * @description Minimal schema required to create an entity\n */\n createSchema?: CO;\n searchableFields?: (keyof B)[];\n uniqueFields?: (keyof B)[];\n\n /**\n * @description Define mutual relationship of this entity with other entities\n */\n mutual?: {\n /**\n * @description Subscribes to update events from specified entities in the array.\n * These events will be used to run prejoin processor.\n */\n subscribes?: { entityType: Entity }[];\n /**\n * @description Virtual schema for mutual relationship. The schema is only used for validation purpose, but these fields are not stored in the database\n */\n mutualSchema: MO;\n\n /**\n * @description Keys of `mutualFields` are fields defined in `mutualSchema`.\n * Each field is a mutual relationship between this entity and another entity.\n */\n mutualFields: {\n [key: string]: {\n entityType: Entity;\n toMutualIds?: (context: any) => string[];\n /**\n * @description (Optional) Custom function to process `mutualData`. If not provided, `mutualData` will be empty.\n *\n * @returns the final state of `mutualData` to be stored in the mutual record. Must be an object.\n */\n mutualDataProcessor?: (\n mutualIds: string[],\n currentMutual: any,\n customContext?: Record<string, any>,\n ) => Record<string, any>;\n };\n };\n\n /**\n * @description (Optional) Better known as tree processor\n * This is used to prejoin entities that are not directly related as mutual.\n * For example, if `learner` entity is related to `course` entity, and `course` entity is related to `module` entity,\n * prejoins can be used to join `learner` and `module` entities.\n * With this, the `learner` entity can access the `module` entity without having to go through the `course` entity,\n * hence reducing the number of queries.\n *\n * DynamoDB best practices: https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/bp-general-normalization.html\n *\n */\n prejoins?: {\n mutualField: string;\n targetEntityType: Entity;\n entityPaths: {\n skipCache?: boolean;\n entityType: Entity;\n processor?: (items: any[], context: Record<string, any>) => any;\n }[];\n }[];\n };\n /**\n * Use this function to perform side effects on the final schema for example refine/superRefine the schema\n *\n * @param schema The final schema of the entity (the combination of `baseSchema`/`createSchema` and `mutualSchema` if specified)\n * @returns void\n *\n * @example\n * ```ts\n * effect: (schema) => {\n * schema.refine(\n * // refinement logic here\n * )\n * }\n */\n effect?: (\n schema: z.ZodObject<z.ZodRawShape>,\n ) => z.ZodEffects<z.ZodObject<z.ZodRawShape>>;\n\n /**\n * @description (Optional) Use tags to create additional access patterns for the entity.\n * Time complexity for retrieving tagged entities is O(1).\n *\n * The following configuration will create a tag named `region` for the `organization` entity grouped by `region`.\n * You would then be able to retrieve all organizations in a specific region by:\n * GET `/core/tag/organization/region?group={region_name}`\n *\n * @example\n *\n * ```ts\n * {\n * name: 'organization',\n * tags: [\n * {\n * name: 'region',\n * processor: (entity) => {\n * return [\n * {\n * group: entity.data.region\n * }\n * ]\n * },\n * }\n * ]\n * }\n * ```\n *\n * @description\n *\n * The following configuration will create a tag named `dob` for the `user` entity sorted by `dob`.\n * You would then be able to retrieve all users sorted by `dob` by:\n * GET `/core/tag/user/dob?start=2000-01-01&end=2020-12-31`\n *\n * @example\n * ```ts\n * {\n * name: 'user',\n * tags: [\n * {\n * name: 'dob',\n * processor: (entity) => {\n * return [\n * {\n * sortValue: entity.data.dob\n * }\n * ]\n * },\n * }\n * ]\n * }\n * ```\n */\n tags?: {\n name: string;\n processor: (entity: { entityId: string; entityType: string; data: Record<string, any>; createdAt: string; updatedAt: string }) => {\n group?: string;\n sortValue?: string;\n }[];\n }[];\n}\n","import type { Entity, MonoriseEntityConfig } from '../types/monorise.type';\nimport { z } from 'zod';\n\nfunction makeSchema<\n T extends Entity,\n B extends z.ZodRawShape,\n C extends z.ZodRawShape,\n M extends z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n>(config: MonoriseEntityConfig<T, B, C, M, CO, MO>) {\n const { baseSchema, createSchema, mutual, effect } = config;\n const { mutualSchema } = mutual || {};\n\n type FinalSchemaType = CO extends z.AnyZodObject\n ? MO extends z.AnyZodObject\n ? z.ZodObject<MO['shape'] & CO['shape']>\n : CO\n : MO extends z.AnyZodObject\n ? z.ZodObject<MO['shape'] & B>\n : z.ZodObject<B>;\n\n const finalSchema = z.object({\n ...baseSchema.shape,\n ...createSchema?.shape,\n ...mutualSchema?.shape,\n }) as FinalSchemaType;\n\n if (effect) {\n return effect(finalSchema) as z.ZodEffects<FinalSchemaType>;\n }\n\n return finalSchema;\n}\n\nconst createEntityConfig = <\n T extends Entity,\n B extends z.ZodRawShape,\n C extends z.ZodRawShape,\n M extends z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n>(\n config: MonoriseEntityConfig<T, B, C, M, CO, MO>,\n) => ({\n ...config,\n finalSchema: makeSchema(config),\n});\n\nexport { createEntityConfig };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAEO,IAAK,SAAL,kBAAKA,YAAL;AAAK,SAAAA;AAAA,GAAA;;;ACDZ,SAAS,SAAS;AAElB,SAAS,WAOP,QAAkD;AAClD,QAAM,EAAE,YAAY,cAAc,QAAQ,OAAO,IAAI;AACrD,QAAM,EAAE,aAAa,IAAI,UAAU,CAAC;AAUpC,QAAM,cAAc,EAAE,OAAO,iDACxB,WAAW,QACX,6CAAc,QACd,6CAAc,MAClB;AAED,MAAI,QAAQ;AACV,WAAO,OAAO,WAAW;AAAA,EAC3B;AAEA,SAAO;AACT;AAEA,IAAM,qBAAqB,CAQzB,WACI,iCACD,SADC;AAAA,EAEJ,aAAa,WAAW,MAAM;AAChC;","names":["Entity"]}
|
|
1
|
+
{"version":3,"sources":["../types/monorise.type.ts","../utils/index.ts"],"sourcesContent":["import type { z } from 'zod';\n\nexport enum Entity {}\n\nexport interface EntitySchemaMap {\n [key: string]: Record<string, any>;\n}\n\nexport type DraftEntity<T extends Entity = Entity> =\n T extends keyof EntitySchemaMap ? EntitySchemaMap[T] : never;\n\nexport type NumericFields<T> = {\n [K in keyof T as T[K] extends number ? K : never]?: number;\n};\n\nexport type CreatedEntity<T extends Entity = Entity> = {\n entityId: string;\n entityType: string;\n data: T extends keyof EntitySchemaMap ? EntitySchemaMap[T] : never;\n createdAt: string;\n updatedAt: string;\n};\n\n/**\n * @description Configuration for a monorise entity, a shared configuration that is used across frontend and backend.\n * This can be served as a single source of truth for the entity configuration.\n * It is used to define the schema, and mutual relationships between this entity and other entities.\n *\n * @example\n * ```ts\n * const baseSchema = z.object({\n * title: z.string(),\n * }).partial();\n *\n * const createSchema = baseSchema.extend({\n * title: z.string(),\n * })\n *\n * const config = createEntityConfig({\n * name: 'learner',\n * displayName: 'Learner',\n * baseSchema,\n * createSchema,\n * });\n * ```\n */\nexport interface MonoriseEntityConfig<\n T extends Entity = Entity,\n B extends z.ZodRawShape = z.ZodRawShape,\n C extends z.ZodRawShape = z.ZodRawShape,\n M extends z.ZodRawShape = z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n> {\n /**\n * @description Name of the entity. Must be in **lower-kebab-case** and **unique** across all entities\n *\n * @example `learner`, `learning-activity`\n */\n name: string | T;\n\n /**\n * @description Display name of the entity. It is not required to be unique\n */\n displayName: string;\n\n /**\n * @description (DEPRECATED) Use `uniqueFields` instead, Monorise should not handle auth mechanism\n * @description (Optional) Specify the authentication method to be used for the entity\n */\n authMethod?: {\n /**\n * @description Authentication method using email\n *\n * Note: The email used for authentication is unique per entity.\n * For example, if `johndoe@mail.com` is used for `learner` entity,\n * it can be reused again on `admin` entity. However, the same email\n * address cannot be repeated for the same entity.\n */\n email: {\n /**\n * @description Number of milliseconds before the token expires\n */\n tokenExpiresIn: number;\n };\n };\n\n /**\n * @description Base schema for the entity\n */\n baseSchema: z.ZodObject<B>;\n\n /**\n * @description Minimal schema required to create an entity\n */\n createSchema?: CO;\n searchableFields?: (keyof B)[];\n uniqueFields?: (keyof B)[];\n\n /**\n * @description Define mutual relationship of this entity with other entities\n */\n mutual?: {\n /**\n * @description Subscribes to update events from specified entities in the array.\n * These events will be used to run prejoin processor.\n */\n subscribes?: { entityType: Entity }[];\n /**\n * @description Virtual schema for mutual relationship. The schema is only used for validation purpose, but these fields are not stored in the database\n */\n mutualSchema: MO;\n\n /**\n * @description Keys of `mutualFields` are fields defined in `mutualSchema`.\n * Each field is a mutual relationship between this entity and another entity.\n */\n mutualFields: {\n [key: string]: {\n entityType: Entity;\n toMutualIds?: (context: any) => string[];\n /**\n * @description (Optional) Custom function to process `mutualData`. If not provided, `mutualData` will be empty.\n *\n * @returns the final state of `mutualData` to be stored in the mutual record. Must be an object.\n */\n mutualDataProcessor?: (\n mutualIds: string[],\n currentMutual: any,\n customContext?: Record<string, any>,\n ) => Record<string, any>;\n };\n };\n\n /**\n * @description (Optional) Better known as tree processor\n * This is used to prejoin entities that are not directly related as mutual.\n * For example, if `learner` entity is related to `course` entity, and `course` entity is related to `module` entity,\n * prejoins can be used to join `learner` and `module` entities.\n * With this, the `learner` entity can access the `module` entity without having to go through the `course` entity,\n * hence reducing the number of queries.\n *\n * DynamoDB best practices: https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/bp-general-normalization.html\n *\n */\n prejoins?: {\n mutualField: string;\n targetEntityType: Entity;\n entityPaths: {\n skipCache?: boolean;\n entityType: Entity;\n processor?: (items: any[], context: Record<string, any>) => any;\n }[];\n }[];\n };\n /**\n * Use this function to perform side effects on the final schema for example refine/superRefine the schema\n *\n * @param schema The final schema of the entity (the combination of `baseSchema`/`createSchema` and `mutualSchema` if specified)\n * @returns void\n *\n * @example\n * ```ts\n * effect: (schema) => {\n * schema.refine(\n * // refinement logic here\n * )\n * }\n */\n effect?: (\n schema: z.ZodObject<z.ZodRawShape>,\n ) => z.ZodEffects<z.ZodObject<z.ZodRawShape>>;\n\n /**\n * @description (Optional) Use tags to create additional access patterns for the entity.\n * Time complexity for retrieving tagged entities is O(1).\n *\n * The following configuration will create a tag named `region` for the `organization` entity grouped by `region`.\n * You would then be able to retrieve all organizations in a specific region by:\n * GET `/core/tag/organization/region?group={region_name}`\n *\n * @example\n *\n * ```ts\n * {\n * name: 'organization',\n * tags: [\n * {\n * name: 'region',\n * processor: (entity) => {\n * return [\n * {\n * group: entity.data.region\n * }\n * ]\n * },\n * }\n * ]\n * }\n * ```\n *\n * @description\n *\n * The following configuration will create a tag named `dob` for the `user` entity sorted by `dob`.\n * You would then be able to retrieve all users sorted by `dob` by:\n * GET `/core/tag/user/dob?start=2000-01-01&end=2020-12-31`\n *\n * @example\n * ```ts\n * {\n * name: 'user',\n * tags: [\n * {\n * name: 'dob',\n * processor: (entity) => {\n * return [\n * {\n * sortValue: entity.data.dob\n * }\n * ]\n * },\n * }\n * ]\n * }\n * ```\n */\n tags?: {\n name: string;\n processor: (entity: { entityId: string; entityType: string; data: Record<string, any>; createdAt: string; updatedAt: string }) => {\n group?: string;\n sortValue?: string;\n }[];\n }[];\n\n /**\n * @description (Optional) Constraints for `adjustEntity` operations.\n * When adjusting numeric fields, these constraints are enforced at the database level.\n * If an adjustment would violate a constraint, the operation is rejected.\n *\n * @example\n * ```ts\n * {\n * adjustmentConstraints: {\n * // Static: same for all entities of this type\n * balance: { min: 0 },\n * credits: { min: 0, max: 10000 },\n *\n * // Dynamic: reads constraint value from entity's own data\n * balance: { minField: 'minBalance' },\n * credits: { min: 0, maxField: 'creditLimit' },\n * }\n * }\n * ```\n */\n adjustmentConstraints?: {\n [fieldName: string]: {\n /** Static minimum value */\n min?: number;\n /** Static maximum value */\n max?: number;\n /** Field name on the entity whose value is used as the minimum (must be a numeric field) */\n minField?: keyof {\n [K in keyof B as B[K] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K : never]: K;\n };\n /** Field name on the entity whose value is used as the maximum (must be a numeric field) */\n maxField?: keyof {\n [K in keyof B as B[K] extends z.ZodNumber | z.ZodOptional<z.ZodNumber> ? K : never]: K;\n };\n };\n };\n}\n","import type { Entity, MonoriseEntityConfig } from '../types/monorise.type';\nimport { z } from 'zod';\n\nfunction makeSchema<\n T extends Entity,\n B extends z.ZodRawShape,\n C extends z.ZodRawShape,\n M extends z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n>(config: MonoriseEntityConfig<T, B, C, M, CO, MO>) {\n const { baseSchema, createSchema, mutual, effect } = config;\n const { mutualSchema } = mutual || {};\n\n type FinalSchemaType = CO extends z.AnyZodObject\n ? MO extends z.AnyZodObject\n ? z.ZodObject<MO['shape'] & CO['shape']>\n : CO\n : MO extends z.AnyZodObject\n ? z.ZodObject<MO['shape'] & B>\n : z.ZodObject<B>;\n\n const finalSchema = z.object({\n ...baseSchema.shape,\n ...createSchema?.shape,\n ...mutualSchema?.shape,\n }) as FinalSchemaType;\n\n if (effect) {\n return effect(finalSchema) as z.ZodEffects<FinalSchemaType>;\n }\n\n return finalSchema;\n}\n\nconst createEntityConfig = <\n T extends Entity,\n B extends z.ZodRawShape,\n C extends z.ZodRawShape,\n M extends z.ZodRawShape,\n CO extends z.ZodObject<C> | undefined = undefined,\n MO extends z.ZodObject<M> | undefined = undefined,\n>(\n config: MonoriseEntityConfig<T, B, C, M, CO, MO>,\n) => ({\n ...config,\n finalSchema: makeSchema(config),\n});\n\nexport { createEntityConfig };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAEO,IAAK,SAAL,kBAAKA,YAAL;AAAK,SAAAA;AAAA,GAAA;;;ACDZ,SAAS,SAAS;AAElB,SAAS,WAOP,QAAkD;AAClD,QAAM,EAAE,YAAY,cAAc,QAAQ,OAAO,IAAI;AACrD,QAAM,EAAE,aAAa,IAAI,UAAU,CAAC;AAUpC,QAAM,cAAc,EAAE,OAAO,iDACxB,WAAW,QACX,6CAAc,QACd,6CAAc,MAClB;AAED,MAAI,QAAQ;AACV,WAAO,OAAO,WAAW;AAAA,EAC3B;AAEA,SAAO;AACT;AAEA,IAAM,qBAAqB,CAQzB,WACI,iCACD,SADC;AAAA,EAEJ,aAAa,WAAW,MAAM;AAChC;","names":["Entity"]}
|
package/dist/cli/cli.js
CHANGED
|
@@ -3,9 +3,27 @@
|
|
|
3
3
|
// cli.ts
|
|
4
4
|
import "tsx";
|
|
5
5
|
import "tsconfig-paths/register.js";
|
|
6
|
+
import fs2 from "fs";
|
|
7
|
+
import path2 from "path";
|
|
8
|
+
import chokidar from "chokidar";
|
|
9
|
+
|
|
10
|
+
// commands/utils/detect-package.ts
|
|
6
11
|
import fs from "fs";
|
|
7
12
|
import path from "path";
|
|
8
|
-
|
|
13
|
+
function detectCombinedPackage(startDir) {
|
|
14
|
+
let dir = startDir;
|
|
15
|
+
while (true) {
|
|
16
|
+
if (fs.existsSync(path.join(dir, "node_modules", "monorise"))) {
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
const parent = path.dirname(dir);
|
|
20
|
+
if (parent === dir) break;
|
|
21
|
+
dir = parent;
|
|
22
|
+
}
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// cli.ts
|
|
9
27
|
function kebabToCamel(str) {
|
|
10
28
|
return str.replace(/-([a-z])/g, (_, letter) => letter.toUpperCase());
|
|
11
29
|
}
|
|
@@ -13,12 +31,12 @@ function kebabToPascal(kebab) {
|
|
|
13
31
|
return kebab.split("-").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join("");
|
|
14
32
|
}
|
|
15
33
|
async function generateConfigFile(configDir, monoriseOutputDir, projectRoot) {
|
|
16
|
-
const configOutputPath =
|
|
34
|
+
const configOutputPath = path2.join(monoriseOutputDir, "config.ts");
|
|
17
35
|
const initialConfigContent = `
|
|
18
36
|
export enum Entity {}
|
|
19
37
|
`;
|
|
20
|
-
|
|
21
|
-
const files =
|
|
38
|
+
fs2.writeFileSync(configOutputPath, initialConfigContent);
|
|
39
|
+
const files = fs2.readdirSync(configDir).filter((file) => file.endsWith(".ts") && file !== "index.ts");
|
|
22
40
|
const names = /* @__PURE__ */ new Set();
|
|
23
41
|
const nameRegex = /^[a-z]+(-[a-z]+)*$/;
|
|
24
42
|
const imports = [];
|
|
@@ -29,10 +47,10 @@ export enum Entity {}
|
|
|
29
47
|
const schemaEntries = [];
|
|
30
48
|
const allowedEntityEntries = [];
|
|
31
49
|
const entityWithEmailAuthEntries = [];
|
|
32
|
-
const relativePathToConfigDir =
|
|
50
|
+
const relativePathToConfigDir = path2.relative(monoriseOutputDir, configDir);
|
|
33
51
|
const importPathPrefix = relativePathToConfigDir ? `${relativePathToConfigDir}/` : "./";
|
|
34
52
|
for (const file of files) {
|
|
35
|
-
const fullPath =
|
|
53
|
+
const fullPath = path2.join(configDir, file);
|
|
36
54
|
const module = await import(fullPath);
|
|
37
55
|
const config = module.default;
|
|
38
56
|
if (!nameRegex.test(config.name)) {
|
|
@@ -66,8 +84,20 @@ export enum Entity {}
|
|
|
66
84
|
entityWithEmailAuthEntries.push(`Entity.${enumKey}`);
|
|
67
85
|
}
|
|
68
86
|
}
|
|
69
|
-
const usesCombinedPackage =
|
|
70
|
-
const
|
|
87
|
+
const usesCombinedPackage = detectCombinedPackage(projectRoot);
|
|
88
|
+
const augmentationBlock = (moduleName) => `
|
|
89
|
+
declare module '${moduleName}' {
|
|
90
|
+
export enum Entity {
|
|
91
|
+
${enumEntries.join(",\n ")}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
${typeEntries.join("\n ")}
|
|
95
|
+
|
|
96
|
+
export interface EntitySchemaMap {
|
|
97
|
+
${schemaMapEntries.join("\n ")}
|
|
98
|
+
}
|
|
99
|
+
}`;
|
|
100
|
+
const moduleAugmentations = usesCombinedPackage ? augmentationBlock("monorise/base") : augmentationBlock("@monorise/base");
|
|
71
101
|
const configOutputContent = `
|
|
72
102
|
import type { z } from 'zod';
|
|
73
103
|
${imports.join("\n")}
|
|
@@ -111,34 +141,23 @@ const config = {
|
|
|
111
141
|
};
|
|
112
142
|
|
|
113
143
|
export default config;
|
|
114
|
-
|
|
115
|
-
declare module '${baseModuleName}' {
|
|
116
|
-
export enum Entity {
|
|
117
|
-
${enumEntries.join(",\n ")}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
${typeEntries.join("\n ")}
|
|
121
|
-
|
|
122
|
-
export interface EntitySchemaMap {
|
|
123
|
-
${schemaMapEntries.join("\n ")}
|
|
124
|
-
}
|
|
125
|
-
}
|
|
144
|
+
${moduleAugmentations}
|
|
126
145
|
`;
|
|
127
|
-
|
|
146
|
+
fs2.writeFileSync(configOutputPath, configOutputContent);
|
|
128
147
|
console.log("Successfully generated config.ts!");
|
|
129
148
|
return configOutputPath;
|
|
130
149
|
}
|
|
131
150
|
async function generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir) {
|
|
132
|
-
const handleOutputPath =
|
|
151
|
+
const handleOutputPath = path2.join(monoriseOutputDir, "handle.ts");
|
|
133
152
|
const customRoutesPath = monoriseConfig.customRoutes;
|
|
134
153
|
let routesImportLine = "";
|
|
135
154
|
let appHandlerPayload = "{}";
|
|
136
155
|
if (customRoutesPath) {
|
|
137
|
-
const absoluteCustomRoutesPath =
|
|
156
|
+
const absoluteCustomRoutesPath = path2.resolve(
|
|
138
157
|
projectRoot,
|
|
139
158
|
customRoutesPath
|
|
140
159
|
);
|
|
141
|
-
if (!
|
|
160
|
+
if (!fs2.existsSync(absoluteCustomRoutesPath) && !fs2.existsSync(`${absoluteCustomRoutesPath}.ts`) && !fs2.existsSync(`${absoluteCustomRoutesPath}.js`)) {
|
|
142
161
|
throw new Error(
|
|
143
162
|
`Custom routes file not found: '${absoluteCustomRoutesPath}'. Please ensure 'customRoutes' in monorise.config.ts points to a valid file.`
|
|
144
163
|
);
|
|
@@ -157,7 +176,7 @@ async function generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir
|
|
|
157
176
|
`Custom routes file at '${absoluteCustomRoutesPath}' must default export an instance of Hono (or an object with .get, .post, .use methods). Or a function that consume the dependency container provided by route handler.`
|
|
158
177
|
);
|
|
159
178
|
}
|
|
160
|
-
let relativePathToRoutes =
|
|
179
|
+
let relativePathToRoutes = path2.relative(
|
|
161
180
|
monoriseOutputDir,
|
|
162
181
|
absoluteCustomRoutesPath
|
|
163
182
|
);
|
|
@@ -168,7 +187,7 @@ async function generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir
|
|
|
168
187
|
routesImportLine = `import routes from '${relativePathToRoutes}';`;
|
|
169
188
|
appHandlerPayload = "{ routes }";
|
|
170
189
|
}
|
|
171
|
-
const usesCombinedPackage =
|
|
190
|
+
const usesCombinedPackage = detectCombinedPackage(projectRoot);
|
|
172
191
|
const coreImportPath = usesCombinedPackage ? "monorise/core" : "@monorise/core";
|
|
173
192
|
const combinedContent = `
|
|
174
193
|
import CoreFactory from '${coreImportPath}';
|
|
@@ -182,30 +201,30 @@ export const tagHandler = coreFactory.tagProcessor;
|
|
|
182
201
|
export const treeHandler = coreFactory.prejoinProcessor;
|
|
183
202
|
export const appHandler = coreFactory.appHandler(${appHandlerPayload});
|
|
184
203
|
`;
|
|
185
|
-
|
|
204
|
+
fs2.writeFileSync(handleOutputPath, combinedContent);
|
|
186
205
|
console.log("Successfully generated handle.ts!");
|
|
187
206
|
return handleOutputPath;
|
|
188
207
|
}
|
|
189
208
|
async function generateFiles(rootPath) {
|
|
190
|
-
const baseDir = rootPath ?
|
|
191
|
-
const configFilePathTS =
|
|
192
|
-
const configFilePathJS =
|
|
209
|
+
const baseDir = rootPath ? path2.resolve(rootPath) : process.cwd();
|
|
210
|
+
const configFilePathTS = path2.join(baseDir, "monorise.config.ts");
|
|
211
|
+
const configFilePathJS = path2.join(baseDir, "monorise.config.js");
|
|
193
212
|
let configFilePath;
|
|
194
|
-
if (
|
|
213
|
+
if (fs2.existsSync(configFilePathTS)) {
|
|
195
214
|
configFilePath = configFilePathTS;
|
|
196
|
-
} else if (
|
|
215
|
+
} else if (fs2.existsSync(configFilePathJS)) {
|
|
197
216
|
configFilePath = configFilePathJS;
|
|
198
217
|
} else {
|
|
199
218
|
throw new Error(
|
|
200
219
|
"Neither monorise.config.ts nor monorise.config.js found in the root of the project."
|
|
201
220
|
);
|
|
202
221
|
}
|
|
203
|
-
const projectRoot =
|
|
222
|
+
const projectRoot = path2.dirname(configFilePath);
|
|
204
223
|
const monoriseConfigModule = await import(configFilePath);
|
|
205
224
|
const monoriseConfig = monoriseConfigModule.default;
|
|
206
|
-
const configDir =
|
|
207
|
-
const monoriseOutputDir =
|
|
208
|
-
|
|
225
|
+
const configDir = path2.resolve(projectRoot, monoriseConfig.configDir);
|
|
226
|
+
const monoriseOutputDir = path2.join(projectRoot, ".monorise");
|
|
227
|
+
fs2.mkdirSync(monoriseOutputDir, { recursive: true });
|
|
209
228
|
await generateConfigFile(configDir, monoriseOutputDir, projectRoot);
|
|
210
229
|
await generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir);
|
|
211
230
|
return configDir;
|
|
@@ -259,10 +278,10 @@ var MONORISE_LOGO = `
|
|
|
259
278
|
|
|
260
279
|
`;
|
|
261
280
|
async function runInitCommand(rootPath) {
|
|
262
|
-
const projectRoot = rootPath ?
|
|
281
|
+
const projectRoot = rootPath ? path2.resolve(rootPath) : process.cwd();
|
|
263
282
|
console.log(MONORISE_LOGO);
|
|
264
283
|
console.log(`Initializing Monorise project in ${projectRoot}...`);
|
|
265
|
-
const monoriseConfigTsPath =
|
|
284
|
+
const monoriseConfigTsPath = path2.join(projectRoot, "monorise.config.ts");
|
|
266
285
|
const monoriseConfigContent = `
|
|
267
286
|
const config = {
|
|
268
287
|
configDir: './monorise/entities',
|
|
@@ -272,17 +291,17 @@ const config = {
|
|
|
272
291
|
|
|
273
292
|
export default config;
|
|
274
293
|
`;
|
|
275
|
-
if (!
|
|
276
|
-
|
|
277
|
-
console.log(`Created ${
|
|
294
|
+
if (!fs2.existsSync(monoriseConfigTsPath)) {
|
|
295
|
+
fs2.writeFileSync(monoriseConfigTsPath, monoriseConfigContent.trimStart());
|
|
296
|
+
console.log(`Created ${path2.relative(projectRoot, monoriseConfigTsPath)}`);
|
|
278
297
|
} else {
|
|
279
298
|
console.log(
|
|
280
|
-
`${
|
|
299
|
+
`${path2.relative(projectRoot, monoriseConfigTsPath)} already exists. Skipping.`
|
|
281
300
|
);
|
|
282
301
|
}
|
|
283
|
-
const monoriseEntitiesDir =
|
|
284
|
-
|
|
285
|
-
const userEntityTsPath =
|
|
302
|
+
const monoriseEntitiesDir = path2.join(projectRoot, "monorise", "entities");
|
|
303
|
+
fs2.mkdirSync(monoriseEntitiesDir, { recursive: true });
|
|
304
|
+
const userEntityTsPath = path2.join(monoriseEntitiesDir, "user.ts");
|
|
286
305
|
const userEntityContent = `
|
|
287
306
|
import { createEntityConfig } from 'monorise/base';
|
|
288
307
|
import { z } from 'zod';
|
|
@@ -305,45 +324,45 @@ const config = createEntityConfig({
|
|
|
305
324
|
|
|
306
325
|
export default config;
|
|
307
326
|
`;
|
|
308
|
-
if (!
|
|
309
|
-
|
|
310
|
-
console.log(`Created ${
|
|
327
|
+
if (!fs2.existsSync(userEntityTsPath)) {
|
|
328
|
+
fs2.writeFileSync(userEntityTsPath, userEntityContent.trimStart());
|
|
329
|
+
console.log(`Created ${path2.relative(projectRoot, userEntityTsPath)}`);
|
|
311
330
|
} else {
|
|
312
331
|
console.log(
|
|
313
|
-
`${
|
|
332
|
+
`${path2.relative(projectRoot, userEntityTsPath)} already exists. Skipping.`
|
|
314
333
|
);
|
|
315
334
|
}
|
|
316
|
-
const packageJsonPath =
|
|
317
|
-
if (
|
|
335
|
+
const packageJsonPath = path2.join(projectRoot, "package.json");
|
|
336
|
+
if (fs2.existsSync(packageJsonPath)) {
|
|
318
337
|
try {
|
|
319
|
-
const packageJsonContent =
|
|
338
|
+
const packageJsonContent = fs2.readFileSync(packageJsonPath, "utf8");
|
|
320
339
|
const packageJson = JSON.parse(packageJsonContent);
|
|
321
340
|
if (packageJson.type !== "module") {
|
|
322
341
|
packageJson.type = "module";
|
|
323
|
-
|
|
342
|
+
fs2.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2));
|
|
324
343
|
console.log(
|
|
325
|
-
`Updated 'type' to 'module' in ${
|
|
344
|
+
`Updated 'type' to 'module' in ${path2.relative(projectRoot, packageJsonPath)}`
|
|
326
345
|
);
|
|
327
346
|
} else {
|
|
328
347
|
console.log(
|
|
329
|
-
`'type: "module"' already set in ${
|
|
348
|
+
`'type: "module"' already set in ${path2.relative(projectRoot, packageJsonPath)}. Skipping.`
|
|
330
349
|
);
|
|
331
350
|
}
|
|
332
351
|
} catch (error) {
|
|
333
352
|
console.error(
|
|
334
|
-
`Error reading or parsing ${
|
|
353
|
+
`Error reading or parsing ${path2.relative(projectRoot, packageJsonPath)}:`,
|
|
335
354
|
error
|
|
336
355
|
);
|
|
337
356
|
}
|
|
338
357
|
} else {
|
|
339
358
|
console.warn(
|
|
340
|
-
`Warning: ${
|
|
359
|
+
`Warning: ${path2.relative(projectRoot, packageJsonPath)} not found. Cannot update 'type'.`
|
|
341
360
|
);
|
|
342
361
|
}
|
|
343
|
-
const tsconfigPath =
|
|
344
|
-
if (
|
|
362
|
+
const tsconfigPath = path2.join(projectRoot, "tsconfig.json");
|
|
363
|
+
if (fs2.existsSync(tsconfigPath)) {
|
|
345
364
|
try {
|
|
346
|
-
const tsconfigContent =
|
|
365
|
+
const tsconfigContent = fs2.readFileSync(tsconfigPath, "utf8");
|
|
347
366
|
const tsconfig = JSON.parse(tsconfigContent);
|
|
348
367
|
if (!tsconfig.compilerOptions) {
|
|
349
368
|
tsconfig.compilerOptions = {};
|
|
@@ -355,24 +374,24 @@ export default config;
|
|
|
355
374
|
const pathValue = ["./.monorise/*"];
|
|
356
375
|
if (!tsconfig.compilerOptions.paths[pathKey]) {
|
|
357
376
|
tsconfig.compilerOptions.paths[pathKey] = pathValue;
|
|
358
|
-
|
|
377
|
+
fs2.writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2));
|
|
359
378
|
console.log(
|
|
360
|
-
`Added '${pathKey}' path alias in ${
|
|
379
|
+
`Added '${pathKey}' path alias in ${path2.relative(projectRoot, tsconfigPath)}`
|
|
361
380
|
);
|
|
362
381
|
} else {
|
|
363
382
|
console.log(
|
|
364
|
-
`'${pathKey}' path alias already set in ${
|
|
383
|
+
`'${pathKey}' path alias already set in ${path2.relative(projectRoot, tsconfigPath)}. Skipping.`
|
|
365
384
|
);
|
|
366
385
|
}
|
|
367
386
|
} catch (error) {
|
|
368
387
|
console.error(
|
|
369
|
-
`Error updating ${
|
|
388
|
+
`Error updating ${path2.relative(projectRoot, tsconfigPath)}:`,
|
|
370
389
|
error
|
|
371
390
|
);
|
|
372
391
|
}
|
|
373
392
|
} else {
|
|
374
393
|
console.warn(
|
|
375
|
-
`Warning: ${
|
|
394
|
+
`Warning: ${path2.relative(projectRoot, tsconfigPath)} not found. Cannot add path alias.`
|
|
376
395
|
);
|
|
377
396
|
}
|
|
378
397
|
console.log("Monorise initialization complete!");
|
|
@@ -382,7 +401,7 @@ async function runDevCommand(configDir, rootPath) {
|
|
|
382
401
|
console.log(`Watching for changes in ${configDir}...`);
|
|
383
402
|
const watcher = chokidar.watch(configDir, {
|
|
384
403
|
ignored: (watchedPath) => {
|
|
385
|
-
const fileName =
|
|
404
|
+
const fileName = path2.basename(watchedPath);
|
|
386
405
|
return fileName === "index.ts" || // Old name, still ignore in case it exists
|
|
387
406
|
fileName === "config.ts" || // Generated config file
|
|
388
407
|
fileName === "processors.ts" || // Generated processors file
|
package/dist/cli/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../cli.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport 'tsx';\nimport 'tsconfig-paths/register.js';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport chokidar from 'chokidar';\n\nfunction kebabToCamel(str: string): string {\n return str.replace(/-([a-z])/g, (_, letter) => letter.toUpperCase());\n}\n\nfunction kebabToPascal(kebab: string): string {\n return kebab\n .split('-')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1))\n .join('');\n}\n\nasync function generateConfigFile(\n configDir: string,\n monoriseOutputDir: string,\n projectRoot: string,\n): Promise<string> {\n const configOutputPath = path.join(monoriseOutputDir, 'config.ts');\n const initialConfigContent = `\nexport enum Entity {}\n`;\n fs.writeFileSync(configOutputPath, initialConfigContent);\n\n const files = fs\n .readdirSync(configDir)\n .filter((file) => file.endsWith('.ts') && file !== 'index.ts');\n\n const names = new Set<string>();\n const nameRegex = /^[a-z]+(-[a-z]+)*$/;\n const imports: string[] = [];\n\n const enumEntries: string[] = [];\n const typeEntries: string[] = [];\n const schemaMapEntries: string[] = [];\n const configEntries: string[] = [];\n const schemaEntries: string[] = [];\n const allowedEntityEntries: string[] = [];\n const entityWithEmailAuthEntries: string[] = [];\n\n const relativePathToConfigDir = path.relative(monoriseOutputDir, configDir);\n const importPathPrefix = relativePathToConfigDir\n ? `${relativePathToConfigDir}/`\n : './';\n\n for (const file of files) {\n const fullPath = path.join(configDir, file);\n const module = await import(fullPath);\n const config = module.default;\n\n if (!nameRegex.test(config.name)) {\n throw new Error(\n `Invalid name format: ${config.name} in ${file}. Must be kebab-case.`,\n );\n }\n\n if (names.has(config.name)) {\n throw new Error(`Duplicate name found: ${config.name} in ${file}`);\n }\n names.add(config.name);\n\n const fileName = file.replace(/\\.ts$/, '');\n const variableName = kebabToCamel(fileName);\n imports.push(\n `import ${variableName} from '${importPathPrefix}${fileName}';`,\n );\n\n const enumKey = config.name.toUpperCase().replace(/-/g, '_');\n enumEntries.push(`${enumKey} = '${config.name}'`);\n typeEntries.push(\n `export type ${kebabToPascal(config.name)}Type = z.infer<(typeof ${variableName})['finalSchema']>;`,\n );\n schemaMapEntries.push(\n `[Entity.${enumKey}]: ${kebabToPascal(config.name)}Type;`,\n );\n\n configEntries.push(`[Entity.${enumKey}]: ${kebabToCamel(config.name)},`);\n schemaEntries.push(\n `[Entity.${enumKey}]: ${kebabToCamel(config.name)}.finalSchema,`,\n );\n\n allowedEntityEntries.push(`Entity.${enumKey}`);\n\n if (config.authMethod?.email) {\n entityWithEmailAuthEntries.push(`Entity.${enumKey}`);\n }\n }\n\n // Detect whether the consumer uses the combined 'monorise' package or scoped '@monorise/*' packages\n const usesCombinedPackage = fs.existsSync(path.join(projectRoot, 'node_modules', 'monorise'));\n const baseModuleName = usesCombinedPackage ? 'monorise/base' : '@monorise/base';\n\n const configOutputContent = `\nimport type { z } from 'zod';\n${imports.join('\\n')}\n\nexport enum Entity {\n ${enumEntries.join(',\\n ')}\n}\n\n${typeEntries.join('\\n')}\n\nexport interface EntitySchemaMap {\n ${schemaMapEntries.join('\\n ')}\n}\n\nconst EntityConfig = {\n ${configEntries.join('\\n ')}\n};\n\nconst FormSchema = {\n ${schemaEntries.join('\\n ')}\n};\n\nconst AllowedEntityTypes = [\n ${allowedEntityEntries.join(',\\n ')}\n];\n\nconst EmailAuthEnabledEntities: Entity[] = [${entityWithEmailAuthEntries.join(', ')}];\n\nexport {\n EntityConfig,\n FormSchema,\n AllowedEntityTypes,\n EmailAuthEnabledEntities,\n};\n\nconst config = {\n EntityConfig,\n FormSchema,\n AllowedEntityTypes,\n EmailAuthEnabledEntities,\n};\n\nexport default config;\n\ndeclare module '${baseModuleName}' {\n export enum Entity {\n ${enumEntries.join(',\\n ')}\n }\n\n ${typeEntries.join('\\n ')}\n\n export interface EntitySchemaMap {\n ${schemaMapEntries.join('\\n ')}\n }\n}\n`;\n\n fs.writeFileSync(configOutputPath, configOutputContent);\n console.log('Successfully generated config.ts!');\n return configOutputPath;\n}\n\nasync function generateHandleFile(\n monoriseConfig: { customRoutes?: string; configDir: string },\n projectRoot: string,\n monoriseOutputDir: string,\n): Promise<string> {\n const handleOutputPath = path.join(monoriseOutputDir, 'handle.ts');\n const customRoutesPath = monoriseConfig.customRoutes;\n\n let routesImportLine = '';\n let appHandlerPayload = '{}'; // Default to an empty object for appHandler if no custom routes\n\n if (customRoutesPath) {\n const absoluteCustomRoutesPath = path.resolve(\n projectRoot,\n customRoutesPath,\n );\n\n if (\n !fs.existsSync(absoluteCustomRoutesPath) &&\n !fs.existsSync(`${absoluteCustomRoutesPath}.ts`) &&\n !fs.existsSync(`${absoluteCustomRoutesPath}.js`)\n ) {\n throw new Error(\n `Custom routes file not found: '${absoluteCustomRoutesPath}'. Please ensure 'customRoutes' in monorise.config.ts points to a valid file.`,\n );\n }\n\n let routesModule;\n try {\n routesModule = await import(absoluteCustomRoutesPath);\n } catch (e: any) {\n throw new Error(\n `Failed to load custom routes file at '${absoluteCustomRoutesPath}'. Ensure it's a valid JavaScript/TypeScript module. Error: ${e.message}`,\n );\n }\n\n const routesExport = routesModule.default;\n\n if (\n !routesExport ||\n routesExport === null ||\n (typeof routesExport === 'object' &&\n !(\n 'get' in routesExport &&\n 'post' in routesExport &&\n 'use' in routesExport\n ))\n ) {\n throw new Error(\n `Custom routes file at '${absoluteCustomRoutesPath}' must default export an instance of Hono (or an object with .get, .post, .use methods). Or a function that consume the dependency container provided by route handler.`,\n );\n }\n\n let relativePathToRoutes = path.relative(\n monoriseOutputDir,\n absoluteCustomRoutesPath,\n );\n relativePathToRoutes = relativePathToRoutes.replace(\n /\\.(ts|js|mjs|cjs)$/,\n '',\n );\n\n // If custom routes are provided, include the import statement and pass 'routes' to appHandler\n routesImportLine = `import routes from '${relativePathToRoutes}';`;\n appHandlerPayload = '{ routes }';\n }\n // If customRoutesPath is not provided, routesImportLine remains empty and appHandlerPayload remains `{}`\n\n // Detect whether the consumer uses the combined 'monorise' package or scoped '@monorise/*' packages\n const usesCombinedPackage = fs.existsSync(path.join(projectRoot, 'node_modules', 'monorise'));\n const coreImportPath = usesCombinedPackage ? 'monorise/core' : '@monorise/core';\n\n const combinedContent = `\nimport CoreFactory from '${coreImportPath}';\nimport config from './config';\n${routesImportLine ? `${routesImportLine}\\n` : ''}const coreFactory = new CoreFactory(config);\n\nexport const replicationHandler = coreFactory.replicationProcessor;\nexport const mutualHandler = coreFactory.mutualProcessor;\nexport const tagHandler = coreFactory.tagProcessor;\nexport const treeHandler = coreFactory.prejoinProcessor;\nexport const appHandler = coreFactory.appHandler(${appHandlerPayload});\n`;\n fs.writeFileSync(handleOutputPath, combinedContent);\n console.log('Successfully generated handle.ts!');\n\n return handleOutputPath;\n}\n\nasync function generateFiles(rootPath?: string): Promise<string> {\n const baseDir = rootPath ? path.resolve(rootPath) : process.cwd();\n const configFilePathTS = path.join(baseDir, 'monorise.config.ts');\n const configFilePathJS = path.join(baseDir, 'monorise.config.js');\n\n let configFilePath: string;\n if (fs.existsSync(configFilePathTS)) {\n configFilePath = configFilePathTS;\n } else if (fs.existsSync(configFilePathJS)) {\n configFilePath = configFilePathJS;\n } else {\n throw new Error(\n 'Neither monorise.config.ts nor monorise.config.js found in the root of the project.',\n );\n }\n\n const projectRoot = path.dirname(configFilePath);\n const monoriseConfigModule = await import(configFilePath);\n const monoriseConfig = monoriseConfigModule.default;\n\n const configDir = path.resolve(projectRoot, monoriseConfig.configDir);\n const monoriseOutputDir = path.join(projectRoot, '.monorise');\n\n fs.mkdirSync(monoriseOutputDir, { recursive: true });\n\n await generateConfigFile(configDir, monoriseOutputDir, projectRoot);\n await generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir);\n\n return configDir;\n}\n\nconst MONORISE_LOGO = `\n\n\n\n ░░░░░░░\n ░░▒▒▒░░░░░░▒▒▒░\n ░▒▒░ ░▒▒░\n ░▒▒░ ░▒▒░\n ░▒░ ░▒▒░\n ░▒▒░ ▒▒▒░\n ░▒░░░▒░ ░▒░░▒▒░\n ░▒▒░ ░▒▒▒░ ░▒▒░ ░▒░░\n ░▒▒ ░▒▒░ ░▒▒░ ░▒░ ░▒░ ░▒░\n ░▒▒░ ░▒░ ░▒░░▒▒░░░ ░░▒▒░░▒░ ░▒▒ ░▒░\n ░░▒░ ░▒░ ░▒░ ░▒▒░░▒▒▒▒▒▒░░▒░ ░▒░░ ░▒░ ░▒░\n ░▒░ ░░▒░ ░▒░ ░░░ ░▒░ ░░ ░▒░ ░▒░ ░▒░░ ░░▒░\n ░▒░ ░▒░ ░▒░ ░▒ ░░ ░▒░ ░▒░ ░▒░ ░▒░ ░░░░\n ░░░ ░░░░ ░░░ ░░ ▒░ ░░░ ░░░ ░░░ ░░░ ░░░░\n ░░░ ░░░░ ░░░ ░░░ ░░░ ░░ ░░░ ░░░ ░░░ ░░░░\n ░░░ ░░░ ░░░ ░░░ ░░ ░░ ░░░ ░░░ ░░░ ░░░\n ░░░ ░░░░ ░░░ ░░░ ░░ ░░░ ░░ ░░░ ░░░ ░░░\n ░░ ░░░ ░░░ ░░░ ░░░ ░░ ░░░ ░░░ ░░░ ░░░\n ░░ ░░ ░░ ░░ ░░ ░░░ ░░░ ░░░ ░░░░ ░░░\n ░░░ ░░ ░░░ ░░░ ░░░\n ░░░░░▒░░░░░░░░░▒░░░░░░░░░ ░ ░░ ░░░ ░░░ ░░\n ░░░ ░░░░░░░░░ ░░░ ░░░\n ░░░ ░░░░░░ ░░ ░░░░░▒░░░░░░▒░░░░\n ░░░░░░░░░░░░░░░░░ ░░░░░ ░░░░░░░░ ░░\n ░░░░░░░ ░░░░░░░░░░░░░░ ░░░░ ░░░░░ ░▒░\n ░░░ ░░░░░░░ ░░░░░░ ░░░░░░░░\n ░░░░░░░░░░░░ ░░░░░░ ░░░░ ░░░░░░░░░░░░░\n ░▒▒░░░░░░░░░░░▒▒░░ ░░▒▒▒░░ ░▒▒░░ ░░░░\n ░▒░ ░░▒▒░ ░▒░ ░▒▒░ ░░▒░\n ░▒░ ░░░░▒▒▒▒▒▒▒▒▒▒░░ ░▒░ ▒▒░ ░░▒▒▒░\n ░▒▒▒▒▒░░░ ░░░▒▒▒▒▒░ ▒▒░ ░▒▒▒▒▒▒░\n ░▒▒░ ░▒▒▒▒ ▒▒▒ ▒▒▒\n ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░░ ░▒▒▒▒▒░ ░▒▒\n ▒▒▒ ░░▒▒▒▒▒▒░ ▒▒▒ ░▒▒\n ▒▒▒ ░▒▒▒▒ ░▒▒▒░\n ▒▓▓▓▒▒▒▓▓▒▒▒░ ▒▒▒░░▒▒░\n ▒▓░ ░▒▒▓▓▒░ ▒▓▓░\n ░▒▓░ ░▒▓▒░▒▓▒\n ░▒▓▒░ ░▒▓▓▒\n ░▒▒▓▓▓▓▓▓▒▒░\n\n\n\n`;\n\nasync function runInitCommand(rootPath?: string) {\n const projectRoot = rootPath ? path.resolve(rootPath) : process.cwd();\n console.log(MONORISE_LOGO);\n console.log(`Initializing Monorise project in ${projectRoot}...`);\n\n // 1. Create monorise.config.ts\n const monoriseConfigTsPath = path.join(projectRoot, 'monorise.config.ts');\n const monoriseConfigContent = `\nconst config = {\n configDir: './monorise/entities',\n // custom route file should export default an Hono object.\n // customRoutes: './path/to/custom/routes.ts'\n};\n\nexport default config;\n`;\n if (!fs.existsSync(monoriseConfigTsPath)) {\n fs.writeFileSync(monoriseConfigTsPath, monoriseConfigContent.trimStart());\n console.log(`Created ${path.relative(projectRoot, monoriseConfigTsPath)}`);\n } else {\n console.log(\n `${path.relative(projectRoot, monoriseConfigTsPath)} already exists. Skipping.`,\n );\n }\n\n // 2. Create ./monorise/entities/user.ts\n const monoriseEntitiesDir = path.join(projectRoot, 'monorise', 'entities');\n fs.mkdirSync(monoriseEntitiesDir, { recursive: true });\n\n const userEntityTsPath = path.join(monoriseEntitiesDir, 'user.ts');\n const userEntityContent = `\nimport { createEntityConfig } from 'monorise/base';\nimport { z } from 'zod';\n\nconst baseSchema = z\n .object({\n displayName: z\n .string()\n .min(1, 'Please provide a name for this user account'),\n firstName: z.string().min(1, 'Please provide first name'),\n lastName: z.string().min(1, 'Please provide last name'),\n jobTitle: z.string(),\n })\n .partial();\n\nconst config = createEntityConfig({\n name: 'user',\n baseSchema,\n});\n\nexport default config;\n`;\n if (!fs.existsSync(userEntityTsPath)) {\n fs.writeFileSync(userEntityTsPath, userEntityContent.trimStart());\n console.log(`Created ${path.relative(projectRoot, userEntityTsPath)}`);\n } else {\n console.log(\n `${path.relative(projectRoot, userEntityTsPath)} already exists. Skipping.`,\n );\n }\n\n // 3. Update package.json\n const packageJsonPath = path.join(projectRoot, 'package.json');\n if (fs.existsSync(packageJsonPath)) {\n try {\n const packageJsonContent = fs.readFileSync(packageJsonPath, 'utf8');\n const packageJson = JSON.parse(packageJsonContent);\n\n if (packageJson.type !== 'module') {\n packageJson.type = 'module';\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2));\n console.log(\n `Updated 'type' to 'module' in ${path.relative(projectRoot, packageJsonPath)}`,\n );\n } else {\n console.log(\n `'type: \"module\"' already set in ${path.relative(projectRoot, packageJsonPath)}. Skipping.`,\n );\n }\n } catch (error) {\n console.error(\n `Error reading or parsing ${path.relative(projectRoot, packageJsonPath)}:`,\n error,\n );\n }\n } else {\n console.warn(\n `Warning: ${path.relative(projectRoot, packageJsonPath)} not found. Cannot update 'type'.`,\n );\n }\n\n // 4. Add tsconfig path alias for .monorise directory\n const tsconfigPath = path.join(projectRoot, 'tsconfig.json');\n if (fs.existsSync(tsconfigPath)) {\n try {\n const tsconfigContent = fs.readFileSync(tsconfigPath, 'utf8');\n const tsconfig = JSON.parse(tsconfigContent);\n\n if (!tsconfig.compilerOptions) {\n tsconfig.compilerOptions = {};\n }\n if (!tsconfig.compilerOptions.paths) {\n tsconfig.compilerOptions.paths = {};\n }\n\n const pathKey = '#/monorise/*';\n const pathValue = ['./.monorise/*'];\n\n if (!tsconfig.compilerOptions.paths[pathKey]) {\n tsconfig.compilerOptions.paths[pathKey] = pathValue;\n fs.writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2));\n console.log(\n `Added '${pathKey}' path alias in ${path.relative(projectRoot, tsconfigPath)}`,\n );\n } else {\n console.log(\n `'${pathKey}' path alias already set in ${path.relative(projectRoot, tsconfigPath)}. Skipping.`,\n );\n }\n } catch (error) {\n console.error(\n `Error updating ${path.relative(projectRoot, tsconfigPath)}:`,\n error,\n );\n }\n } else {\n console.warn(\n `Warning: ${path.relative(projectRoot, tsconfigPath)} not found. Cannot add path alias.`,\n );\n }\n\n console.log('Monorise initialization complete!');\n}\n\nasync function runDevCommand(configDir: string, rootPath?: string) {\n console.log(MONORISE_LOGO);\n console.log(`Watching for changes in ${configDir}...`);\n const watcher = chokidar.watch(configDir, {\n ignored: (watchedPath: string) => {\n const fileName = path.basename(watchedPath);\n return (\n fileName === 'index.ts' || // Old name, still ignore in case it exists\n fileName === 'config.ts' || // Generated config file\n fileName === 'processors.ts' || // Generated processors file\n fileName === 'app.ts' || // Generated app file\n fileName.startsWith('.') ||\n watchedPath.endsWith('.js') ||\n watchedPath.endsWith('.jsx') ||\n watchedPath.endsWith('.d.ts')\n );\n },\n persistent: true,\n ignoreInitial: true,\n });\n\n watcher.on('add', async (filePath) => {\n console.log(`File ${filePath} has been added. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n watcher.on('change', async (filePath) => {\n console.log(`File ${filePath} has been changed. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n watcher.on('unlink', async (filePath) => {\n console.log(`File ${filePath} has been removed. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('Monorise dev terminated. Closing watcher and sst dev...');\n watcher.close();\n process.exit(0);\n });\n process.on('SIGTERM', () => {\n console.log('Monorise dev terminated. Closing watcher and sst dev...');\n watcher.close();\n process.exit(0);\n });\n}\n\nasync function runBuildCommand(rootPath?: string) {\n console.log('Starting sst build...');\n await generateFiles(rootPath);\n}\n\nasync function main() {\n const args = process.argv.slice(2);\n const command = args[0];\n\n let rootPath: string | undefined;\n const rootFlagIndex = args.indexOf('--config-root');\n if (rootFlagIndex > -1 && args[rootFlagIndex + 1]) {\n rootPath = args[rootFlagIndex + 1];\n }\n\n try {\n if (command === 'dev') {\n const configDir = await generateFiles(rootPath);\n await runDevCommand(configDir, rootPath);\n } else if (command === 'build') {\n await runBuildCommand(rootPath);\n } else if (command === 'init') {\n await runInitCommand(rootPath);\n } else {\n console.error(\n 'Unknown command. Usage: monorise [dev|build|init] [--config-root <path>]',\n );\n process.exit(1);\n }\n } catch (err) {\n console.error('Monorise process failed:', err);\n process.exit(1);\n }\n}\n\nmain().catch((err) => {\n console.error('Monorise encountered an unhandled error:', err);\n process.exit(1);\n});\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../cli.ts","../commands/utils/detect-package.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport 'tsx';\nimport 'tsconfig-paths/register.js';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport chokidar from 'chokidar';\nimport { detectCombinedPackage } from './commands/utils/detect-package';\n\nfunction kebabToCamel(str: string): string {\n return str.replace(/-([a-z])/g, (_, letter) => letter.toUpperCase());\n}\n\nfunction kebabToPascal(kebab: string): string {\n return kebab\n .split('-')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1))\n .join('');\n}\n\nasync function generateConfigFile(\n configDir: string,\n monoriseOutputDir: string,\n projectRoot: string,\n): Promise<string> {\n const configOutputPath = path.join(monoriseOutputDir, 'config.ts');\n const initialConfigContent = `\nexport enum Entity {}\n`;\n fs.writeFileSync(configOutputPath, initialConfigContent);\n\n const files = fs\n .readdirSync(configDir)\n .filter((file) => file.endsWith('.ts') && file !== 'index.ts');\n\n const names = new Set<string>();\n const nameRegex = /^[a-z]+(-[a-z]+)*$/;\n const imports: string[] = [];\n\n const enumEntries: string[] = [];\n const typeEntries: string[] = [];\n const schemaMapEntries: string[] = [];\n const configEntries: string[] = [];\n const schemaEntries: string[] = [];\n const allowedEntityEntries: string[] = [];\n const entityWithEmailAuthEntries: string[] = [];\n\n const relativePathToConfigDir = path.relative(monoriseOutputDir, configDir);\n const importPathPrefix = relativePathToConfigDir\n ? `${relativePathToConfigDir}/`\n : './';\n\n for (const file of files) {\n const fullPath = path.join(configDir, file);\n const module = await import(fullPath);\n const config = module.default;\n\n if (!nameRegex.test(config.name)) {\n throw new Error(\n `Invalid name format: ${config.name} in ${file}. Must be kebab-case.`,\n );\n }\n\n if (names.has(config.name)) {\n throw new Error(`Duplicate name found: ${config.name} in ${file}`);\n }\n names.add(config.name);\n\n const fileName = file.replace(/\\.ts$/, '');\n const variableName = kebabToCamel(fileName);\n imports.push(\n `import ${variableName} from '${importPathPrefix}${fileName}';`,\n );\n\n const enumKey = config.name.toUpperCase().replace(/-/g, '_');\n enumEntries.push(`${enumKey} = '${config.name}'`);\n typeEntries.push(\n `export type ${kebabToPascal(config.name)}Type = z.infer<(typeof ${variableName})['finalSchema']>;`,\n );\n schemaMapEntries.push(\n `[Entity.${enumKey}]: ${kebabToPascal(config.name)}Type;`,\n );\n\n configEntries.push(`[Entity.${enumKey}]: ${kebabToCamel(config.name)},`);\n schemaEntries.push(\n `[Entity.${enumKey}]: ${kebabToCamel(config.name)}.finalSchema,`,\n );\n\n allowedEntityEntries.push(`Entity.${enumKey}`);\n\n if (config.authMethod?.email) {\n entityWithEmailAuthEntries.push(`Entity.${enumKey}`);\n }\n }\n\n // Detect whether the consumer uses the combined 'monorise' package or scoped '@monorise/*' packages\n const usesCombinedPackage = detectCombinedPackage(projectRoot);\n\n // Build module augmentation block\n const augmentationBlock = (moduleName: string) => `\ndeclare module '${moduleName}' {\n export enum Entity {\n ${enumEntries.join(',\\n ')}\n }\n\n ${typeEntries.join('\\n ')}\n\n export interface EntitySchemaMap {\n ${schemaMapEntries.join('\\n ')}\n }\n}`;\n\n // Augment the correct module based on which package is installed\n const moduleAugmentations = usesCombinedPackage\n ? augmentationBlock('monorise/base')\n : augmentationBlock('@monorise/base');\n\n const configOutputContent = `\nimport type { z } from 'zod';\n${imports.join('\\n')}\n\nexport enum Entity {\n ${enumEntries.join(',\\n ')}\n}\n\n${typeEntries.join('\\n')}\n\nexport interface EntitySchemaMap {\n ${schemaMapEntries.join('\\n ')}\n}\n\nconst EntityConfig = {\n ${configEntries.join('\\n ')}\n};\n\nconst FormSchema = {\n ${schemaEntries.join('\\n ')}\n};\n\nconst AllowedEntityTypes = [\n ${allowedEntityEntries.join(',\\n ')}\n];\n\nconst EmailAuthEnabledEntities: Entity[] = [${entityWithEmailAuthEntries.join(', ')}];\n\nexport {\n EntityConfig,\n FormSchema,\n AllowedEntityTypes,\n EmailAuthEnabledEntities,\n};\n\nconst config = {\n EntityConfig,\n FormSchema,\n AllowedEntityTypes,\n EmailAuthEnabledEntities,\n};\n\nexport default config;\n${moduleAugmentations}\n`;\n\n fs.writeFileSync(configOutputPath, configOutputContent);\n console.log('Successfully generated config.ts!');\n return configOutputPath;\n}\n\nasync function generateHandleFile(\n monoriseConfig: { customRoutes?: string; configDir: string },\n projectRoot: string,\n monoriseOutputDir: string,\n): Promise<string> {\n const handleOutputPath = path.join(monoriseOutputDir, 'handle.ts');\n const customRoutesPath = monoriseConfig.customRoutes;\n\n let routesImportLine = '';\n let appHandlerPayload = '{}'; // Default to an empty object for appHandler if no custom routes\n\n if (customRoutesPath) {\n const absoluteCustomRoutesPath = path.resolve(\n projectRoot,\n customRoutesPath,\n );\n\n if (\n !fs.existsSync(absoluteCustomRoutesPath) &&\n !fs.existsSync(`${absoluteCustomRoutesPath}.ts`) &&\n !fs.existsSync(`${absoluteCustomRoutesPath}.js`)\n ) {\n throw new Error(\n `Custom routes file not found: '${absoluteCustomRoutesPath}'. Please ensure 'customRoutes' in monorise.config.ts points to a valid file.`,\n );\n }\n\n let routesModule;\n try {\n routesModule = await import(absoluteCustomRoutesPath);\n } catch (e: any) {\n throw new Error(\n `Failed to load custom routes file at '${absoluteCustomRoutesPath}'. Ensure it's a valid JavaScript/TypeScript module. Error: ${e.message}`,\n );\n }\n\n const routesExport = routesModule.default;\n\n if (\n !routesExport ||\n routesExport === null ||\n (typeof routesExport === 'object' &&\n !(\n 'get' in routesExport &&\n 'post' in routesExport &&\n 'use' in routesExport\n ))\n ) {\n throw new Error(\n `Custom routes file at '${absoluteCustomRoutesPath}' must default export an instance of Hono (or an object with .get, .post, .use methods). Or a function that consume the dependency container provided by route handler.`,\n );\n }\n\n let relativePathToRoutes = path.relative(\n monoriseOutputDir,\n absoluteCustomRoutesPath,\n );\n relativePathToRoutes = relativePathToRoutes.replace(\n /\\.(ts|js|mjs|cjs)$/,\n '',\n );\n\n // If custom routes are provided, include the import statement and pass 'routes' to appHandler\n routesImportLine = `import routes from '${relativePathToRoutes}';`;\n appHandlerPayload = '{ routes }';\n }\n // If customRoutesPath is not provided, routesImportLine remains empty and appHandlerPayload remains `{}`\n\n // Detect whether the consumer uses the combined 'monorise' package or scoped '@monorise/*' packages\n const usesCombinedPackage = detectCombinedPackage(projectRoot);\n const coreImportPath = usesCombinedPackage ? 'monorise/core' : '@monorise/core';\n\n const combinedContent = `\nimport CoreFactory from '${coreImportPath}';\nimport config from './config';\n${routesImportLine ? `${routesImportLine}\\n` : ''}const coreFactory = new CoreFactory(config);\n\nexport const replicationHandler = coreFactory.replicationProcessor;\nexport const mutualHandler = coreFactory.mutualProcessor;\nexport const tagHandler = coreFactory.tagProcessor;\nexport const treeHandler = coreFactory.prejoinProcessor;\nexport const appHandler = coreFactory.appHandler(${appHandlerPayload});\n`;\n fs.writeFileSync(handleOutputPath, combinedContent);\n console.log('Successfully generated handle.ts!');\n\n return handleOutputPath;\n}\n\nasync function generateFiles(rootPath?: string): Promise<string> {\n const baseDir = rootPath ? path.resolve(rootPath) : process.cwd();\n const configFilePathTS = path.join(baseDir, 'monorise.config.ts');\n const configFilePathJS = path.join(baseDir, 'monorise.config.js');\n\n let configFilePath: string;\n if (fs.existsSync(configFilePathTS)) {\n configFilePath = configFilePathTS;\n } else if (fs.existsSync(configFilePathJS)) {\n configFilePath = configFilePathJS;\n } else {\n throw new Error(\n 'Neither monorise.config.ts nor monorise.config.js found in the root of the project.',\n );\n }\n\n const projectRoot = path.dirname(configFilePath);\n const monoriseConfigModule = await import(configFilePath);\n const monoriseConfig = monoriseConfigModule.default;\n\n const configDir = path.resolve(projectRoot, monoriseConfig.configDir);\n const monoriseOutputDir = path.join(projectRoot, '.monorise');\n\n fs.mkdirSync(monoriseOutputDir, { recursive: true });\n\n await generateConfigFile(configDir, monoriseOutputDir, projectRoot);\n await generateHandleFile(monoriseConfig, projectRoot, monoriseOutputDir);\n\n return configDir;\n}\n\nconst MONORISE_LOGO = `\n\n\n\n ░░░░░░░\n ░░▒▒▒░░░░░░▒▒▒░\n ░▒▒░ ░▒▒░\n ░▒▒░ ░▒▒░\n ░▒░ ░▒▒░\n ░▒▒░ ▒▒▒░\n ░▒░░░▒░ ░▒░░▒▒░\n ░▒▒░ ░▒▒▒░ ░▒▒░ ░▒░░\n ░▒▒ ░▒▒░ ░▒▒░ ░▒░ ░▒░ ░▒░\n ░▒▒░ ░▒░ ░▒░░▒▒░░░ ░░▒▒░░▒░ ░▒▒ ░▒░\n ░░▒░ ░▒░ ░▒░ ░▒▒░░▒▒▒▒▒▒░░▒░ ░▒░░ ░▒░ ░▒░\n ░▒░ ░░▒░ ░▒░ ░░░ ░▒░ ░░ ░▒░ ░▒░ ░▒░░ ░░▒░\n ░▒░ ░▒░ ░▒░ ░▒ ░░ ░▒░ ░▒░ ░▒░ ░▒░ ░░░░\n ░░░ ░░░░ ░░░ ░░ ▒░ ░░░ ░░░ ░░░ ░░░ ░░░░\n ░░░ ░░░░ ░░░ ░░░ ░░░ ░░ ░░░ ░░░ ░░░ ░░░░\n ░░░ ░░░ ░░░ ░░░ ░░ ░░ ░░░ ░░░ ░░░ ░░░\n ░░░ ░░░░ ░░░ ░░░ ░░ ░░░ ░░ ░░░ ░░░ ░░░\n ░░ ░░░ ░░░ ░░░ ░░░ ░░ ░░░ ░░░ ░░░ ░░░\n ░░ ░░ ░░ ░░ ░░ ░░░ ░░░ ░░░ ░░░░ ░░░\n ░░░ ░░ ░░░ ░░░ ░░░\n ░░░░░▒░░░░░░░░░▒░░░░░░░░░ ░ ░░ ░░░ ░░░ ░░\n ░░░ ░░░░░░░░░ ░░░ ░░░\n ░░░ ░░░░░░ ░░ ░░░░░▒░░░░░░▒░░░░\n ░░░░░░░░░░░░░░░░░ ░░░░░ ░░░░░░░░ ░░\n ░░░░░░░ ░░░░░░░░░░░░░░ ░░░░ ░░░░░ ░▒░\n ░░░ ░░░░░░░ ░░░░░░ ░░░░░░░░\n ░░░░░░░░░░░░ ░░░░░░ ░░░░ ░░░░░░░░░░░░░\n ░▒▒░░░░░░░░░░░▒▒░░ ░░▒▒▒░░ ░▒▒░░ ░░░░\n ░▒░ ░░▒▒░ ░▒░ ░▒▒░ ░░▒░\n ░▒░ ░░░░▒▒▒▒▒▒▒▒▒▒░░ ░▒░ ▒▒░ ░░▒▒▒░\n ░▒▒▒▒▒░░░ ░░░▒▒▒▒▒░ ▒▒░ ░▒▒▒▒▒▒░\n ░▒▒░ ░▒▒▒▒ ▒▒▒ ▒▒▒\n ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░░ ░▒▒▒▒▒░ ░▒▒\n ▒▒▒ ░░▒▒▒▒▒▒░ ▒▒▒ ░▒▒\n ▒▒▒ ░▒▒▒▒ ░▒▒▒░\n ▒▓▓▓▒▒▒▓▓▒▒▒░ ▒▒▒░░▒▒░\n ▒▓░ ░▒▒▓▓▒░ ▒▓▓░\n ░▒▓░ ░▒▓▒░▒▓▒\n ░▒▓▒░ ░▒▓▓▒\n ░▒▒▓▓▓▓▓▓▒▒░\n\n\n\n`;\n\nasync function runInitCommand(rootPath?: string) {\n const projectRoot = rootPath ? path.resolve(rootPath) : process.cwd();\n console.log(MONORISE_LOGO);\n console.log(`Initializing Monorise project in ${projectRoot}...`);\n\n // 1. Create monorise.config.ts\n const monoriseConfigTsPath = path.join(projectRoot, 'monorise.config.ts');\n const monoriseConfigContent = `\nconst config = {\n configDir: './monorise/entities',\n // custom route file should export default an Hono object.\n // customRoutes: './path/to/custom/routes.ts'\n};\n\nexport default config;\n`;\n if (!fs.existsSync(monoriseConfigTsPath)) {\n fs.writeFileSync(monoriseConfigTsPath, monoriseConfigContent.trimStart());\n console.log(`Created ${path.relative(projectRoot, monoriseConfigTsPath)}`);\n } else {\n console.log(\n `${path.relative(projectRoot, monoriseConfigTsPath)} already exists. Skipping.`,\n );\n }\n\n // 2. Create ./monorise/entities/user.ts\n const monoriseEntitiesDir = path.join(projectRoot, 'monorise', 'entities');\n fs.mkdirSync(monoriseEntitiesDir, { recursive: true });\n\n const userEntityTsPath = path.join(monoriseEntitiesDir, 'user.ts');\n const userEntityContent = `\nimport { createEntityConfig } from 'monorise/base';\nimport { z } from 'zod';\n\nconst baseSchema = z\n .object({\n displayName: z\n .string()\n .min(1, 'Please provide a name for this user account'),\n firstName: z.string().min(1, 'Please provide first name'),\n lastName: z.string().min(1, 'Please provide last name'),\n jobTitle: z.string(),\n })\n .partial();\n\nconst config = createEntityConfig({\n name: 'user',\n baseSchema,\n});\n\nexport default config;\n`;\n if (!fs.existsSync(userEntityTsPath)) {\n fs.writeFileSync(userEntityTsPath, userEntityContent.trimStart());\n console.log(`Created ${path.relative(projectRoot, userEntityTsPath)}`);\n } else {\n console.log(\n `${path.relative(projectRoot, userEntityTsPath)} already exists. Skipping.`,\n );\n }\n\n // 3. Update package.json\n const packageJsonPath = path.join(projectRoot, 'package.json');\n if (fs.existsSync(packageJsonPath)) {\n try {\n const packageJsonContent = fs.readFileSync(packageJsonPath, 'utf8');\n const packageJson = JSON.parse(packageJsonContent);\n\n if (packageJson.type !== 'module') {\n packageJson.type = 'module';\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2));\n console.log(\n `Updated 'type' to 'module' in ${path.relative(projectRoot, packageJsonPath)}`,\n );\n } else {\n console.log(\n `'type: \"module\"' already set in ${path.relative(projectRoot, packageJsonPath)}. Skipping.`,\n );\n }\n } catch (error) {\n console.error(\n `Error reading or parsing ${path.relative(projectRoot, packageJsonPath)}:`,\n error,\n );\n }\n } else {\n console.warn(\n `Warning: ${path.relative(projectRoot, packageJsonPath)} not found. Cannot update 'type'.`,\n );\n }\n\n // 4. Add tsconfig path alias for .monorise directory\n const tsconfigPath = path.join(projectRoot, 'tsconfig.json');\n if (fs.existsSync(tsconfigPath)) {\n try {\n const tsconfigContent = fs.readFileSync(tsconfigPath, 'utf8');\n const tsconfig = JSON.parse(tsconfigContent);\n\n if (!tsconfig.compilerOptions) {\n tsconfig.compilerOptions = {};\n }\n if (!tsconfig.compilerOptions.paths) {\n tsconfig.compilerOptions.paths = {};\n }\n\n const pathKey = '#/monorise/*';\n const pathValue = ['./.monorise/*'];\n\n if (!tsconfig.compilerOptions.paths[pathKey]) {\n tsconfig.compilerOptions.paths[pathKey] = pathValue;\n fs.writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2));\n console.log(\n `Added '${pathKey}' path alias in ${path.relative(projectRoot, tsconfigPath)}`,\n );\n } else {\n console.log(\n `'${pathKey}' path alias already set in ${path.relative(projectRoot, tsconfigPath)}. Skipping.`,\n );\n }\n } catch (error) {\n console.error(\n `Error updating ${path.relative(projectRoot, tsconfigPath)}:`,\n error,\n );\n }\n } else {\n console.warn(\n `Warning: ${path.relative(projectRoot, tsconfigPath)} not found. Cannot add path alias.`,\n );\n }\n\n console.log('Monorise initialization complete!');\n}\n\nasync function runDevCommand(configDir: string, rootPath?: string) {\n console.log(MONORISE_LOGO);\n console.log(`Watching for changes in ${configDir}...`);\n const watcher = chokidar.watch(configDir, {\n ignored: (watchedPath: string) => {\n const fileName = path.basename(watchedPath);\n return (\n fileName === 'index.ts' || // Old name, still ignore in case it exists\n fileName === 'config.ts' || // Generated config file\n fileName === 'processors.ts' || // Generated processors file\n fileName === 'app.ts' || // Generated app file\n fileName.startsWith('.') ||\n watchedPath.endsWith('.js') ||\n watchedPath.endsWith('.jsx') ||\n watchedPath.endsWith('.d.ts')\n );\n },\n persistent: true,\n ignoreInitial: true,\n });\n\n watcher.on('add', async (filePath) => {\n console.log(`File ${filePath} has been added. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n watcher.on('change', async (filePath) => {\n console.log(`File ${filePath} has been changed. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n watcher.on('unlink', async (filePath) => {\n console.log(`File ${filePath} has been removed. Regenerating...`);\n try {\n await generateFiles(rootPath);\n } catch (err) {\n console.error('Regeneration failed:', err);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('Monorise dev terminated. Closing watcher and sst dev...');\n watcher.close();\n process.exit(0);\n });\n process.on('SIGTERM', () => {\n console.log('Monorise dev terminated. Closing watcher and sst dev...');\n watcher.close();\n process.exit(0);\n });\n}\n\nasync function runBuildCommand(rootPath?: string) {\n console.log('Starting sst build...');\n await generateFiles(rootPath);\n}\n\nasync function main() {\n const args = process.argv.slice(2);\n const command = args[0];\n\n let rootPath: string | undefined;\n const rootFlagIndex = args.indexOf('--config-root');\n if (rootFlagIndex > -1 && args[rootFlagIndex + 1]) {\n rootPath = args[rootFlagIndex + 1];\n }\n\n try {\n if (command === 'dev') {\n const configDir = await generateFiles(rootPath);\n await runDevCommand(configDir, rootPath);\n } else if (command === 'build') {\n await runBuildCommand(rootPath);\n } else if (command === 'init') {\n await runInitCommand(rootPath);\n } else {\n console.error(\n 'Unknown command. Usage: monorise [dev|build|init] [--config-root <path>]',\n );\n process.exit(1);\n }\n } catch (err) {\n console.error('Monorise process failed:', err);\n process.exit(1);\n }\n}\n\nmain().catch((err) => {\n console.error('Monorise encountered an unhandled error:', err);\n process.exit(1);\n});\n","import fs from 'node:fs';\nimport path from 'node:path';\n\n/**\n * Detects whether the combined 'monorise' package is installed by walking up\n * the directory tree. This handles monorepo setups where dependencies are\n * hoisted to the root node_modules.\n */\nexport function detectCombinedPackage(startDir: string): boolean {\n let dir = startDir;\n while (true) {\n if (fs.existsSync(path.join(dir, 'node_modules', 'monorise'))) {\n return true;\n }\n const parent = path.dirname(dir);\n if (parent === dir) break; // reached filesystem root\n dir = parent;\n }\n return false;\n}\n"],"mappings":"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","names":["fs","path","path","fs"]}
|