@aerokit/sdk 12.56.0 → 12.57.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/cjs/db/decorators.js +1 -1
- package/dist/cjs/db/repository.js +1 -1
- package/dist/cjs/db/store.js +79 -12
- package/dist/dts/db/decorators.d.ts +4 -1
- package/dist/dts/db/store.d.ts +6 -0
- package/dist/esm/db/decorators.mjs +1 -1
- package/dist/esm/db/repository.mjs +1 -1
- package/dist/esm/db/store.mjs +79 -12
- package/package.json +1 -1
|
@@ -164,4 +164,4 @@ function ManyToOne(typeFunction, options = {}) {
|
|
|
164
164
|
});
|
|
165
165
|
};
|
|
166
166
|
}
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: string;\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new (...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "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",
  "names": []
}

|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "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",
  "names": []
}

|
|
@@ -145,4 +145,4 @@ class Repository {
|
|
|
145
145
|
async triggerEvent(_data) {
|
|
146
146
|
}
|
|
147
147
|
}
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/repository.ts"],
  "sourcesContent": ["import { store, translator, EntityConstructor, Options } from \"@aerokit/sdk/db\";\n\n/**\n * Represents the data structure passed to the event trigger method before/after an operation.\n */\nexport interface EntityEvent<T> {\n    readonly operation: 'create' | 'update' | 'delete';\n    readonly table: string;\n    readonly entity: Partial<T>; // Use Partial<T> for create/delete where some fields might be missing\n    readonly key: {\n        name: string;\n        column: string;\n        value: string | number;\n    }\n    readonly previousEntity?: T;\n}\n\n\n// --- Repository Class ---\n\n/**\n * Abstract base class for data access/business logic, wrapping the `store` API.\n * It handles entity metadata lookup, CRUD operations, translation, and event triggering.\n * @template T The entity type (must be an object).\n */\nexport abstract class Repository<T extends Record<string, any>> {\n\n    private entityConstructor: EntityConstructor;\n\n    constructor(entityConstructor: EntityConstructor) {\n        this.entityConstructor = entityConstructor;\n        \n        // Caches entity metadata (name, table, id) onto the constructor function for static access\n\t\tif (!this.entityConstructor.$entity_name) {\n            // Assumes store methods return non-null strings\n\t\t\tthis.entityConstructor.$entity_name = (store as any).getEntityName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$table_name = (store as any).getTableName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_name = (store as any).getIdName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_column = (store as any).getIdColumn(this.entityConstructor.name);\n\t\t}\n    }\n\n    protected getEntityName(): string {\n        // Use non-null assertion since the constructor guarantees these properties exist\n        return this.entityConstructor.$entity_name!;\n    }\n\n    protected getTableName(): string {\n        return this.entityConstructor.$table_name!;\n    }\n\n    protected getIdName(): string {\n        return this.entityConstructor.$id_name!;\n    }\n\n    protected getIdColumn(): string {\n        return this.entityConstructor.$id_column!;\n    }\n\n    /**\n     * Finds all entities matching the given options.\n     */\n    public findAll(options: Options = {}): T[] {\n        // Assume store.list returns T[] but we explicitly cast it to T[]\n        const list: T[] = (store as any).list(this.getEntityName(), options);\n        (translator as any).translateList(list, options.language, this.getTableName());\n        return list;\n    }\n\n    /**\n     * Finds a single entity by its primary key ID.\n     */\n    public findById(id: number | string, options: Options = {}): T | undefined {\n        // Assume store.get returns T or null/undefined\n        const entity: T | null = (store as any).get(this.getEntityName(), id);\n        (translator as any).translateEntity(entity, id, options.language, this.getTableName());\n        return entity ?? undefined;\n    }\n\n    /**\n     * Creates a new entity in the database.\n     * @returns The generated ID (string or number).\n     */\n    public create(entity: T): string | number {\n        const id = (store as any).save(this.getEntityName(), entity);\n        this.triggerEvent({\n            operation: \"create\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n        return id;\n    }\n\n    /**\n     * Updates an existing entity.\n     * The entity must contain the primary key.\n     */\n    public update(entity: T): void {\n        const idName = this.getIdName();\n        const id = entity[idName] as (number | string);\n        \n        // Retrieve the entity state before update for the event payload\n        const previousEntity = this.findById(id);\n\n        (store as any).update(this.getEntityName(), entity);\n        \n        this.triggerEvent({\n            operation: \"update\",\n            table: this.getTableName(),\n            entity: entity,\n            previousEntity: previousEntity,\n            key: {\n                name: idName,\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Creates the entity if the ID is null/undefined, otherwise updates it.\n     * If an ID is provided but the entity doesn't exist, it creates it.\n     * @returns The entity's ID.\n     */\n    public upsert(entity: T): string | number {\n        const id = entity[this.getIdName()];\n        \n        // If no ID is present, save (create)\n        if (id === null || id === undefined) {\n            return (store as any).save(this.getEntityName(), entity);\n        }\n\n        // If ID is present, check existence\n        const existingEntity = (store as any).get(this.getEntityName(), id);\n        \n        if (existingEntity) {\n            this.update(entity);\n            return id;\n        } else {\n            // ID exists, but entity does not -> save (create with provided ID)\n            return (store as any).save(this.getEntityName(), entity);\n        }\n    }\n\n    /**\n     * Deletes an entity by its primary key ID.\n     */\n    public deleteById(id: number | string): void {\n        // Retrieve entity before removal for the event payload\n        const entity = (store as any).get(this.getEntityName(), id);\n        \n        (store as any).remove(this.getEntityName(), id);\n\n        this.triggerEvent({\n            operation: \"delete\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Counts the number of entities matching the given options.\n     */\n    public count(options?: Options): number {\n        return (store as any).count(this.getEntityName(), options);\n    }\n\n    /**\n     * Protected method intended for subclass overriding or internal event handling.\n     */\n    protected async triggerEvent(_data: EntityEvent<T>): Promise<void> {\n        // Empty body as in the original code\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/repository.ts"],
  "sourcesContent": ["import { store, translator, EntityConstructor, Options } from \"@aerokit/sdk/db\";\n\n/**\n * Represents the data structure passed to the event trigger method before/after an operation.\n */\nexport interface EntityEvent<T> {\n    readonly operation: 'create' | 'update' | 'delete';\n    readonly table: string;\n    readonly entity: Partial<T>; // Use Partial<T> for create/delete where some fields might be missing\n    readonly key: {\n        name: string;\n        column: string;\n        value: string | number;\n    }\n    readonly previousEntity?: T;\n}\n\n\n// --- Repository Class ---\n\n/**\n * Abstract base class for data access/business logic, wrapping the `store` API.\n * It handles entity metadata lookup, CRUD operations, translation, and event triggering.\n * @template T The entity type (must be an object).\n */\nexport abstract class Repository<T extends Record<string, any>> {\n\n    private entityConstructor: EntityConstructor;\n\n    constructor(entityConstructor: EntityConstructor) {\n        this.entityConstructor = entityConstructor;\n        \n        // Caches entity metadata (name, table, id) onto the constructor function for static access\n\t\tif (!this.entityConstructor.$entity_name) {\n            // Assumes store methods return non-null strings\n\t\t\tthis.entityConstructor.$entity_name = store.getEntityName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$table_name = store.getTableName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_name = store.getIdName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_column = store.getIdColumn(this.entityConstructor.name);\n\t\t}\n    }\n\n    protected getEntityName(): string {\n        // Use non-null assertion since the constructor guarantees these properties exist\n        return this.entityConstructor.$entity_name!;\n    }\n\n    protected getTableName(): string {\n        return this.entityConstructor.$table_name!;\n    }\n\n    protected getIdName(): string {\n        return this.entityConstructor.$id_name!;\n    }\n\n    protected getIdColumn(): string {\n        return this.entityConstructor.$id_column!;\n    }\n\n    /**\n     * Finds all entities matching the given options.\n     */\n    public findAll(options: Options = {}): T[] {\n        // Assume store.list returns T[] but we explicitly cast it to T[]\n        const list: T[] = store.list(this.getEntityName(), options);\n        translator.translateList(list, options.language, this.getTableName());\n        return list;\n    }\n\n    /**\n     * Finds a single entity by its primary key ID.\n     */\n    public findById(id: number | string, options: Options = {}): T | undefined {\n        // Assume store.get returns T or null/undefined\n        const entity: T | null = store.get(this.getEntityName(), id);\n        translator.translateEntity(entity, id, options.language, this.getTableName());\n        return entity ?? undefined;\n    }\n\n    /**\n     * Creates a new entity in the database.\n     * @returns The generated ID (string or number).\n     */\n    public create(entity: T): string | number {\n        const id = store.save(this.getEntityName(), entity);\n        this.triggerEvent({\n            operation: \"create\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n        return id;\n    }\n\n    /**\n     * Updates an existing entity.\n     * The entity must contain the primary key.\n     */\n    public update(entity: T): void {\n        const idName = this.getIdName();\n        const id = entity[idName] as (number | string);\n        \n        // Retrieve the entity state before update for the event payload\n        const previousEntity = this.findById(id);\n\n        store.update(this.getEntityName(), entity);\n        \n        this.triggerEvent({\n            operation: \"update\",\n            table: this.getTableName(),\n            entity: entity,\n            previousEntity: previousEntity,\n            key: {\n                name: idName,\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Creates the entity if the ID is null/undefined, otherwise updates it.\n     * If an ID is provided but the entity doesn't exist, it creates it.\n     * @returns The entity's ID.\n     */\n    public upsert(entity: T): string | number {\n        const id = entity[this.getIdName()];\n        \n        // If no ID is present, save (create)\n        if (id === null || id === undefined) {\n            return store.save(this.getEntityName(), entity);\n        }\n\n        // If ID is present, check existence\n        const existingEntity = store.get(this.getEntityName(), id);\n        \n        if (existingEntity) {\n            this.update(entity);\n            return id;\n        } else {\n            // ID exists, but entity does not -> save (create with provided ID)\n            return store.save(this.getEntityName(), entity);\n        }\n    }\n\n    /**\n     * Deletes an entity by its primary key ID.\n     */\n    public deleteById(id: number | string): void {\n        // Retrieve entity before removal for the event payload\n        const entity = store.get(this.getEntityName(), id);\n        \n        store.remove(this.getEntityName(), id);\n\n        this.triggerEvent({\n            operation: \"delete\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Counts the number of entities matching the given options.\n     */\n    public count(options?: Options): number {\n        return store.count(this.getEntityName(), options);\n    }\n\n    /**\n     * Protected method intended for subclass overriding or internal event handling.\n     */\n    protected async triggerEvent(_data: EntityEvent<T>): Promise<void> {\n        // Empty body as in the original code\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

|
package/dist/cjs/db/store.js
CHANGED
|
@@ -74,7 +74,7 @@ class Store {
|
|
|
74
74
|
*/
|
|
75
75
|
static list(name, options) {
|
|
76
76
|
const result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);
|
|
77
|
-
return
|
|
77
|
+
return Store.parseResult(result);
|
|
78
78
|
}
|
|
79
79
|
/**
|
|
80
80
|
* Counts the number of entries based on optional filtering options.
|
|
@@ -98,7 +98,7 @@ class Store {
|
|
|
98
98
|
if (result === null || result === void 0 || result === "") {
|
|
99
99
|
return void 0;
|
|
100
100
|
}
|
|
101
|
-
return
|
|
101
|
+
return Store.parseResult(result);
|
|
102
102
|
}
|
|
103
103
|
/**
|
|
104
104
|
* Deletes an entry by its ID.
|
|
@@ -118,7 +118,7 @@ class Store {
|
|
|
118
118
|
*/
|
|
119
119
|
static find(name, example, limit = 100, offset = 0) {
|
|
120
120
|
const result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);
|
|
121
|
-
return
|
|
121
|
+
return Store.parseResult(result);
|
|
122
122
|
}
|
|
123
123
|
/**
|
|
124
124
|
* Queries all entries for a given script with pagination.
|
|
@@ -148,22 +148,22 @@ class Store {
|
|
|
148
148
|
}
|
|
149
149
|
if (arr.length === 0) {
|
|
150
150
|
const result = DataStoreFacade.query(query, null, limit, offset);
|
|
151
|
-
return
|
|
151
|
+
return Store.parseResult(result);
|
|
152
152
|
}
|
|
153
153
|
const first = arr[0];
|
|
154
154
|
if (first && typeof first === "object" && "name" in first && "type" in first) {
|
|
155
155
|
const result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);
|
|
156
|
-
return
|
|
156
|
+
return Store.parseResult(result);
|
|
157
157
|
}
|
|
158
158
|
if (first && typeof first === "object" && "type" in first && !("name" in first)) {
|
|
159
159
|
const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);
|
|
160
|
-
return
|
|
160
|
+
return Store.parseResult(result);
|
|
161
161
|
}
|
|
162
162
|
if (arr.every(
|
|
163
163
|
(v) => typeof v === "string" || typeof v === "number" || typeof v === "boolean" || v instanceof Date || Array.isArray(v)
|
|
164
164
|
)) {
|
|
165
165
|
const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);
|
|
166
|
-
return
|
|
166
|
+
return Store.parseResult(result);
|
|
167
167
|
}
|
|
168
168
|
throw new Error("Unsupported parameter format: " + JSON.stringify(parameters));
|
|
169
169
|
}
|
|
@@ -193,22 +193,22 @@ class Store {
|
|
|
193
193
|
}
|
|
194
194
|
if (arr.length === 0) {
|
|
195
195
|
const result = DataStoreFacade.queryNative(query, null, limit, offset);
|
|
196
|
-
return
|
|
196
|
+
return Store.parseResult(result);
|
|
197
197
|
}
|
|
198
198
|
const first = arr[0];
|
|
199
199
|
if (first && typeof first === "object" && "name" in first && "type" in first) {
|
|
200
200
|
const result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);
|
|
201
|
-
return
|
|
201
|
+
return Store.parseResult(result);
|
|
202
202
|
}
|
|
203
203
|
if (first && typeof first === "object" && "type" in first && !("name" in first)) {
|
|
204
204
|
const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);
|
|
205
|
-
return
|
|
205
|
+
return Store.parseResult(result);
|
|
206
206
|
}
|
|
207
207
|
if (arr.every(
|
|
208
208
|
(v) => typeof v === "string" || typeof v === "number" || typeof v === "boolean" || v instanceof Date || Array.isArray(v)
|
|
209
209
|
)) {
|
|
210
210
|
const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);
|
|
211
|
-
return
|
|
211
|
+
return Store.parseResult(result);
|
|
212
212
|
}
|
|
213
213
|
throw new Error("Unsupported parameter format: " + JSON.stringify(parameters));
|
|
214
214
|
}
|
|
@@ -237,8 +237,75 @@ class Store {
|
|
|
237
237
|
static getIdColumn(name) {
|
|
238
238
|
return DataStoreFacade.getIdColumn(name);
|
|
239
239
|
}
|
|
240
|
+
/**
|
|
241
|
+
* Parse a JSON string and revive ISO date strings into JS Date objects.
|
|
242
|
+
* It handles both full ISO timestamps (with timezone) and date-only strings (YYYY-MM-DD).
|
|
243
|
+
* Returns undefined for null/empty inputs.
|
|
244
|
+
*/
|
|
245
|
+
static parseResult(result) {
|
|
246
|
+
if (result === null || result === void 0 || result === "") {
|
|
247
|
+
return void 0;
|
|
248
|
+
}
|
|
249
|
+
if (typeof result !== "string") {
|
|
250
|
+
return result;
|
|
251
|
+
}
|
|
252
|
+
const ISO_DATETIME = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+\-]\d{2}:?\d{2})$/;
|
|
253
|
+
const DATE_ONLY = /^\d{4}-\d{2}-\d{2}$/;
|
|
254
|
+
const TZ_NO_COLON = /([+\-]\d{2})(\d{2})$/;
|
|
255
|
+
const SPACE_DATETIME = /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+\-]\d{2}:?\d{2})?$/;
|
|
256
|
+
const TIME_ONLY = /^\d{2}:\d{2}:\d{2}(?:\.\d+)?$/;
|
|
257
|
+
const EPOCH_MS = /^[+\-]?\d{13}$/;
|
|
258
|
+
const EPOCH_S = /^[+\-]?\d{10}$/;
|
|
259
|
+
return JSON.parse(result, (key, value) => {
|
|
260
|
+
if (typeof value === "string") {
|
|
261
|
+
const s = value.trim();
|
|
262
|
+
if (EPOCH_MS.test(s)) {
|
|
263
|
+
const ms = parseInt(s, 10);
|
|
264
|
+
return new Date(ms);
|
|
265
|
+
}
|
|
266
|
+
if (EPOCH_S.test(s)) {
|
|
267
|
+
const ms = parseInt(s, 10) * 1e3;
|
|
268
|
+
return new Date(ms);
|
|
269
|
+
}
|
|
270
|
+
if (SPACE_DATETIME.test(s)) {
|
|
271
|
+
let v = s.replace(" ", "T");
|
|
272
|
+
if (TZ_NO_COLON.test(v)) {
|
|
273
|
+
v = v.replace(TZ_NO_COLON, "$1:$2");
|
|
274
|
+
}
|
|
275
|
+
const d = new Date(v);
|
|
276
|
+
if (!isNaN(d.getTime())) {
|
|
277
|
+
return d;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
if (TIME_ONLY.test(s)) {
|
|
281
|
+
const m = s.match(/(\d{2}):(\d{2}):(\d{2})(?:\.(\d+))?/);
|
|
282
|
+
if (m) {
|
|
283
|
+
const hh = parseInt(m[1], 10);
|
|
284
|
+
const mm = parseInt(m[2], 10);
|
|
285
|
+
const ss = parseInt(m[3], 10);
|
|
286
|
+
const frac = m[4] ? (m[4] + "000").substring(0, 3) : "000";
|
|
287
|
+
const ms = parseInt(frac, 10);
|
|
288
|
+
const now = /* @__PURE__ */ new Date();
|
|
289
|
+
const d = new Date(Date.UTC(now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate(), hh, mm, ss, ms));
|
|
290
|
+
return d;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
if (ISO_DATETIME.test(s) || DATE_ONLY.test(s)) {
|
|
294
|
+
let v = s;
|
|
295
|
+
if (TZ_NO_COLON.test(v)) {
|
|
296
|
+
v = v.replace(TZ_NO_COLON, "$1:$2");
|
|
297
|
+
}
|
|
298
|
+
const d = new Date(v);
|
|
299
|
+
if (!isNaN(d.getTime())) {
|
|
300
|
+
return d;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
return value;
|
|
305
|
+
});
|
|
306
|
+
}
|
|
240
307
|
}
|
|
241
308
|
if (typeof module !== "undefined") {
|
|
242
309
|
module.exports = Store;
|
|
243
310
|
}
|
|
244
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/store.ts"],
  "sourcesContent": ["const DataStoreFacade = Java.type(\"org.eclipse.dirigible.components.api.db.DataStoreFacade\");\n\n/**\n * Defines the available comparison operators for query conditions.\n */\nexport enum Operator {\n\tEQ = \"=\", // Equals\n\tNE = \"<>\", // Not Equals\n\tGT = \">\", // Greater Than\n\tLT = \"<\", // Less Than\n\tGE = \">=\", // Greater Than or Equals\n\tLE = \"<=\", // Less Than or Equals\n\tLIKE = \"LIKE\", // SQL LIKE operator\n\tBETWEEN = \"BETWEEN\", // SQL BETWEEN operator (requires two values)\n\tIN = \"IN\" // SQL IN operator (requires a List or Array of values)\n}\n\n/**\n * Defines the direction for sorting.\n */\nexport enum Direction {\n\tASC = \"ASC\", // Ascending\n\tDESC = \"DESC\" // Descending\n}\n\n/**\n * Represents a single condition for filtering data.\n */\nexport interface Condition {\n\tpropertyName: string,\n\toperator: Operator,\n\tvalue: any | any[]\n}\n\n/**\n * Represents a single sorting instruction.\n */\nexport interface Sort {\n\tpropertyName: string,\n\tdirection: Direction\n}\n\n/**\n * Defines optional parameters for list and count operations.\n */\nexport interface Options {\n\tconditions?: Condition[],\n\tsorts?: Sort[],\n\tlimit?: number,\n\toffset?: number,\n\tlanguage?: string\n}\n\nimport { TypedQueryParameter, NamedQueryParameter } from './query';\n\n/**\n * Facade class for interacting with the underlying Dirigible Data Store.\n * All methods serialize/deserialize JavaScript objects to/from JSON strings\n * before interacting with the native Java facade.\n */\nexport class Store {\n\n\t/**\n\t * Saves a new entry to the data store.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to save.\n\t * @returns The ID of the newly created entry (string or number).\n\t */\n\tpublic static save(name: string, entry: any): string | number {\n\t\treturn DataStoreFacade.save(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Inserts a new entry or updates an existing one if the ID is present.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to insert/update.\n\t */\n\tpublic static upsert(name: string, entry: any): void {\n\t\tDataStoreFacade.upsert(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Updates an existing entry.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object with the ID and updated data.\n\t */\n\tpublic static update(name: string, entry: any): void {\n\t\tDataStoreFacade.update(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Lists entries based on optional filtering, sorting, and pagination options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static list(name: string, options?: Options): any[] {\n\t\tconst result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);\n\t\treturn JSON.parse(result);\n\t}\n\t\n\t/**\n\t * Counts the number of entries based on optional filtering options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns The count of matching entries.\n\t */\n\tpublic static count(name: string, options?: Options): number {\n\t\tconst optionsString = options ? JSON.stringify(options) : null;\n\t\tconst result = DataStoreFacade.count(name, optionsString);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Retrieves a single entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry.\n\t * @returns The entry object, or undefined if not found.\n\t */\n\tpublic static get(name: string, id: any): any | undefined {\n\t\tconst result = DataStoreFacade.get(name, id);\n\t\t// Assuming the native API returns null/undefined or an empty JSON string if not found, \n\t\t// otherwise JSON.parse handles the conversion.\n\t\tif (result === null || result === undefined || result === \"\") {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn JSON.parse(result);\n\t};\n\n\t/**\n\t * Deletes an entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry to remove.\n\t */\n\tpublic static remove(name: string, id: any): void {\n\t\tDataStoreFacade.deleteEntry(name, id);\n\t}\n\t\n\t/**\n\t * Finds entries matching an example object (query-by-example).\n\t * @param name The entity/table name.\n\t * @param example An object containing properties to match.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of matching JavaScript objects.\n\t */\n\tpublic static find(name: string, example: any, limit: number = 100, offset: number = 0): any[] {\n\t\tconst result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);\n\t\treturn JSON.parse(result);\n\t}\n\t\n\t/**\n\t * Queries all entries for a given script with pagination.\n\t * @param query The query script.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static query(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t    if (parameters == null) {\n\t      arr = [];\n\t    } else if (typeof parameters === \"string\") {\n\t      try {\n\t        const parsed = JSON.parse(parameters);\n\t        if (!Array.isArray(parsed)) {\n\t          throw new Error(\"Input parameter string must represent a JSON array\");\n\t        }\n\t        arr = parsed;\n\t      } catch (e) {\n\t        throw new Error(\"Invalid JSON parameters: \" + e);\n\t      }\n\t    } else if (Array.isArray(parameters)) {\n\t      arr = parameters;\n\t    } else {\n\t      throw new Error(\"Parameters must be either an array or a JSON string\");\n\t    }\n\n\t    if (arr.length === 0) {\n\t\t  const result = DataStoreFacade.query(query, null, limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    const first = arr[0];\n\n\t    // NamedQueryParameter (has name + type)\n\t    if (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t  const result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // TypedQueryParameter (has type, no name)\n\t    if (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t  const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // Primitive array\n\t    if (\n\t      arr.every(\n\t        (v) =>\n\t          typeof v === \"string\" ||\n\t          typeof v === \"number\" ||\n\t          typeof v === \"boolean\" ||\n\t          v instanceof Date\t||\n\t\t  \t  Array.isArray(v)\n\t      )\n\t    ) {\n\t\t  const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    throw new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\t\n\t/**\n\t * Queries all entries for a given entity name without pagination.\n\t * @param query The entity/table name.\n\t * @returns An array of all JavaScript objects.\n\t */\n\tpublic static queryNative(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t      arr = [];\n\t    } else if (typeof parameters === \"string\") {\n\t      try {\n\t        const parsed = JSON.parse(parameters);\n\t        if (!Array.isArray(parsed)) {\n\t          throw new Error(\"Input parameter string must represent a JSON array\");\n\t        }\n\t        arr = parsed;\n\t      } catch (e) {\n\t        throw new Error(\"Invalid JSON parameters: \" + e);\n\t      }\n\t    } else if (Array.isArray(parameters)) {\n\t      arr = parameters;\n\t    } else {\n\t      throw new Error(\"Parameters must be either an array or a JSON string\");\n\t    }\n\n\t    if (arr.length === 0) {\n\t\t  const result = DataStoreFacade.queryNative(query, null, limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    const first = arr[0];\n\n\t    // NamedQueryParameter (has name + type)\n\t    if (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t  const result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // TypedQueryParameter (has type, no name)\n\t    if (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t  const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // Primitive array\n\t    if (\n\t      arr.every(\n\t        (v) =>\n\t          typeof v === \"string\" ||\n\t          typeof v === \"number\" ||\n\t          typeof v === \"boolean\" ||\n\t          v instanceof Date ||\n\t\t\t  Array.isArray(v)\n\t      )\n\t    ) {\n\t\t  const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    throw new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\t\n\t// --- Metadata Getters ---\n\n\t/**\n\t * Gets the name of the entity associated with the store name.\n\t */\n\tpublic static getEntityName(name: string): string {\n\t\treturn DataStoreFacade.getEntityName(name);\n\t}\n\t\n\t/**\n\t * Gets the underlying database table name for the entity.\n\t */\n\tpublic static getTableName(name: string): string {\n\t\treturn DataStoreFacade.getTableName(name);\n\t}\n\t\t\n\t/**\n\t * Gets the property name used as the ID field in the entity object.\n\t */\n\tpublic static getIdName(name: string): string {\n\t\treturn DataStoreFacade.getIdName(name);\n\t}\n\t\t\t\n\t/**\n\t * Gets the underlying database column name used for the ID field.\n\t */\n\tpublic static getIdColumn(name: string): string {\n\t\treturn DataStoreFacade.getIdColumn(name);\n\t}\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Store;\n}"],
  "mappings": "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",
  "names": ["Operator", "Direction"]
}

|
|
311
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/store.ts"],
  "sourcesContent": ["const DataStoreFacade = Java.type(\"org.eclipse.dirigible.components.api.db.DataStoreFacade\");\n\n/**\n * Defines the available comparison operators for query conditions.\n */\nexport enum Operator {\n\tEQ = \"=\", // Equals\n\tNE = \"<>\", // Not Equals\n\tGT = \">\", // Greater Than\n\tLT = \"<\", // Less Than\n\tGE = \">=\", // Greater Than or Equals\n\tLE = \"<=\", // Less Than or Equals\n\tLIKE = \"LIKE\", // SQL LIKE operator\n\tBETWEEN = \"BETWEEN\", // SQL BETWEEN operator (requires two values)\n\tIN = \"IN\" // SQL IN operator (requires a List or Array of values)\n}\n\n/**\n * Defines the direction for sorting.\n */\nexport enum Direction {\n\tASC = \"ASC\", // Ascending\n\tDESC = \"DESC\" // Descending\n}\n\n/**\n * Represents a single condition for filtering data.\n */\nexport interface Condition {\n\tpropertyName: string,\n\toperator: Operator,\n\tvalue: any | any[]\n}\n\n/**\n * Represents a single sorting instruction.\n */\nexport interface Sort {\n\tpropertyName: string,\n\tdirection: Direction\n}\n\n/**\n * Defines optional parameters for list and count operations.\n */\nexport interface Options {\n\tconditions?: Condition[],\n\tsorts?: Sort[],\n\tlimit?: number,\n\toffset?: number,\n\tlanguage?: string\n}\n\nimport { TypedQueryParameter, NamedQueryParameter } from './query';\n\n/**\n * Facade class for interacting with the underlying Dirigible Data Store.\n * All methods serialize/deserialize JavaScript objects to/from JSON strings\n * before interacting with the native Java facade.\n */\nexport class Store {\n\n\t/**\n\t * Saves a new entry to the data store.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to save.\n\t * @returns The ID of the newly created entry (string or number).\n\t */\n\tpublic static save(name: string, entry: any): string | number {\n\t\treturn DataStoreFacade.save(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Inserts a new entry or updates an existing one if the ID is present.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to insert/update.\n\t */\n\tpublic static upsert(name: string, entry: any): void {\n\t\tDataStoreFacade.upsert(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Updates an existing entry.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object with the ID and updated data.\n\t */\n\tpublic static update(name: string, entry: any): void {\n\t\tDataStoreFacade.update(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Lists entries based on optional filtering, sorting, and pagination options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static list(name: string, options?: Options): any[] {\n\t\tconst result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);\n\t\treturn Store.parseResult(result);\n\t}\n\n\t/**\n\t * Counts the number of entries based on optional filtering options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns The count of matching entries.\n\t */\n\tpublic static count(name: string, options?: Options): number {\n\t\tconst optionsString = options ? JSON.stringify(options) : null;\n\t\tconst result = DataStoreFacade.count(name, optionsString);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Retrieves a single entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry.\n\t * @returns The entry object, or undefined if not found.\n\t */\n\tpublic static get(name: string, id: any): any | undefined {\n\t\tconst result = DataStoreFacade.get(name, id);\n\t\t// Assuming the native API returns null/undefined or an empty JSON string if not found, \n\t\t// otherwise JSON.parse handles the conversion.\n\t\tif (result === null || result === undefined || result === \"\") {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn Store.parseResult(result);\n\t};\n\n\t/**\n\t * Deletes an entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry to remove.\n\t */\n\tpublic static remove(name: string, id: any): void {\n\t\tDataStoreFacade.deleteEntry(name, id);\n\t}\n\n\t/**\n\t * Finds entries matching an example object (query-by-example).\n\t * @param name The entity/table name.\n\t * @param example An object containing properties to match.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of matching JavaScript objects.\n\t */\n\tpublic static find(name: string, example: any, limit: number = 100, offset: number = 0): any[] {\n\t\tconst result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);\n\t\treturn Store.parseResult(result);\n\t}\n\n\t/**\n\t * Queries all entries for a given script with pagination.\n\t * @param query The query script.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static query(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t\t\tarr = [];\n\t\t} else if (typeof parameters === \"string\") {\n\t\t\ttry {\n\t\t\t\tconst parsed = JSON.parse(parameters);\n\t\t\t\tif (!Array.isArray(parsed)) {\n\t\t\t\t\tthrow new Error(\"Input parameter string must represent a JSON array\");\n\t\t\t\t}\n\t\t\t\tarr = parsed;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new Error(\"Invalid JSON parameters: \" + e);\n\t\t\t}\n\t\t} else if (Array.isArray(parameters)) {\n\t\t\tarr = parameters;\n\t\t} else {\n\t\t\tthrow new Error(\"Parameters must be either an array or a JSON string\");\n\t\t}\n\n\t\tif (arr.length === 0) {\n\t\t\tconst result = DataStoreFacade.query(query, null, limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tconst first = arr[0];\n\n\t\t// NamedQueryParameter (has name + type)\n\t\tif (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t\tconst result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// TypedQueryParameter (has type, no name)\n\t\tif (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t\tconst result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// Primitive array\n\t\tif (\n\t\t\tarr.every(\n\t\t\t\t(v) =>\n\t\t\t\t\ttypeof v === \"string\" ||\n\t\t\t\t\ttypeof v === \"number\" ||\n\t\t\t\t\ttypeof v === \"boolean\" ||\n\t\t\t\t\tv instanceof Date ||\n\t\t\t\t\tArray.isArray(v)\n\t\t\t)\n\t\t) {\n\t\t\tconst result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tthrow new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\n\t/**\n\t * Queries all entries for a given entity name without pagination.\n\t * @param query The entity/table name.\n\t * @returns An array of all JavaScript objects.\n\t */\n\tpublic static queryNative(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t\t\tarr = [];\n\t\t} else if (typeof parameters === \"string\") {\n\t\t\ttry {\n\t\t\t\tconst parsed = JSON.parse(parameters);\n\t\t\t\tif (!Array.isArray(parsed)) {\n\t\t\t\t\tthrow new Error(\"Input parameter string must represent a JSON array\");\n\t\t\t\t}\n\t\t\t\tarr = parsed;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new Error(\"Invalid JSON parameters: \" + e);\n\t\t\t}\n\t\t} else if (Array.isArray(parameters)) {\n\t\t\tarr = parameters;\n\t\t} else {\n\t\t\tthrow new Error(\"Parameters must be either an array or a JSON string\");\n\t\t}\n\n\t\tif (arr.length === 0) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, null, limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tconst first = arr[0];\n\n\t\t// NamedQueryParameter (has name + type)\n\t\tif (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t\tconst result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// TypedQueryParameter (has type, no name)\n\t\tif (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// Primitive array\n\t\tif (\n\t\t\tarr.every(\n\t\t\t\t(v) =>\n\t\t\t\t\ttypeof v === \"string\" ||\n\t\t\t\t\ttypeof v === \"number\" ||\n\t\t\t\t\ttypeof v === \"boolean\" ||\n\t\t\t\t\tv instanceof Date ||\n\t\t\t\t\tArray.isArray(v)\n\t\t\t)\n\t\t) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tthrow new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\n\t// --- Metadata Getters ---\n\n\t/**\n\t * Gets the name of the entity associated with the store name.\n\t */\n\tpublic static getEntityName(name: string): string {\n\t\treturn DataStoreFacade.getEntityName(name);\n\t}\n\n\t/**\n\t * Gets the underlying database table name for the entity.\n\t */\n\tpublic static getTableName(name: string): string {\n\t\treturn DataStoreFacade.getTableName(name);\n\t}\n\n\t/**\n\t * Gets the property name used as the ID field in the entity object.\n\t */\n\tpublic static getIdName(name: string): string {\n\t\treturn DataStoreFacade.getIdName(name);\n\t}\n\n\t/**\n\t * Gets the underlying database column name used for the ID field.\n\t */\n\tpublic static getIdColumn(name: string): string {\n\t\treturn DataStoreFacade.getIdColumn(name);\n\t}\n\n\t/**\n\t * Parse a JSON string and revive ISO date strings into JS Date objects.\n\t * It handles both full ISO timestamps (with timezone) and date-only strings (YYYY-MM-DD).\n\t * Returns undefined for null/empty inputs.\n\t */\n\tprivate static parseResult(result: any): any {\n\t\tif (result === null || result === undefined || result === '') {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (typeof result !== 'string') {\n\t\t\t// already an object/array\n\t\t\treturn result;\n\t\t}\n\n\t\t// Accept timezone offsets with or without colon (e.g. +00:00 or +0000)\n\t\tconst ISO_DATETIME = /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|[+\\-]\\d{2}:?\\d{2})$/;\n\t\tconst DATE_ONLY = /^\\d{4}-\\d{2}-\\d{2}$/;\n\t\tconst TZ_NO_COLON = /([+\\-]\\d{2})(\\d{2})$/;\n\t\t// Space-separated datetime: \"YYYY-MM-DD HH:MM:SS\" (optionally with fractional seconds and timezone)\n\t\tconst SPACE_DATETIME = /^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|[+\\-]\\d{2}:?\\d{2})?$/;\n\t\t// Time-only strings like \"11:29:33\" or \"11:29:33.123\"\n\t\tconst TIME_ONLY = /^\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?$/;\n\t\t// Epoch strings: 13-digit ms or 10-digit seconds\n\t\tconst EPOCH_MS = /^[+\\-]?\\d{13}$/;\n\t\tconst EPOCH_S = /^[+\\-]?\\d{10}$/;\n\n\t\treturn JSON.parse(result, (key, value) => {\n\t\t\tif (typeof value === 'string') {\n\t\t\t\tconst s = value.trim();\n\n\t\t\t\t// Epoch millisecond/second strings\n\t\t\t\tif (EPOCH_MS.test(s)) {\n\t\t\t\t\tconst ms = parseInt(s, 10);\n\t\t\t\t\treturn new Date(ms);\n\t\t\t\t}\n\t\t\t\tif (EPOCH_S.test(s)) {\n\t\t\t\t\tconst ms = parseInt(s, 10) * 1000;\n\t\t\t\t\treturn new Date(ms);\n\t\t\t\t}\n\n\t\t\t\t// Space-separated datetimes: normalize to ISO and parse\n\t\t\t\tif (SPACE_DATETIME.test(s)) {\n\t\t\t\t\tlet v = s.replace(' ', 'T');\n\t\t\t\t\tif (TZ_NO_COLON.test(v)) {\n\t\t\t\t\t\tv = v.replace(TZ_NO_COLON, '$1:$2');\n\t\t\t\t\t}\n\t\t\t\t\tconst d = new Date(v);\n\t\t\t\t\tif (!isNaN(d.getTime())) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Time-only strings: attach current UTC date and parse as UTC\n\t\t\t\tif (TIME_ONLY.test(s)) {\n\t\t\t\t\tconst m = s.match(/(\\d{2}):(\\d{2}):(\\d{2})(?:\\.(\\d+))?/);\n\t\t\t\t\tif (m) {\n\t\t\t\t\t\tconst hh = parseInt(m[1], 10);\n\t\t\t\t\t\tconst mm = parseInt(m[2], 10);\n\t\t\t\t\t\tconst ss = parseInt(m[3], 10);\n\t\t\t\t\t\tconst frac = m[4] ? (m[4] + '000').substring(0, 3) : '000';\n\t\t\t\t\t\tconst ms = parseInt(frac, 10);\n\t\t\t\t\t\tconst now = new Date();\n\t\t\t\t\t\tconst d = new Date(Date.UTC(now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate(), hh, mm, ss, ms));\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (ISO_DATETIME.test(s) || DATE_ONLY.test(s)) {\n\t\t\t\t\t// normalize timezone without colon (e.g. +0000 -> +00:00) because Date parsing\n\t\t\t\t\t// prefers the colon-separated offset in many JS engines\n\t\t\t\t\tlet v = s;\n\t\t\t\t\tif (TZ_NO_COLON.test(v)) {\n\t\t\t\t\t\tv = v.replace(TZ_NO_COLON, '$1:$2');\n\t\t\t\t\t}\n\t\t\t\t\tconst d = new Date(v);\n\t\t\t\t\tif (!isNaN(d.getTime())) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn value;\n\t\t});\n\t}\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Store;\n}"],
  "mappings": "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",
  "names": ["Operator", "Direction"]
}

|
|
@@ -19,12 +19,15 @@ type ClassDecoratorContext = {
|
|
|
19
19
|
name?: string | symbol;
|
|
20
20
|
addInitializer(fn: () => void): void;
|
|
21
21
|
};
|
|
22
|
+
export type ColumnTypes = 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal' | 'string' | 'char' | 'text' | 'nstring' | 'ntext' | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant' | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob' | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';
|
|
22
23
|
export interface ColumnOptions {
|
|
23
24
|
name?: string;
|
|
24
|
-
type?: string;
|
|
25
|
+
type?: ColumnTypes | (string & {});
|
|
25
26
|
length?: number;
|
|
26
27
|
nullable?: boolean;
|
|
27
28
|
defaultValue?: string;
|
|
29
|
+
precision?: number;
|
|
30
|
+
scale?: number;
|
|
28
31
|
}
|
|
29
32
|
export interface OneToManyOptions {
|
|
30
33
|
table?: string;
|
package/dist/dts/db/store.d.ts
CHANGED
|
@@ -136,4 +136,10 @@ export declare class Store {
|
|
|
136
136
|
* Gets the underlying database column name used for the ID field.
|
|
137
137
|
*/
|
|
138
138
|
static getIdColumn(name: string): string;
|
|
139
|
+
/**
|
|
140
|
+
* Parse a JSON string and revive ISO date strings into JS Date objects.
|
|
141
|
+
* It handles both full ISO timestamps (with timezone) and date-only strings (YYYY-MM-DD).
|
|
142
|
+
* Returns undefined for null/empty inputs.
|
|
143
|
+
*/
|
|
144
|
+
private static parseResult;
|
|
139
145
|
}
|
|
@@ -145,4 +145,4 @@ export {
|
|
|
145
145
|
OneToMany,
|
|
146
146
|
Table
|
|
147
147
|
};
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: string;\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new (...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "AAyEA,MAAM,cACH,WAAmB,iCAClB,WAAmB,+BAA+B,oBAAI,QAAQ;AAElE,SAAS,iBAAiB,aAA2C;AACnE,MAAI,CAAC,YAAY,IAAI,WAAW,GAAG;AACjC,gBAAY,IAAI,aAAa,CAAC,CAAC;AAAA,EACjC;AACA,SAAO,YAAY,IAAI,WAAW;AACpC;AAGA,SAAS,MAAM,IAAsB;AAEnC,UAAQ,QAAQ,EAAE,KAAK,EAAE;AAC3B;AAGA,SAAS,wBACP,MACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,SAAS;AAC5B,YAAM,IAAI,MAAM,IAAI,IAAI,uBAAuB;AAAA,IACjD;AAEA,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACN,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,UAAI,SAAS,KAAM,UAAS,OAAO;AACnC,UAAI,SAAS,YAAa,UAAS,cAAc;AACjD,UAAI,SAAS,SAAU,UAAS,gBAAgB;AAAA,IAClD,CAAC;AAAA,EACH;AACF;AAMO,SAAS,cAAc,aAAqB;AACjD,SAAO,SACL,OACA,SACA;AACA,QAAI,QAAQ,SAAS,SAAS;AAC5B,cAAQ,eAAe,WAAY;AACjC,QAAC,MAA4B,iBAAiB;AAAA,MAChD,CAAC;AACD,aAAO;AAAA,IACT,WAAW,QAAQ,SAAS,SAAS;AACnC,cAAQ,eAAe,WAAY;AACjC,cAAM,OAAQ,KAAa;AAC3B,cAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,cAAM,gBAAgB,iBAAiB,IAAI;AAE3C,YAAI,WAAW,cAAc;AAAA,UAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,QAC5B;AAEA,YAAI,CAAC,UAAU;AACb,qBAAW;AAAA,YACT;AAAA,YACA,MAAM;AAAA,YACN,aAAa;AAAA,UACf;AACA,wBAAc,KAAK,QAAQ;AAAA,QAC7B;AAEA,iBAAS,gBAAgB;AAAA,MAC3B,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAQO,SAAS,OAAO,YAAqB;AAC1C,SAAO,SAAU,OAAiB,SAAgC;AAChE,YAAQ,eAAe,WAAY;AAEjC,YAAM,MAAM;AACV,cAAM,OAAO;AAGb,YAAI,KAAK,aAAc;AACvB,aAAK,eAAe;AAEpB,aAAK,eAAe,cAAc,KAAK;AAEvC,cAAM,gBAAgB,iBAAiB,IAAI;AAC3C,cAAM,aAAa,cAAc,KAAK,CAAC,MAAM,EAAE,IAAI;AAEnD,YAAI,YAAY;AACd,eAAK,WAAW,WAAW;AAE3B,eAAK,aACH,WAAW,eAAe,QAC1B,WAAW,aAAa,YAAY;AAAA,QACxC;AAAA,MAGF,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;AAOO,SAAS,MAAM,WAAoB;AACxC,SAAO,SACL,OACA,SACA;AACA,YAAQ,eAAe,WAAY;AACjC,MAAC,MAA4B,cAC3B,cAAc,QAAQ,MAAM,SAAS,KAAK,MAAM,KAAK,YAAY;AAAA,IACrE,CAAC;AAED,WAAO;AAAA,EACT;AACF;AAMO,MAAM,SAAS,CAAC,YACrB,wBAAwB,UAAU,OAAO;AAKpC,MAAM,KAAK,MAAM,wBAAwB,IAAI;AAM7C,MAAM,YAAY,CAAC,aACxB,wBAAwB,WAAW;AAK9B,SAAS,UACd,cACA,SACA;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACN,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;AAKO,SAAS,UACd,cACA,UAA4B,CAAC,GAC7B;AACA,SAAO,SAAU,GAAQ,SAAqC;AAC5D,QAAI,QAAQ,SAAS,QAAS;AAE9B,YAAQ,eAAe,WAAY;AACjC,YAAM,OAAQ,KAAa;AAC3B,YAAM,eAAe,QAAQ,KAAK,SAAS;AAC3C,YAAM,gBAAgB,iBAAiB,IAAI;AAE3C,UAAI,WAAW,cAAc;AAAA,QAC3B,CAAC,MAAM,EAAE,iBAAiB;AAAA,MAC5B;AAEA,UAAI,CAAC,UAAU;AACb,mBAAW;AAAA,UACT;AAAA,UACA,MAAM;AAAA,UACN,aAAa;AAAA,QACf;AACA,sBAAc,KAAK,QAAQ;AAAA,MAC7B;AAEA,eAAS,mBAAmB,EAAE,MAAM,aAAa,GAAG,QAAQ;AAAA,IAC9D,CAAC;AAAA,EACH;AACF;",
  "names": []
}

|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/decorators.ts"],
  "sourcesContent": ["/**\n * * ECMAScript 2025-compliant ORM decorator implementation\n * Compatible with GraalJS runtime.\n * * Features:\n * - Uses context.addInitializer for stable decorator timing\n * - Stores metadata in a global WeakMap cache\n * - Finalizes entity metadata once per class\n * - Defers finalization via microtask (Promise.resolve().then)\n */\n\n// --- Decorator Context Types (based on ECMAScript Decorators proposal) ---\ntype ClassFieldDecoratorContext = {\n  kind: \"field\";\n  name: string | symbol;\n  static: boolean;\n  private: boolean;\n  addInitializer(fn: () => void): void;\n};\n\ntype ClassDecoratorContext = {\n  kind: \"class\";\n  name?: string | symbol;\n  addInitializer(fn: () => void): void;\n};\n\nexport type ColumnTypes =\n  // Numeric types\n  | 'integer' | 'long' | 'short' | 'byte' | 'float' | 'double' | 'big_integer' | 'big_decimal'\n  // String types\n  | 'string' | 'char' | 'text' | 'nstring' | 'ntext'\n  // Date/Time types\n  | 'date' | 'time' | 'timestamp' | 'calendar' | 'calendar_date' | 'instant'\n  // Boolean types\n  | 'boolean' | 'true_false' | 'yes_no' | 'numeric_boolean' \n  // Binary types\n  | 'binary' | 'blob' | 'clob' | 'materialized_blob' | 'materialized_clob'\n  // Other types\n  | 'serializable' | 'any' | 'object' | 'uuid-char' | 'uuid-binary' | 'json' | 'jsonb' | 'xml';\n\n// --- Metadata Models ---\nexport interface ColumnOptions {\n  name?: string;\n  type?: ColumnTypes | (string & {});\n  length?: number;\n  nullable?: boolean;\n  defaultValue?: string;\n  precision?: number;\n  scale?: number;\n}\n\nexport interface OneToManyOptions {\n  table?: string;\n  joinColumn: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  inverse?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n  joinColumnNotNull?: boolean;\n}\n\nexport interface ManyToOneOptions {\n  joinColumn?: string;\n  cascade?: \"all\" | \"none\" | \"persist\" | \"merge\" | \"remove\";\n  nullable?: boolean;\n  lazy?: boolean;\n  fetch?: \"select\" | \"join\";\n}\n\ninterface PropertyMetadata {\n  propertyName: string;\n  isId: boolean;\n  isGenerated: boolean;\n  documentation?: string;\n  columnOptions?: ColumnOptions;\n  oneToManyOptions?: { type: Function; options: OneToManyOptions };\n  manyToOneOptions?: { type: Function; options: ManyToOneOptions };\n}\n\nexport interface EntityConstructor extends Function {\n  new(...args: any[]): any;\n  $entity_name: string;\n  $table_name: string;\n  $id_name: string;\n  $id_column: string;\n  $initialized?: boolean;\n  $documentation?: string;\n}\n\n// --- Global Metadata Cache ---\nconst globalCache: WeakMap<Function, PropertyMetadata[]> =\n  (globalThis as any).__decorator_metadata_cache__ ||\n  ((globalThis as any).__decorator_metadata_cache__ = new WeakMap());\n\nfunction getMetadataArray(constructor: Function): PropertyMetadata[] {\n  if (!globalCache.has(constructor)) {\n    globalCache.set(constructor, []);\n  }\n  return globalCache.get(constructor)!;\n}\n\n// --- Defer Helper (GraalJS-safe microtask) ---\nfunction defer(fn: () => void): void {\n  // Uses Promise microtask queue for deferred execution\n  Promise.resolve().then(fn);\n}\n\n// --- Core Property Decorator Factory ---\nfunction createPropertyDecorator(\n  kind: \"column\" | \"id\" | \"generated\",\n  options?: ColumnOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") {\n      throw new Error(`@${kind} must apply to fields`);\n    }\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      if (kind === \"id\") metadata.isId = true;\n      if (kind === \"generated\") metadata.isGenerated = true;\n      if (kind === \"column\") metadata.columnOptions = options;\n    });\n  };\n}\n\n// --- @Documentation Decorator (Dual-Purpose) ---\n/**\n * Adds documentation metadata to a class or a field.\n */\nexport function Documentation(description: string) {\n  return function (\n    value: Function | any,\n    context: ClassDecoratorContext | ClassFieldDecoratorContext\n  ) {\n    if (context.kind === \"class\") {\n      context.addInitializer(function () {\n        (value as EntityConstructor).$documentation = description;\n      });\n      return value;\n    } else if (context.kind === \"field\") {\n      context.addInitializer(function () {\n        const ctor = (this as any).constructor as EntityConstructor;\n        const propertyName = context.name.toString();\n        const metadataArray = getMetadataArray(ctor);\n\n        let metadata = metadataArray.find(\n          (m) => m.propertyName === propertyName\n        );\n\n        if (!metadata) {\n          metadata = {\n            propertyName: propertyName,\n            isId: false,\n            isGenerated: false,\n          };\n          metadataArray.push(metadata);\n        }\n\n        metadata.documentation = description;\n      });\n    }\n  };\n}\n\n\n// --- @Entity Decorator ---\n/**\n * Marks a class as an entity and initiates metadata finalization.\n * @param entityName The name of the entity (defaults to class name).\n */\nexport function Entity(entityName?: string) {\n  return function (value: Function, context: ClassDecoratorContext) {\n    context.addInitializer(function () {\n      // Defer execution to ensure all field decorators have run\n      defer(() => {\n        const ctor = value as EntityConstructor;\n\n        // Prevent duplicate registration (idempotency)\n        if (ctor.$initialized) return;\n        ctor.$initialized = true;\n\n        ctor.$entity_name = entityName || ctor.name;\n\n        const metadataArray = getMetadataArray(ctor);\n        const idMetadata = metadataArray.find((m) => m.isId);\n\n        if (idMetadata) {\n          ctor.$id_name = idMetadata.propertyName;\n          // Determine ID column name: use explicit name or convert property name to upper case\n          ctor.$id_column =\n            idMetadata.columnOptions?.name ||\n            idMetadata.propertyName.toUpperCase();\n        }\n\n        // Future: Logic to map all properties to columns/relations goes here\n      });\n    });\n  };\n}\n\n// --- @Table Decorator ---\n/**\n * Specifies the database table name for the entity.\n * @param tableName The table name (defaults to uppercase class name).\n */\nexport function Table(tableName?: string) {\n  return function <T extends EntityConstructor>(\n    value: T,\n    context: ClassDecoratorContext\n  ) {\n    context.addInitializer(function () {\n      (value as EntityConstructor).$table_name =\n        tableName || (context.name?.toString() ?? value.name.toUpperCase());\n    });\n\n    return value;\n  };\n}\n\n// --- Exported Property Decorators ---\n/**\n * Marks a property as a standard database column.\n */\nexport const Column = (options?: ColumnOptions) =>\n  createPropertyDecorator(\"column\", options);\n\n/**\n * Marks a property as the entity's primary key.\n */\nexport const Id = () => createPropertyDecorator(\"id\");\n\n/**\n * Marks a property as a generated value (e.g., auto-increment).\n * @param strategy The generation strategy (e.g., \"IDENTITY\"). Parameter is currently unused in logic.\n */\nexport const Generated = (strategy: string) =>\n  createPropertyDecorator(\"generated\");\n\n/**\n * Defines a one-to-many relationship.\n */\nexport function OneToMany(\n  typeFunction: () => Function,\n  options: OneToManyOptions\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.oneToManyOptions = { type: typeFunction(), options };\n    });\n  };\n}\n\n/**\n * Defines a many-to-one relationship.\n */\nexport function ManyToOne(\n  typeFunction: () => Function,\n  options: ManyToOneOptions = {}\n) {\n  return function (_: any, context: ClassFieldDecoratorContext) {\n    if (context.kind !== \"field\") return;\n\n    context.addInitializer(function () {\n      const ctor = (this as any).constructor as EntityConstructor;\n      const propertyName = context.name.toString();\n      const metadataArray = getMetadataArray(ctor);\n\n      let metadata = metadataArray.find(\n        (m) => m.propertyName === propertyName\n      );\n\n      if (!metadata) {\n        metadata = {\n          propertyName: propertyName,\n          isId: false,\n          isGenerated: false,\n        };\n        metadataArray.push(metadata);\n      }\n\n      metadata.manyToOneOptions = { type: typeFunction(), options };\n    });\n  };\n}"],
  "mappings": "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",
  "names": []
}

|
|
@@ -126,4 +126,4 @@ class Repository {
|
|
|
126
126
|
export {
|
|
127
127
|
Repository
|
|
128
128
|
};
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/repository.ts"],
  "sourcesContent": ["import { store, translator, EntityConstructor, Options } from \"@aerokit/sdk/db\";\n\n/**\n * Represents the data structure passed to the event trigger method before/after an operation.\n */\nexport interface EntityEvent<T> {\n    readonly operation: 'create' | 'update' | 'delete';\n    readonly table: string;\n    readonly entity: Partial<T>; // Use Partial<T> for create/delete where some fields might be missing\n    readonly key: {\n        name: string;\n        column: string;\n        value: string | number;\n    }\n    readonly previousEntity?: T;\n}\n\n\n// --- Repository Class ---\n\n/**\n * Abstract base class for data access/business logic, wrapping the `store` API.\n * It handles entity metadata lookup, CRUD operations, translation, and event triggering.\n * @template T The entity type (must be an object).\n */\nexport abstract class Repository<T extends Record<string, any>> {\n\n    private entityConstructor: EntityConstructor;\n\n    constructor(entityConstructor: EntityConstructor) {\n        this.entityConstructor = entityConstructor;\n        \n        // Caches entity metadata (name, table, id) onto the constructor function for static access\n\t\tif (!this.entityConstructor.$entity_name) {\n            // Assumes store methods return non-null strings\n\t\t\tthis.entityConstructor.$entity_name = (store as any).getEntityName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$table_name = (store as any).getTableName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_name = (store as any).getIdName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_column = (store as any).getIdColumn(this.entityConstructor.name);\n\t\t}\n    }\n\n    protected getEntityName(): string {\n        // Use non-null assertion since the constructor guarantees these properties exist\n        return this.entityConstructor.$entity_name!;\n    }\n\n    protected getTableName(): string {\n        return this.entityConstructor.$table_name!;\n    }\n\n    protected getIdName(): string {\n        return this.entityConstructor.$id_name!;\n    }\n\n    protected getIdColumn(): string {\n        return this.entityConstructor.$id_column!;\n    }\n\n    /**\n     * Finds all entities matching the given options.\n     */\n    public findAll(options: Options = {}): T[] {\n        // Assume store.list returns T[] but we explicitly cast it to T[]\n        const list: T[] = (store as any).list(this.getEntityName(), options);\n        (translator as any).translateList(list, options.language, this.getTableName());\n        return list;\n    }\n\n    /**\n     * Finds a single entity by its primary key ID.\n     */\n    public findById(id: number | string, options: Options = {}): T | undefined {\n        // Assume store.get returns T or null/undefined\n        const entity: T | null = (store as any).get(this.getEntityName(), id);\n        (translator as any).translateEntity(entity, id, options.language, this.getTableName());\n        return entity ?? undefined;\n    }\n\n    /**\n     * Creates a new entity in the database.\n     * @returns The generated ID (string or number).\n     */\n    public create(entity: T): string | number {\n        const id = (store as any).save(this.getEntityName(), entity);\n        this.triggerEvent({\n            operation: \"create\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n        return id;\n    }\n\n    /**\n     * Updates an existing entity.\n     * The entity must contain the primary key.\n     */\n    public update(entity: T): void {\n        const idName = this.getIdName();\n        const id = entity[idName] as (number | string);\n        \n        // Retrieve the entity state before update for the event payload\n        const previousEntity = this.findById(id);\n\n        (store as any).update(this.getEntityName(), entity);\n        \n        this.triggerEvent({\n            operation: \"update\",\n            table: this.getTableName(),\n            entity: entity,\n            previousEntity: previousEntity,\n            key: {\n                name: idName,\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Creates the entity if the ID is null/undefined, otherwise updates it.\n     * If an ID is provided but the entity doesn't exist, it creates it.\n     * @returns The entity's ID.\n     */\n    public upsert(entity: T): string | number {\n        const id = entity[this.getIdName()];\n        \n        // If no ID is present, save (create)\n        if (id === null || id === undefined) {\n            return (store as any).save(this.getEntityName(), entity);\n        }\n\n        // If ID is present, check existence\n        const existingEntity = (store as any).get(this.getEntityName(), id);\n        \n        if (existingEntity) {\n            this.update(entity);\n            return id;\n        } else {\n            // ID exists, but entity does not -> save (create with provided ID)\n            return (store as any).save(this.getEntityName(), entity);\n        }\n    }\n\n    /**\n     * Deletes an entity by its primary key ID.\n     */\n    public deleteById(id: number | string): void {\n        // Retrieve entity before removal for the event payload\n        const entity = (store as any).get(this.getEntityName(), id);\n        \n        (store as any).remove(this.getEntityName(), id);\n\n        this.triggerEvent({\n            operation: \"delete\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Counts the number of entities matching the given options.\n     */\n    public count(options?: Options): number {\n        return (store as any).count(this.getEntityName(), options);\n    }\n\n    /**\n     * Protected method intended for subclass overriding or internal event handling.\n     */\n    protected async triggerEvent(_data: EntityEvent<T>): Promise<void> {\n        // Empty body as in the original code\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/repository.ts"],
  "sourcesContent": ["import { store, translator, EntityConstructor, Options } from \"@aerokit/sdk/db\";\n\n/**\n * Represents the data structure passed to the event trigger method before/after an operation.\n */\nexport interface EntityEvent<T> {\n    readonly operation: 'create' | 'update' | 'delete';\n    readonly table: string;\n    readonly entity: Partial<T>; // Use Partial<T> for create/delete where some fields might be missing\n    readonly key: {\n        name: string;\n        column: string;\n        value: string | number;\n    }\n    readonly previousEntity?: T;\n}\n\n\n// --- Repository Class ---\n\n/**\n * Abstract base class for data access/business logic, wrapping the `store` API.\n * It handles entity metadata lookup, CRUD operations, translation, and event triggering.\n * @template T The entity type (must be an object).\n */\nexport abstract class Repository<T extends Record<string, any>> {\n\n    private entityConstructor: EntityConstructor;\n\n    constructor(entityConstructor: EntityConstructor) {\n        this.entityConstructor = entityConstructor;\n        \n        // Caches entity metadata (name, table, id) onto the constructor function for static access\n\t\tif (!this.entityConstructor.$entity_name) {\n            // Assumes store methods return non-null strings\n\t\t\tthis.entityConstructor.$entity_name = store.getEntityName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$table_name = store.getTableName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_name = store.getIdName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_column = store.getIdColumn(this.entityConstructor.name);\n\t\t}\n    }\n\n    protected getEntityName(): string {\n        // Use non-null assertion since the constructor guarantees these properties exist\n        return this.entityConstructor.$entity_name!;\n    }\n\n    protected getTableName(): string {\n        return this.entityConstructor.$table_name!;\n    }\n\n    protected getIdName(): string {\n        return this.entityConstructor.$id_name!;\n    }\n\n    protected getIdColumn(): string {\n        return this.entityConstructor.$id_column!;\n    }\n\n    /**\n     * Finds all entities matching the given options.\n     */\n    public findAll(options: Options = {}): T[] {\n        // Assume store.list returns T[] but we explicitly cast it to T[]\n        const list: T[] = store.list(this.getEntityName(), options);\n        translator.translateList(list, options.language, this.getTableName());\n        return list;\n    }\n\n    /**\n     * Finds a single entity by its primary key ID.\n     */\n    public findById(id: number | string, options: Options = {}): T | undefined {\n        // Assume store.get returns T or null/undefined\n        const entity: T | null = store.get(this.getEntityName(), id);\n        translator.translateEntity(entity, id, options.language, this.getTableName());\n        return entity ?? undefined;\n    }\n\n    /**\n     * Creates a new entity in the database.\n     * @returns The generated ID (string or number).\n     */\n    public create(entity: T): string | number {\n        const id = store.save(this.getEntityName(), entity);\n        this.triggerEvent({\n            operation: \"create\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n        return id;\n    }\n\n    /**\n     * Updates an existing entity.\n     * The entity must contain the primary key.\n     */\n    public update(entity: T): void {\n        const idName = this.getIdName();\n        const id = entity[idName] as (number | string);\n        \n        // Retrieve the entity state before update for the event payload\n        const previousEntity = this.findById(id);\n\n        store.update(this.getEntityName(), entity);\n        \n        this.triggerEvent({\n            operation: \"update\",\n            table: this.getTableName(),\n            entity: entity,\n            previousEntity: previousEntity,\n            key: {\n                name: idName,\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Creates the entity if the ID is null/undefined, otherwise updates it.\n     * If an ID is provided but the entity doesn't exist, it creates it.\n     * @returns The entity's ID.\n     */\n    public upsert(entity: T): string | number {\n        const id = entity[this.getIdName()];\n        \n        // If no ID is present, save (create)\n        if (id === null || id === undefined) {\n            return store.save(this.getEntityName(), entity);\n        }\n\n        // If ID is present, check existence\n        const existingEntity = store.get(this.getEntityName(), id);\n        \n        if (existingEntity) {\n            this.update(entity);\n            return id;\n        } else {\n            // ID exists, but entity does not -> save (create with provided ID)\n            return store.save(this.getEntityName(), entity);\n        }\n    }\n\n    /**\n     * Deletes an entity by its primary key ID.\n     */\n    public deleteById(id: number | string): void {\n        // Retrieve entity before removal for the event payload\n        const entity = store.get(this.getEntityName(), id);\n        \n        store.remove(this.getEntityName(), id);\n\n        this.triggerEvent({\n            operation: \"delete\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Counts the number of entities matching the given options.\n     */\n    public count(options?: Options): number {\n        return store.count(this.getEntityName(), options);\n    }\n\n    /**\n     * Protected method intended for subclass overriding or internal event handling.\n     */\n    protected async triggerEvent(_data: EntityEvent<T>): Promise<void> {\n        // Empty body as in the original code\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

|
package/dist/esm/db/store.mjs
CHANGED
|
@@ -50,7 +50,7 @@ class Store {
|
|
|
50
50
|
*/
|
|
51
51
|
static list(name, options) {
|
|
52
52
|
const result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);
|
|
53
|
-
return
|
|
53
|
+
return Store.parseResult(result);
|
|
54
54
|
}
|
|
55
55
|
/**
|
|
56
56
|
* Counts the number of entries based on optional filtering options.
|
|
@@ -74,7 +74,7 @@ class Store {
|
|
|
74
74
|
if (result === null || result === void 0 || result === "") {
|
|
75
75
|
return void 0;
|
|
76
76
|
}
|
|
77
|
-
return
|
|
77
|
+
return Store.parseResult(result);
|
|
78
78
|
}
|
|
79
79
|
/**
|
|
80
80
|
* Deletes an entry by its ID.
|
|
@@ -94,7 +94,7 @@ class Store {
|
|
|
94
94
|
*/
|
|
95
95
|
static find(name, example, limit = 100, offset = 0) {
|
|
96
96
|
const result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);
|
|
97
|
-
return
|
|
97
|
+
return Store.parseResult(result);
|
|
98
98
|
}
|
|
99
99
|
/**
|
|
100
100
|
* Queries all entries for a given script with pagination.
|
|
@@ -124,22 +124,22 @@ class Store {
|
|
|
124
124
|
}
|
|
125
125
|
if (arr.length === 0) {
|
|
126
126
|
const result = DataStoreFacade.query(query, null, limit, offset);
|
|
127
|
-
return
|
|
127
|
+
return Store.parseResult(result);
|
|
128
128
|
}
|
|
129
129
|
const first = arr[0];
|
|
130
130
|
if (first && typeof first === "object" && "name" in first && "type" in first) {
|
|
131
131
|
const result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);
|
|
132
|
-
return
|
|
132
|
+
return Store.parseResult(result);
|
|
133
133
|
}
|
|
134
134
|
if (first && typeof first === "object" && "type" in first && !("name" in first)) {
|
|
135
135
|
const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);
|
|
136
|
-
return
|
|
136
|
+
return Store.parseResult(result);
|
|
137
137
|
}
|
|
138
138
|
if (arr.every(
|
|
139
139
|
(v) => typeof v === "string" || typeof v === "number" || typeof v === "boolean" || v instanceof Date || Array.isArray(v)
|
|
140
140
|
)) {
|
|
141
141
|
const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);
|
|
142
|
-
return
|
|
142
|
+
return Store.parseResult(result);
|
|
143
143
|
}
|
|
144
144
|
throw new Error("Unsupported parameter format: " + JSON.stringify(parameters));
|
|
145
145
|
}
|
|
@@ -169,22 +169,22 @@ class Store {
|
|
|
169
169
|
}
|
|
170
170
|
if (arr.length === 0) {
|
|
171
171
|
const result = DataStoreFacade.queryNative(query, null, limit, offset);
|
|
172
|
-
return
|
|
172
|
+
return Store.parseResult(result);
|
|
173
173
|
}
|
|
174
174
|
const first = arr[0];
|
|
175
175
|
if (first && typeof first === "object" && "name" in first && "type" in first) {
|
|
176
176
|
const result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);
|
|
177
|
-
return
|
|
177
|
+
return Store.parseResult(result);
|
|
178
178
|
}
|
|
179
179
|
if (first && typeof first === "object" && "type" in first && !("name" in first)) {
|
|
180
180
|
const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);
|
|
181
|
-
return
|
|
181
|
+
return Store.parseResult(result);
|
|
182
182
|
}
|
|
183
183
|
if (arr.every(
|
|
184
184
|
(v) => typeof v === "string" || typeof v === "number" || typeof v === "boolean" || v instanceof Date || Array.isArray(v)
|
|
185
185
|
)) {
|
|
186
186
|
const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);
|
|
187
|
-
return
|
|
187
|
+
return Store.parseResult(result);
|
|
188
188
|
}
|
|
189
189
|
throw new Error("Unsupported parameter format: " + JSON.stringify(parameters));
|
|
190
190
|
}
|
|
@@ -213,6 +213,73 @@ class Store {
|
|
|
213
213
|
static getIdColumn(name) {
|
|
214
214
|
return DataStoreFacade.getIdColumn(name);
|
|
215
215
|
}
|
|
216
|
+
/**
|
|
217
|
+
* Parse a JSON string and revive ISO date strings into JS Date objects.
|
|
218
|
+
* It handles both full ISO timestamps (with timezone) and date-only strings (YYYY-MM-DD).
|
|
219
|
+
* Returns undefined for null/empty inputs.
|
|
220
|
+
*/
|
|
221
|
+
static parseResult(result) {
|
|
222
|
+
if (result === null || result === void 0 || result === "") {
|
|
223
|
+
return void 0;
|
|
224
|
+
}
|
|
225
|
+
if (typeof result !== "string") {
|
|
226
|
+
return result;
|
|
227
|
+
}
|
|
228
|
+
const ISO_DATETIME = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+\-]\d{2}:?\d{2})$/;
|
|
229
|
+
const DATE_ONLY = /^\d{4}-\d{2}-\d{2}$/;
|
|
230
|
+
const TZ_NO_COLON = /([+\-]\d{2})(\d{2})$/;
|
|
231
|
+
const SPACE_DATETIME = /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+\-]\d{2}:?\d{2})?$/;
|
|
232
|
+
const TIME_ONLY = /^\d{2}:\d{2}:\d{2}(?:\.\d+)?$/;
|
|
233
|
+
const EPOCH_MS = /^[+\-]?\d{13}$/;
|
|
234
|
+
const EPOCH_S = /^[+\-]?\d{10}$/;
|
|
235
|
+
return JSON.parse(result, (key, value) => {
|
|
236
|
+
if (typeof value === "string") {
|
|
237
|
+
const s = value.trim();
|
|
238
|
+
if (EPOCH_MS.test(s)) {
|
|
239
|
+
const ms = parseInt(s, 10);
|
|
240
|
+
return new Date(ms);
|
|
241
|
+
}
|
|
242
|
+
if (EPOCH_S.test(s)) {
|
|
243
|
+
const ms = parseInt(s, 10) * 1e3;
|
|
244
|
+
return new Date(ms);
|
|
245
|
+
}
|
|
246
|
+
if (SPACE_DATETIME.test(s)) {
|
|
247
|
+
let v = s.replace(" ", "T");
|
|
248
|
+
if (TZ_NO_COLON.test(v)) {
|
|
249
|
+
v = v.replace(TZ_NO_COLON, "$1:$2");
|
|
250
|
+
}
|
|
251
|
+
const d = new Date(v);
|
|
252
|
+
if (!isNaN(d.getTime())) {
|
|
253
|
+
return d;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
if (TIME_ONLY.test(s)) {
|
|
257
|
+
const m = s.match(/(\d{2}):(\d{2}):(\d{2})(?:\.(\d+))?/);
|
|
258
|
+
if (m) {
|
|
259
|
+
const hh = parseInt(m[1], 10);
|
|
260
|
+
const mm = parseInt(m[2], 10);
|
|
261
|
+
const ss = parseInt(m[3], 10);
|
|
262
|
+
const frac = m[4] ? (m[4] + "000").substring(0, 3) : "000";
|
|
263
|
+
const ms = parseInt(frac, 10);
|
|
264
|
+
const now = /* @__PURE__ */ new Date();
|
|
265
|
+
const d = new Date(Date.UTC(now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate(), hh, mm, ss, ms));
|
|
266
|
+
return d;
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
if (ISO_DATETIME.test(s) || DATE_ONLY.test(s)) {
|
|
270
|
+
let v = s;
|
|
271
|
+
if (TZ_NO_COLON.test(v)) {
|
|
272
|
+
v = v.replace(TZ_NO_COLON, "$1:$2");
|
|
273
|
+
}
|
|
274
|
+
const d = new Date(v);
|
|
275
|
+
if (!isNaN(d.getTime())) {
|
|
276
|
+
return d;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
return value;
|
|
281
|
+
});
|
|
282
|
+
}
|
|
216
283
|
}
|
|
217
284
|
if (typeof module !== "undefined") {
|
|
218
285
|
module.exports = Store;
|
|
@@ -222,4 +289,4 @@ export {
|
|
|
222
289
|
Operator,
|
|
223
290
|
Store
|
|
224
291
|
};
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/store.ts"],
  "sourcesContent": ["const DataStoreFacade = Java.type(\"org.eclipse.dirigible.components.api.db.DataStoreFacade\");\n\n/**\n * Defines the available comparison operators for query conditions.\n */\nexport enum Operator {\n\tEQ = \"=\", // Equals\n\tNE = \"<>\", // Not Equals\n\tGT = \">\", // Greater Than\n\tLT = \"<\", // Less Than\n\tGE = \">=\", // Greater Than or Equals\n\tLE = \"<=\", // Less Than or Equals\n\tLIKE = \"LIKE\", // SQL LIKE operator\n\tBETWEEN = \"BETWEEN\", // SQL BETWEEN operator (requires two values)\n\tIN = \"IN\" // SQL IN operator (requires a List or Array of values)\n}\n\n/**\n * Defines the direction for sorting.\n */\nexport enum Direction {\n\tASC = \"ASC\", // Ascending\n\tDESC = \"DESC\" // Descending\n}\n\n/**\n * Represents a single condition for filtering data.\n */\nexport interface Condition {\n\tpropertyName: string,\n\toperator: Operator,\n\tvalue: any | any[]\n}\n\n/**\n * Represents a single sorting instruction.\n */\nexport interface Sort {\n\tpropertyName: string,\n\tdirection: Direction\n}\n\n/**\n * Defines optional parameters for list and count operations.\n */\nexport interface Options {\n\tconditions?: Condition[],\n\tsorts?: Sort[],\n\tlimit?: number,\n\toffset?: number,\n\tlanguage?: string\n}\n\nimport { TypedQueryParameter, NamedQueryParameter } from './query';\n\n/**\n * Facade class for interacting with the underlying Dirigible Data Store.\n * All methods serialize/deserialize JavaScript objects to/from JSON strings\n * before interacting with the native Java facade.\n */\nexport class Store {\n\n\t/**\n\t * Saves a new entry to the data store.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to save.\n\t * @returns The ID of the newly created entry (string or number).\n\t */\n\tpublic static save(name: string, entry: any): string | number {\n\t\treturn DataStoreFacade.save(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Inserts a new entry or updates an existing one if the ID is present.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to insert/update.\n\t */\n\tpublic static upsert(name: string, entry: any): void {\n\t\tDataStoreFacade.upsert(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Updates an existing entry.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object with the ID and updated data.\n\t */\n\tpublic static update(name: string, entry: any): void {\n\t\tDataStoreFacade.update(name, JSON.stringify(entry));\n\t}\n\t\n\t/**\n\t * Lists entries based on optional filtering, sorting, and pagination options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static list(name: string, options?: Options): any[] {\n\t\tconst result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);\n\t\treturn JSON.parse(result);\n\t}\n\t\n\t/**\n\t * Counts the number of entries based on optional filtering options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns The count of matching entries.\n\t */\n\tpublic static count(name: string, options?: Options): number {\n\t\tconst optionsString = options ? JSON.stringify(options) : null;\n\t\tconst result = DataStoreFacade.count(name, optionsString);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Retrieves a single entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry.\n\t * @returns The entry object, or undefined if not found.\n\t */\n\tpublic static get(name: string, id: any): any | undefined {\n\t\tconst result = DataStoreFacade.get(name, id);\n\t\t// Assuming the native API returns null/undefined or an empty JSON string if not found, \n\t\t// otherwise JSON.parse handles the conversion.\n\t\tif (result === null || result === undefined || result === \"\") {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn JSON.parse(result);\n\t};\n\n\t/**\n\t * Deletes an entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry to remove.\n\t */\n\tpublic static remove(name: string, id: any): void {\n\t\tDataStoreFacade.deleteEntry(name, id);\n\t}\n\t\n\t/**\n\t * Finds entries matching an example object (query-by-example).\n\t * @param name The entity/table name.\n\t * @param example An object containing properties to match.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of matching JavaScript objects.\n\t */\n\tpublic static find(name: string, example: any, limit: number = 100, offset: number = 0): any[] {\n\t\tconst result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);\n\t\treturn JSON.parse(result);\n\t}\n\t\n\t/**\n\t * Queries all entries for a given script with pagination.\n\t * @param query The query script.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static query(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t    if (parameters == null) {\n\t      arr = [];\n\t    } else if (typeof parameters === \"string\") {\n\t      try {\n\t        const parsed = JSON.parse(parameters);\n\t        if (!Array.isArray(parsed)) {\n\t          throw new Error(\"Input parameter string must represent a JSON array\");\n\t        }\n\t        arr = parsed;\n\t      } catch (e) {\n\t        throw new Error(\"Invalid JSON parameters: \" + e);\n\t      }\n\t    } else if (Array.isArray(parameters)) {\n\t      arr = parameters;\n\t    } else {\n\t      throw new Error(\"Parameters must be either an array or a JSON string\");\n\t    }\n\n\t    if (arr.length === 0) {\n\t\t  const result = DataStoreFacade.query(query, null, limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    const first = arr[0];\n\n\t    // NamedQueryParameter (has name + type)\n\t    if (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t  const result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // TypedQueryParameter (has type, no name)\n\t    if (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t  const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // Primitive array\n\t    if (\n\t      arr.every(\n\t        (v) =>\n\t          typeof v === \"string\" ||\n\t          typeof v === \"number\" ||\n\t          typeof v === \"boolean\" ||\n\t          v instanceof Date\t||\n\t\t  \t  Array.isArray(v)\n\t      )\n\t    ) {\n\t\t  const result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    throw new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\t\n\t/**\n\t * Queries all entries for a given entity name without pagination.\n\t * @param query The entity/table name.\n\t * @returns An array of all JavaScript objects.\n\t */\n\tpublic static queryNative(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t      arr = [];\n\t    } else if (typeof parameters === \"string\") {\n\t      try {\n\t        const parsed = JSON.parse(parameters);\n\t        if (!Array.isArray(parsed)) {\n\t          throw new Error(\"Input parameter string must represent a JSON array\");\n\t        }\n\t        arr = parsed;\n\t      } catch (e) {\n\t        throw new Error(\"Invalid JSON parameters: \" + e);\n\t      }\n\t    } else if (Array.isArray(parameters)) {\n\t      arr = parameters;\n\t    } else {\n\t      throw new Error(\"Parameters must be either an array or a JSON string\");\n\t    }\n\n\t    if (arr.length === 0) {\n\t\t  const result = DataStoreFacade.queryNative(query, null, limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    const first = arr[0];\n\n\t    // NamedQueryParameter (has name + type)\n\t    if (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t  const result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // TypedQueryParameter (has type, no name)\n\t    if (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t  const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    // Primitive array\n\t    if (\n\t      arr.every(\n\t        (v) =>\n\t          typeof v === \"string\" ||\n\t          typeof v === \"number\" ||\n\t          typeof v === \"boolean\" ||\n\t          v instanceof Date ||\n\t\t\t  Array.isArray(v)\n\t      )\n\t    ) {\n\t\t  const result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t  return JSON.parse(result);\n\t    }\n\n\t    throw new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\t\n\t// --- Metadata Getters ---\n\n\t/**\n\t * Gets the name of the entity associated with the store name.\n\t */\n\tpublic static getEntityName(name: string): string {\n\t\treturn DataStoreFacade.getEntityName(name);\n\t}\n\t\n\t/**\n\t * Gets the underlying database table name for the entity.\n\t */\n\tpublic static getTableName(name: string): string {\n\t\treturn DataStoreFacade.getTableName(name);\n\t}\n\t\t\n\t/**\n\t * Gets the property name used as the ID field in the entity object.\n\t */\n\tpublic static getIdName(name: string): string {\n\t\treturn DataStoreFacade.getIdName(name);\n\t}\n\t\t\t\n\t/**\n\t * Gets the underlying database column name used for the ID field.\n\t */\n\tpublic static getIdColumn(name: string): string {\n\t\treturn DataStoreFacade.getIdColumn(name);\n\t}\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Store;\n}"],
  "mappings": "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",
  "names": ["Operator", "Direction"]
}

|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/store.ts"],
  "sourcesContent": ["const DataStoreFacade = Java.type(\"org.eclipse.dirigible.components.api.db.DataStoreFacade\");\n\n/**\n * Defines the available comparison operators for query conditions.\n */\nexport enum Operator {\n\tEQ = \"=\", // Equals\n\tNE = \"<>\", // Not Equals\n\tGT = \">\", // Greater Than\n\tLT = \"<\", // Less Than\n\tGE = \">=\", // Greater Than or Equals\n\tLE = \"<=\", // Less Than or Equals\n\tLIKE = \"LIKE\", // SQL LIKE operator\n\tBETWEEN = \"BETWEEN\", // SQL BETWEEN operator (requires two values)\n\tIN = \"IN\" // SQL IN operator (requires a List or Array of values)\n}\n\n/**\n * Defines the direction for sorting.\n */\nexport enum Direction {\n\tASC = \"ASC\", // Ascending\n\tDESC = \"DESC\" // Descending\n}\n\n/**\n * Represents a single condition for filtering data.\n */\nexport interface Condition {\n\tpropertyName: string,\n\toperator: Operator,\n\tvalue: any | any[]\n}\n\n/**\n * Represents a single sorting instruction.\n */\nexport interface Sort {\n\tpropertyName: string,\n\tdirection: Direction\n}\n\n/**\n * Defines optional parameters for list and count operations.\n */\nexport interface Options {\n\tconditions?: Condition[],\n\tsorts?: Sort[],\n\tlimit?: number,\n\toffset?: number,\n\tlanguage?: string\n}\n\nimport { TypedQueryParameter, NamedQueryParameter } from './query';\n\n/**\n * Facade class for interacting with the underlying Dirigible Data Store.\n * All methods serialize/deserialize JavaScript objects to/from JSON strings\n * before interacting with the native Java facade.\n */\nexport class Store {\n\n\t/**\n\t * Saves a new entry to the data store.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to save.\n\t * @returns The ID of the newly created entry (string or number).\n\t */\n\tpublic static save(name: string, entry: any): string | number {\n\t\treturn DataStoreFacade.save(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Inserts a new entry or updates an existing one if the ID is present.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object to insert/update.\n\t */\n\tpublic static upsert(name: string, entry: any): void {\n\t\tDataStoreFacade.upsert(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Updates an existing entry.\n\t * @param name The entity/table name.\n\t * @param entry The JavaScript object with the ID and updated data.\n\t */\n\tpublic static update(name: string, entry: any): void {\n\t\tDataStoreFacade.update(name, JSON.stringify(entry));\n\t}\n\n\t/**\n\t * Lists entries based on optional filtering, sorting, and pagination options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static list(name: string, options?: Options): any[] {\n\t\tconst result = DataStoreFacade.list(name, options ? JSON.stringify(options) : null);\n\t\treturn Store.parseResult(result);\n\t}\n\n\t/**\n\t * Counts the number of entries based on optional filtering options.\n\t * @param name The entity/table name.\n\t * @param options Optional {@link Options} for query execution.\n\t * @returns The count of matching entries.\n\t */\n\tpublic static count(name: string, options?: Options): number {\n\t\tconst optionsString = options ? JSON.stringify(options) : null;\n\t\tconst result = DataStoreFacade.count(name, optionsString);\n\t\treturn result;\n\t}\n\n\t/**\n\t * Retrieves a single entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry.\n\t * @returns The entry object, or undefined if not found.\n\t */\n\tpublic static get(name: string, id: any): any | undefined {\n\t\tconst result = DataStoreFacade.get(name, id);\n\t\t// Assuming the native API returns null/undefined or an empty JSON string if not found, \n\t\t// otherwise JSON.parse handles the conversion.\n\t\tif (result === null || result === undefined || result === \"\") {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn Store.parseResult(result);\n\t};\n\n\t/**\n\t * Deletes an entry by its ID.\n\t * @param name The entity/table name.\n\t * @param id The ID of the entry to remove.\n\t */\n\tpublic static remove(name: string, id: any): void {\n\t\tDataStoreFacade.deleteEntry(name, id);\n\t}\n\n\t/**\n\t * Finds entries matching an example object (query-by-example).\n\t * @param name The entity/table name.\n\t * @param example An object containing properties to match.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of matching JavaScript objects.\n\t */\n\tpublic static find(name: string, example: any, limit: number = 100, offset: number = 0): any[] {\n\t\tconst result = DataStoreFacade.find(name, JSON.stringify(example), limit, offset);\n\t\treturn Store.parseResult(result);\n\t}\n\n\t/**\n\t * Queries all entries for a given script with pagination.\n\t * @param query The query script.\n\t * @param limit Maximum number of results to return.\n\t * @param offset Number of results to skip.\n\t * @returns An array of JavaScript objects.\n\t */\n\tpublic static query(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t\t\tarr = [];\n\t\t} else if (typeof parameters === \"string\") {\n\t\t\ttry {\n\t\t\t\tconst parsed = JSON.parse(parameters);\n\t\t\t\tif (!Array.isArray(parsed)) {\n\t\t\t\t\tthrow new Error(\"Input parameter string must represent a JSON array\");\n\t\t\t\t}\n\t\t\t\tarr = parsed;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new Error(\"Invalid JSON parameters: \" + e);\n\t\t\t}\n\t\t} else if (Array.isArray(parameters)) {\n\t\t\tarr = parameters;\n\t\t} else {\n\t\t\tthrow new Error(\"Parameters must be either an array or a JSON string\");\n\t\t}\n\n\t\tif (arr.length === 0) {\n\t\t\tconst result = DataStoreFacade.query(query, null, limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tconst first = arr[0];\n\n\t\t// NamedQueryParameter (has name + type)\n\t\tif (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t\tconst result = DataStoreFacade.queryNamed(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// TypedQueryParameter (has type, no name)\n\t\tif (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t\tconst result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// Primitive array\n\t\tif (\n\t\t\tarr.every(\n\t\t\t\t(v) =>\n\t\t\t\t\ttypeof v === \"string\" ||\n\t\t\t\t\ttypeof v === \"number\" ||\n\t\t\t\t\ttypeof v === \"boolean\" ||\n\t\t\t\t\tv instanceof Date ||\n\t\t\t\t\tArray.isArray(v)\n\t\t\t)\n\t\t) {\n\t\t\tconst result = DataStoreFacade.query(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tthrow new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\n\t/**\n\t * Queries all entries for a given entity name without pagination.\n\t * @param query The entity/table name.\n\t * @returns An array of all JavaScript objects.\n\t */\n\tpublic static queryNative(query: string, parameters?: (string | number | boolean | Date | TypedQueryParameter | NamedQueryParameter)[], limit: number = 100, offset: number = 0): any[] {\n\t\tlet arr: any[] = [];\n\t\tif (parameters == null) {\n\t\t\tarr = [];\n\t\t} else if (typeof parameters === \"string\") {\n\t\t\ttry {\n\t\t\t\tconst parsed = JSON.parse(parameters);\n\t\t\t\tif (!Array.isArray(parsed)) {\n\t\t\t\t\tthrow new Error(\"Input parameter string must represent a JSON array\");\n\t\t\t\t}\n\t\t\t\tarr = parsed;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new Error(\"Invalid JSON parameters: \" + e);\n\t\t\t}\n\t\t} else if (Array.isArray(parameters)) {\n\t\t\tarr = parameters;\n\t\t} else {\n\t\t\tthrow new Error(\"Parameters must be either an array or a JSON string\");\n\t\t}\n\n\t\tif (arr.length === 0) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, null, limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tconst first = arr[0];\n\n\t\t// NamedQueryParameter (has name + type)\n\t\tif (first && typeof first === \"object\" && \"name\" in first && \"type\" in first) {\n\t\t\tconst result = DataStoreFacade.queryNativeNamed(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// TypedQueryParameter (has type, no name)\n\t\tif (first && typeof first === \"object\" && \"type\" in first && !(\"name\" in first)) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\t// Primitive array\n\t\tif (\n\t\t\tarr.every(\n\t\t\t\t(v) =>\n\t\t\t\t\ttypeof v === \"string\" ||\n\t\t\t\t\ttypeof v === \"number\" ||\n\t\t\t\t\ttypeof v === \"boolean\" ||\n\t\t\t\t\tv instanceof Date ||\n\t\t\t\t\tArray.isArray(v)\n\t\t\t)\n\t\t) {\n\t\t\tconst result = DataStoreFacade.queryNative(query, JSON.stringify(arr), limit, offset);\n\t\t\treturn Store.parseResult(result);\n\t\t}\n\n\t\tthrow new Error(\"Unsupported parameter format: \" + JSON.stringify(parameters));\n\t}\n\n\t// --- Metadata Getters ---\n\n\t/**\n\t * Gets the name of the entity associated with the store name.\n\t */\n\tpublic static getEntityName(name: string): string {\n\t\treturn DataStoreFacade.getEntityName(name);\n\t}\n\n\t/**\n\t * Gets the underlying database table name for the entity.\n\t */\n\tpublic static getTableName(name: string): string {\n\t\treturn DataStoreFacade.getTableName(name);\n\t}\n\n\t/**\n\t * Gets the property name used as the ID field in the entity object.\n\t */\n\tpublic static getIdName(name: string): string {\n\t\treturn DataStoreFacade.getIdName(name);\n\t}\n\n\t/**\n\t * Gets the underlying database column name used for the ID field.\n\t */\n\tpublic static getIdColumn(name: string): string {\n\t\treturn DataStoreFacade.getIdColumn(name);\n\t}\n\n\t/**\n\t * Parse a JSON string and revive ISO date strings into JS Date objects.\n\t * It handles both full ISO timestamps (with timezone) and date-only strings (YYYY-MM-DD).\n\t * Returns undefined for null/empty inputs.\n\t */\n\tprivate static parseResult(result: any): any {\n\t\tif (result === null || result === undefined || result === '') {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (typeof result !== 'string') {\n\t\t\t// already an object/array\n\t\t\treturn result;\n\t\t}\n\n\t\t// Accept timezone offsets with or without colon (e.g. +00:00 or +0000)\n\t\tconst ISO_DATETIME = /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|[+\\-]\\d{2}:?\\d{2})$/;\n\t\tconst DATE_ONLY = /^\\d{4}-\\d{2}-\\d{2}$/;\n\t\tconst TZ_NO_COLON = /([+\\-]\\d{2})(\\d{2})$/;\n\t\t// Space-separated datetime: \"YYYY-MM-DD HH:MM:SS\" (optionally with fractional seconds and timezone)\n\t\tconst SPACE_DATETIME = /^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|[+\\-]\\d{2}:?\\d{2})?$/;\n\t\t// Time-only strings like \"11:29:33\" or \"11:29:33.123\"\n\t\tconst TIME_ONLY = /^\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?$/;\n\t\t// Epoch strings: 13-digit ms or 10-digit seconds\n\t\tconst EPOCH_MS = /^[+\\-]?\\d{13}$/;\n\t\tconst EPOCH_S = /^[+\\-]?\\d{10}$/;\n\n\t\treturn JSON.parse(result, (key, value) => {\n\t\t\tif (typeof value === 'string') {\n\t\t\t\tconst s = value.trim();\n\n\t\t\t\t// Epoch millisecond/second strings\n\t\t\t\tif (EPOCH_MS.test(s)) {\n\t\t\t\t\tconst ms = parseInt(s, 10);\n\t\t\t\t\treturn new Date(ms);\n\t\t\t\t}\n\t\t\t\tif (EPOCH_S.test(s)) {\n\t\t\t\t\tconst ms = parseInt(s, 10) * 1000;\n\t\t\t\t\treturn new Date(ms);\n\t\t\t\t}\n\n\t\t\t\t// Space-separated datetimes: normalize to ISO and parse\n\t\t\t\tif (SPACE_DATETIME.test(s)) {\n\t\t\t\t\tlet v = s.replace(' ', 'T');\n\t\t\t\t\tif (TZ_NO_COLON.test(v)) {\n\t\t\t\t\t\tv = v.replace(TZ_NO_COLON, '$1:$2');\n\t\t\t\t\t}\n\t\t\t\t\tconst d = new Date(v);\n\t\t\t\t\tif (!isNaN(d.getTime())) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Time-only strings: attach current UTC date and parse as UTC\n\t\t\t\tif (TIME_ONLY.test(s)) {\n\t\t\t\t\tconst m = s.match(/(\\d{2}):(\\d{2}):(\\d{2})(?:\\.(\\d+))?/);\n\t\t\t\t\tif (m) {\n\t\t\t\t\t\tconst hh = parseInt(m[1], 10);\n\t\t\t\t\t\tconst mm = parseInt(m[2], 10);\n\t\t\t\t\t\tconst ss = parseInt(m[3], 10);\n\t\t\t\t\t\tconst frac = m[4] ? (m[4] + '000').substring(0, 3) : '000';\n\t\t\t\t\t\tconst ms = parseInt(frac, 10);\n\t\t\t\t\t\tconst now = new Date();\n\t\t\t\t\t\tconst d = new Date(Date.UTC(now.getUTCFullYear(), now.getUTCMonth(), now.getUTCDate(), hh, mm, ss, ms));\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (ISO_DATETIME.test(s) || DATE_ONLY.test(s)) {\n\t\t\t\t\t// normalize timezone without colon (e.g. +0000 -> +00:00) because Date parsing\n\t\t\t\t\t// prefers the colon-separated offset in many JS engines\n\t\t\t\t\tlet v = s;\n\t\t\t\t\tif (TZ_NO_COLON.test(v)) {\n\t\t\t\t\t\tv = v.replace(TZ_NO_COLON, '$1:$2');\n\t\t\t\t\t}\n\t\t\t\t\tconst d = new Date(v);\n\t\t\t\t\tif (!isNaN(d.getTime())) {\n\t\t\t\t\t\treturn d;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn value;\n\t\t});\n\t}\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Store;\n}"],
  "mappings": "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",
  "names": ["Operator", "Direction"]
}

|