@appconda/sdk 1.0.634 → 1.0.636

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.
@@ -201,9 +201,31 @@ export type TDriveBreadcrumb = {
201
201
  id: string;
202
202
  name: string;
203
203
  };
204
+ export type TDriveRootProvider = "LOCAL" | "GOOGLE_DRIVE" | "DROPBOX";
205
+ export type TDriveRoot = {
206
+ id: string;
207
+ tenantId: string;
208
+ provider: TDriveRootProvider;
209
+ name: string;
210
+ credentialId?: string | null;
211
+ remoteRootId?: string | null;
212
+ remoteRootPath?: string | null;
213
+ isDefaultLocal: boolean;
214
+ createdAt?: string;
215
+ updatedAt?: string;
216
+ };
217
+ export type TDriveProviderFolder = {
218
+ id: string;
219
+ name: string;
220
+ parentId?: string | null;
221
+ path?: string | null;
222
+ };
204
223
  export type TDriveItem = {
205
224
  id: string;
206
225
  tenantId: string;
226
+ rootId?: string;
227
+ provider?: TDriveRootProvider;
228
+ isRemote?: boolean;
207
229
  name: string;
208
230
  normalizedName?: string;
209
231
  kind: string;
@@ -223,6 +245,8 @@ export type TDriveItem = {
223
245
  export type TDriveTreeNode = {
224
246
  id: string;
225
247
  tenantId: string;
248
+ rootId?: string;
249
+ provider?: TDriveRootProvider;
226
250
  name: string;
227
251
  parentId?: string | null;
228
252
  kind: string;
@@ -242,6 +266,13 @@ export type TDriveDeleteImpact = {
242
266
  totalFolders: number;
243
267
  totalBytes: number;
244
268
  };
269
+ export type TDriveFileContent = {
270
+ item: TDriveItem;
271
+ base64: string;
272
+ content: string | null;
273
+ mimeType: string;
274
+ sizeBytes: number;
275
+ };
245
276
  export type TWikiFileViewResolution = {
246
277
  fileId: string;
247
278
  path: string;
@@ -349,7 +380,7 @@ export type TDataModel = {
349
380
  id: string;
350
381
  name: string;
351
382
  displayName: string;
352
- description: string;
383
+ description?: string | null;
353
384
  importSource?: string | null;
354
385
  };
355
386
  export type TCollection = {
@@ -399,6 +430,16 @@ export type TCollectionRelation = {
399
430
  targetFieldDisplayName?: string | null;
400
431
  };
401
432
  export type TAutomationRuleTriggerType = "created" | "updated" | "linked" | "unlinked" | "schedule";
433
+ export type TCollectionAutomationRuleConditionOperator = "is" | "is-not" | "contains" | "is-empty" | "is-not-empty";
434
+ export type TCollectionAutomationRuleTriggerConfig = {
435
+ updatedFieldId?: string | null;
436
+ };
437
+ export type TCollectionAutomationRuleCondition = {
438
+ id: string;
439
+ fieldId: string;
440
+ operator: TCollectionAutomationRuleConditionOperator;
441
+ value?: string | string[] | boolean | null;
442
+ };
402
443
  export type TAutomationRuleActionType = "create" | "update" | "delete" | "append-description" | "script";
403
444
  export type TAutomationRuleAction = {
404
445
  id: string;
@@ -424,6 +465,8 @@ export type TCollectionAutomationRule = {
424
465
  description: string;
425
466
  enabled: boolean;
426
467
  trigger: TAutomationRuleTriggerType;
468
+ triggerConfig?: TCollectionAutomationRuleTriggerConfig | null;
469
+ conditions?: TCollectionAutomationRuleCondition[];
427
470
  actions: TAutomationRuleAction[];
428
471
  activity: TAutomationRuleActivityItem[];
429
472
  createdAt: string;
@@ -434,10 +477,43 @@ export type TCollectionViewColumn = {
434
477
  visible: boolean;
435
478
  width?: number;
436
479
  };
437
- export type TCollectionViewConfig = {
480
+ export type TCollectionGridViewConfig = {
438
481
  version: 1;
439
482
  columns: TCollectionViewColumn[];
483
+ filters: TCollectionBoardFilterRule[];
484
+ };
485
+ export type TCollectionBoardCardSize = "small" | "medium" | "large";
486
+ export type TCollectionBoardColorMode = "group" | "none";
487
+ export type TCollectionBoardFilterOperator = "is" | "is-not" | "contains" | "is-empty" | "is-not-empty";
488
+ export type TCollectionBoardFilterRule = {
489
+ id: string;
490
+ fieldName: string;
491
+ operator: TCollectionBoardFilterOperator;
492
+ value?: string | string[] | boolean | null;
440
493
  };
494
+ export type TCollectionBoardSortRule = {
495
+ id: string;
496
+ fieldName: string;
497
+ direction: "asc" | "desc";
498
+ };
499
+ export type TCollectionBoardGroupVisibleFieldOverride = {
500
+ groupId: string;
501
+ visibleFieldNames: string[];
502
+ };
503
+ export type TCollectionBoardViewConfig = {
504
+ version: 1;
505
+ columns: TCollectionViewColumn[];
506
+ titleFieldName: string;
507
+ groupByFieldName: string;
508
+ columnOrder: string[];
509
+ cardOrderByColumn?: Record<string, string[]>;
510
+ cardSize: TCollectionBoardCardSize;
511
+ filters: TCollectionBoardFilterRule[];
512
+ sorts: TCollectionBoardSortRule[];
513
+ colorMode: TCollectionBoardColorMode;
514
+ groupVisibleFieldOverrides: TCollectionBoardGroupVisibleFieldOverride[];
515
+ };
516
+ export type TCollectionViewConfig = TCollectionGridViewConfig | TCollectionBoardViewConfig;
441
517
  export type TCollectionView = {
442
518
  id: string;
443
519
  tenantId: string;
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/modules/emploid/types.ts"],"names":[],"mappings":"","sourcesContent":["\nexport type TEmploid = {\n    id: string;\n    name: string;\n    description: string;\n    status: string;\n    occupation: string;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TPaginatedEmploidsResult = {\n    emploids: TEmploid[];\n    totalCount: number;\n    hasMore: boolean;\n    nextCursor?: string;\n};\n\nexport type TScope = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    parentScopeId?: string | null;\n    name: string;\n    description: string;\n    type?: string;\n    isFolderType?: boolean;\n    content?: any;\n    markdownContent?: string;\n    createdAt?: string;\n    updatedAt?: string;\n}\n\nexport type TOccupation = {\n    tenantId: string;\n    id: string;\n    name: string;\n    description: string;\n    topics: TDomainTopic[];\n}\n\nexport type TDomainTopic = {\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n}\n\nexport type TJobDefinition = {\n    id: string;\n    emploidId: string;\n    scopeId: string;\n    name: string;\n    description: string;\n    category: string;\n    priority: string;\n    status: string;\n}\n\nexport type TCompetency = {\n    id: string;\n    emploidId: string;\n    scopeId: string;\n    jobDefinitionId: string;\n    name: string;\n    description: string;\n    inputs: any[];\n}\n\nexport type TAgentFlow = {\n    id: string;\n    name: string;\n    description: string;\n    folderId: string;\n}\n\nexport type TDeleteAgentFlowResult = {\n    deleted: boolean;\n    id: string;\n}\n\nexport type TAgentFlowFolder = {\n    id: string;\n    name: string;\n    description: string;\n    agentFlows: TAgentFlow[];\n}\n\nexport type TExtension = {\n    tenantId: string;\n    id: string;\n    extensionId: string;\n    config: any;\n}\n\nexport type TAssistant = {\n    id: string;\n    alias: string;\n    name: string;\n    description: string;\n    prompt: string;\n    config: {\n        mode: \"simple\" | \"advanced\"\n    }\n}\n\nexport type TAssistantInstruction = {\n    tenantId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: any;\n    assistantId: string;\n    assistant: TAssistant;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TAssistantConstraint = {\n    tenantId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    constraints: any;\n    assistantId: string;\n    assistant: TAssistant;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TAssistantDatasource = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TAssistantSkill = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TAssistantChannel = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TWorker = {\n    id: string;\n    emploidId: string;\n    marketStoreId?: string | null;\n    emploid: TEmploid;\n    name: string;\n    description: string;\n    avatar: string;\n    status: string;\n    version: number;\n    publishDate: string;\n}\n\nexport type TInput = {\n    id: string;\n    emploidId: string;\n    competencyId: string;\n    name: string;\n    description: string;\n    type: string;\n}\n\nexport type TTeam = {\n    id: string;\n    alias: string;\n    name: string;\n    description: string;\n}\n\nexport type TChat = {\n    id: string;\n    createdAt: string;\n    title: string;\n    userId: string;\n    visibility: string;\n    lastContext: any;\n}\n\n\nexport type TDocument = {\n    id: string;\n    createdAt: string;\n    title: string;\n    content?: string;\n    kind: string;\n    userId: string;\n}\n\nexport type TUploadedFile = {\n    id?: string;\n    fileId?: string;\n    bucketId?: string;\n    fileName?: string;\n    path?: string;\n    pathname?: string;\n    url?: string;\n    filePath?: string;\n    contentType?: string;\n    mimeType?: string;\n    fileSize?: number;\n    size?: number;\n    type?: string;\n    createdAt?: string;\n    updatedAt?: string;\n    [key: string]: any;\n}\n\nexport type TDriveBreadcrumb = {\n    id: string;\n    name: string;\n}\n\nexport type TDriveItem = {\n    id: string;\n    tenantId: string;\n    name: string;\n    normalizedName?: string;\n    kind: string;\n    status: string;\n    parentId?: string | null;\n    storageKey?: string | null;\n    mimeType?: string | null;\n    extension?: string | null;\n    sizeBytes?: number | null;\n    createdBy?: string | null;\n    updatedBy?: string | null;\n    createdAt?: string;\n    updatedAt?: string;\n    breadcrumbs?: TDriveBreadcrumb[];\n    downloadPath?: string | null;\n}\n\nexport type TDriveTreeNode = {\n    id: string;\n    tenantId: string;\n    name: string;\n    parentId?: string | null;\n    kind: string;\n    children: TDriveTreeNode[];\n}\n\nexport type TPreparedDriveUpload = {\n    item: TDriveItem;\n    uploadPath: string;\n    downloadPath: string;\n}\n\nexport type TDriveDeleteImpact = {\n    itemId: string;\n    name: string;\n    kind: string;\n    totalItems: number;\n    totalFiles: number;\n    totalFolders: number;\n    totalBytes: number;\n}\n\nexport type TWikiFileViewResolution = {\n    fileId: string;\n    path: string;\n    url: string;\n    filePath: string;\n    [key: string]: any;\n}\n\nexport type TStreamId = {\n    id: string;\n    chatId: string;\n    createdAt: string;\n}\n\n\n\nexport type TInstruction = {\n    id: string;\n    emploidId: string;\n    content: string;\n    type: string;\n    active: boolean;\n}\n\nexport type TConstraint = {\n    id: string;\n    emploidId: string;\n    content: string;\n    type: string;\n    active: boolean;\n}\n\nexport type TCommand = {\n    id: string;\n    tenantId: string;\n    name: string;\n    description: string;\n    type: string;\n    targetId: string;\n    targetType: string;\n}\n\nexport type TTaskTemplate = {\n    id: string;\n    task: string;\n    description: string;\n    tenantId: string;\n    emploidId: string;\n}\n\nexport type TWikiPageStatus =\n    | \"DRAFT\"\n    | \"PUBLISHED\"\n    | \"ARCHIVED\";\n\nexport interface TWikiPage {\n    // identity\n    id: string;\n    tenantId: string;\n    workspaceId: string;\n\n    // content meta\n    title: string;\n    slug: string;\n    description?: string;\n\n    // tree\n    parentId?: string;\n\n    // state\n    status: TWikiPageStatus;\n\n    // audit\n    createdAt: string;\n    updatedAt: string;\n    deletedAt?: string;\n\n    // relations (opsiyonel, eager load edilirse gelir)\n    parent?: TWikiPage;\n    children?: TWikiPage[];\n\n    // revisions (liste veya sayım için)\n    revisions?: TWikiRevision[];\n    revisionCount?: number;\n\n    // ---- frontend-only / derived fields ----\n\n    // aktif içerik (latest revision’dan gelir)\n    content?: any;\n\n    // liste / arama için\n    contentText?: string;\n\n    // permission cache (ACL UI için)\n    canView?: boolean;\n    canEdit?: boolean;\n    canDelete?: boolean;\n    canManage?: boolean;\n}\n\nexport interface TWikiRevision {\n    id: string;\n    wikiPageId: string;\n\n    content: any;\n\n    createdBy: string;\n    createdAt: string;\n}\n\nexport interface TWikiCommentUser {\n    id: string;\n    name: string;\n    avatarUrl: string;\n}\n\nexport interface TWikiComment {\n    id: string;\n    pageId: string;\n    parentCommentId?: string | null;\n    content: string;\n    selection?: string | null;\n    creatorId: string;\n    workspaceId: string;\n    resolvedAt?: string | null;\n    resolvedById?: string | null;\n    createdAt: string;\n    editedAt?: string | null;\n    deletedAt?: string | null;\n    creator: TWikiCommentUser;\n    resolvedBy?: TWikiCommentUser | null;\n}\n\nexport interface TWikiCommentPagination {\n    items: TWikiComment[];\n    meta: {\n        page: number;\n        limit: number;\n        hasNextPage: boolean;\n        hasPrevPage: boolean;\n    };\n}\n\n\nexport type TDataModel = {\n    id: string;\n    name: string;\n    displayName: string;\n    description: string;\n    importSource?: string | null;\n}\n\nexport type TCollection = {\n    tenantId: string;\n    dataModel: TDataModel;\n    id: string;\n    name: string;\n    displayName: string;\n    description: string;\n    stats: {\n        totalFields: number;\n        activeFields: number;\n        deletedFields: number;\n        data: string;\n        storage: string;\n    }\n}\n\nexport type TCollectionField = {\n    id: string;\n    collectionId: string;\n    dataModelId: string;\n    name: string;\n    displayName: string;\n    type: string;\n    required: boolean;\n    config?: any;\n    order?: number;\n    deletedAt?: string;\n    deletedBy?: string;\n}\n\nexport type TCollectionRelation = {\n    id: string;\n    fieldId: string;\n    fieldName: string;\n    displayName: string;\n    description?: string;\n    cardinality: \"one\" | \"many\";\n    inverseCardinality: \"one\" | \"many\";\n    targetCollectionId: string;\n    targetCollection?: {\n        id: string;\n        name: string;\n        displayName: string;\n    } | null;\n    targetFieldId?: string | null;\n    targetFieldName?: string | null;\n    targetFieldDisplayName?: string | null;\n}\n\nexport type TAutomationRuleTriggerType =\n    | \"created\"\n    | \"updated\"\n    | \"linked\"\n    | \"unlinked\"\n    | \"schedule\";\n\nexport type TAutomationRuleActionType =\n    | \"create\"\n    | \"update\"\n    | \"delete\"\n    | \"append-description\"\n    | \"script\";\n\nexport type TAutomationRuleAction = {\n    id: string;\n    type: TAutomationRuleActionType | null;\n    fieldId?: string | null;\n    value?: string;\n    valueMode?: \"literal\" | \"formula\";\n    formula?: string;\n    template?: string;\n    script?: string;\n}\n\nexport type TAutomationRuleActivityItem = {\n    id: string;\n    message: string;\n    createdAt: string;\n}\n\nexport type TCollectionAutomationRule = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    description: string;\n    enabled: boolean;\n    trigger: TAutomationRuleTriggerType;\n    actions: TAutomationRuleAction[];\n    activity: TAutomationRuleActivityItem[];\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TCollectionViewColumn = {\n    fieldName: string;\n    visible: boolean;\n    width?: number;\n}\n\nexport type TCollectionViewConfig = {\n    version: 1;\n    columns: TCollectionViewColumn[];\n}\n\nexport type TCollectionView = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    type: string;\n    config: TCollectionViewConfig;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TCollectionButtonAction = TAutomationRuleAction;\n\nexport type TCollectionButtonActivityItem = TAutomationRuleActivityItem;\n\nexport type TCollectionButton = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    description: string;\n    enabled: boolean;\n    actions: TCollectionButtonAction[];\n    activity: TCollectionButtonActivityItem[];\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TRelationRecordOption = {\n    id: string;\n    label: string;\n    collectionId: string;\n}\n\nexport type TDatasource = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TSkill = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TChannel = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TKnowledge = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    entityType: string;\n    name: string;\n    description: string;\n    loaderId: string;\n    config: any;\n}\n\nexport type TWorkerTopic = {\n    tenantId: string;\n    workerId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n}\n\nexport type TTopic = {\n    tenantId: string;\n    entityId: string;\n    entityType: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n    category: string;\n}\n\nexport type TPublishDomain = {\n    id: string;\n    tenantId: string;\n    occupationId: string;\n    version: number;\n    prompt: string;\n    data: any;\n}\n\nexport type TPublishEmploid = {\n    id: string;\n    tenantId: string;\n    emploidId: string;\n    version: number;\n    prompt: string;\n    data: any;\n}\n\nexport type TMarketStoreItem = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    itemType: \"worker\";\n    title: string;\n    description: string;\n    avatar: string;\n    summary: Record<string, number>;\n    package: any;\n    createdAt: string;\n    updatedAt: string;\n    publishedAt: string;\n}\n\nexport type TPublishWorkerToMarketStore = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    itemType: \"worker\";\n    title: string;\n    description: string;\n    avatar: string;\n    summary: Record<string, number>;\n    package: any;\n    createdAt: string;\n    updatedAt: string;\n    publishedAt: string;\n}\n\n\nexport type TEnhanceTopic = {\n    tone: string[];\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/modules/emploid/types.ts"],"names":[],"mappings":"","sourcesContent":["\nexport type TEmploid = {\n    id: string;\n    name: string;\n    description: string;\n    status: string;\n    occupation: string;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TPaginatedEmploidsResult = {\n    emploids: TEmploid[];\n    totalCount: number;\n    hasMore: boolean;\n    nextCursor?: string;\n};\n\nexport type TScope = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    parentScopeId?: string | null;\n    name: string;\n    description: string;\n    type?: string;\n    isFolderType?: boolean;\n    content?: any;\n    markdownContent?: string;\n    createdAt?: string;\n    updatedAt?: string;\n}\n\nexport type TOccupation = {\n    tenantId: string;\n    id: string;\n    name: string;\n    description: string;\n    topics: TDomainTopic[];\n}\n\nexport type TDomainTopic = {\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n}\n\nexport type TJobDefinition = {\n    id: string;\n    emploidId: string;\n    scopeId: string;\n    name: string;\n    description: string;\n    category: string;\n    priority: string;\n    status: string;\n}\n\nexport type TCompetency = {\n    id: string;\n    emploidId: string;\n    scopeId: string;\n    jobDefinitionId: string;\n    name: string;\n    description: string;\n    inputs: any[];\n}\n\nexport type TAgentFlow = {\n    id: string;\n    name: string;\n    description: string;\n    folderId: string;\n}\n\nexport type TDeleteAgentFlowResult = {\n    deleted: boolean;\n    id: string;\n}\n\nexport type TAgentFlowFolder = {\n    id: string;\n    name: string;\n    description: string;\n    agentFlows: TAgentFlow[];\n}\n\nexport type TExtension = {\n    tenantId: string;\n    id: string;\n    extensionId: string;\n    config: any;\n}\n\nexport type TAssistant = {\n    id: string;\n    alias: string;\n    name: string;\n    description: string;\n    prompt: string;\n    config: {\n        mode: \"simple\" | \"advanced\"\n    }\n}\n\nexport type TAssistantInstruction = {\n    tenantId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: any;\n    assistantId: string;\n    assistant: TAssistant;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TAssistantConstraint = {\n    tenantId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    constraints: any;\n    assistantId: string;\n    assistant: TAssistant;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TAssistantDatasource = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TAssistantSkill = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TAssistantChannel = {\n    tenantId: string;\n    id: string;\n    type: string;\n    assistantId: string;\n    name: string;\n    config: any;\n}\n\nexport type TWorker = {\n    id: string;\n    emploidId: string;\n    marketStoreId?: string | null;\n    emploid: TEmploid;\n    name: string;\n    description: string;\n    avatar: string;\n    status: string;\n    version: number;\n    publishDate: string;\n}\n\nexport type TInput = {\n    id: string;\n    emploidId: string;\n    competencyId: string;\n    name: string;\n    description: string;\n    type: string;\n}\n\nexport type TTeam = {\n    id: string;\n    alias: string;\n    name: string;\n    description: string;\n}\n\nexport type TChat = {\n    id: string;\n    createdAt: string;\n    title: string;\n    userId: string;\n    visibility: string;\n    lastContext: any;\n}\n\n\nexport type TDocument = {\n    id: string;\n    createdAt: string;\n    title: string;\n    content?: string;\n    kind: string;\n    userId: string;\n}\n\nexport type TUploadedFile = {\n    id?: string;\n    fileId?: string;\n    bucketId?: string;\n    fileName?: string;\n    path?: string;\n    pathname?: string;\n    url?: string;\n    filePath?: string;\n    contentType?: string;\n    mimeType?: string;\n    fileSize?: number;\n    size?: number;\n    type?: string;\n    createdAt?: string;\n    updatedAt?: string;\n    [key: string]: any;\n}\n\nexport type TDriveBreadcrumb = {\n    id: string;\n    name: string;\n}\n\nexport type TDriveRootProvider = \"LOCAL\" | \"GOOGLE_DRIVE\" | \"DROPBOX\";\n\nexport type TDriveRoot = {\n    id: string;\n    tenantId: string;\n    provider: TDriveRootProvider;\n    name: string;\n    credentialId?: string | null;\n    remoteRootId?: string | null;\n    remoteRootPath?: string | null;\n    isDefaultLocal: boolean;\n    createdAt?: string;\n    updatedAt?: string;\n}\n\nexport type TDriveProviderFolder = {\n    id: string;\n    name: string;\n    parentId?: string | null;\n    path?: string | null;\n}\n\nexport type TDriveItem = {\n    id: string;\n    tenantId: string;\n    rootId?: string;\n    provider?: TDriveRootProvider;\n    isRemote?: boolean;\n    name: string;\n    normalizedName?: string;\n    kind: string;\n    status: string;\n    parentId?: string | null;\n    storageKey?: string | null;\n    mimeType?: string | null;\n    extension?: string | null;\n    sizeBytes?: number | null;\n    createdBy?: string | null;\n    updatedBy?: string | null;\n    createdAt?: string;\n    updatedAt?: string;\n    breadcrumbs?: TDriveBreadcrumb[];\n    downloadPath?: string | null;\n}\n\nexport type TDriveTreeNode = {\n    id: string;\n    tenantId: string;\n    rootId?: string;\n    provider?: TDriveRootProvider;\n    name: string;\n    parentId?: string | null;\n    kind: string;\n    children: TDriveTreeNode[];\n}\n\nexport type TPreparedDriveUpload = {\n    item: TDriveItem;\n    uploadPath: string;\n    downloadPath: string;\n}\n\nexport type TDriveDeleteImpact = {\n    itemId: string;\n    name: string;\n    kind: string;\n    totalItems: number;\n    totalFiles: number;\n    totalFolders: number;\n    totalBytes: number;\n}\n\nexport type TDriveFileContent = {\n    item: TDriveItem;\n    base64: string;\n    content: string | null;\n    mimeType: string;\n    sizeBytes: number;\n}\n\nexport type TWikiFileViewResolution = {\n    fileId: string;\n    path: string;\n    url: string;\n    filePath: string;\n    [key: string]: any;\n}\n\nexport type TStreamId = {\n    id: string;\n    chatId: string;\n    createdAt: string;\n}\n\n\n\nexport type TInstruction = {\n    id: string;\n    emploidId: string;\n    content: string;\n    type: string;\n    active: boolean;\n}\n\nexport type TConstraint = {\n    id: string;\n    emploidId: string;\n    content: string;\n    type: string;\n    active: boolean;\n}\n\nexport type TCommand = {\n    id: string;\n    tenantId: string;\n    name: string;\n    description: string;\n    type: string;\n    targetId: string;\n    targetType: string;\n}\n\nexport type TTaskTemplate = {\n    id: string;\n    task: string;\n    description: string;\n    tenantId: string;\n    emploidId: string;\n}\n\nexport type TWikiPageStatus =\n    | \"DRAFT\"\n    | \"PUBLISHED\"\n    | \"ARCHIVED\";\n\nexport interface TWikiPage {\n    // identity\n    id: string;\n    tenantId: string;\n    workspaceId: string;\n\n    // content meta\n    title: string;\n    slug: string;\n    description?: string;\n\n    // tree\n    parentId?: string;\n\n    // state\n    status: TWikiPageStatus;\n\n    // audit\n    createdAt: string;\n    updatedAt: string;\n    deletedAt?: string;\n\n    // relations (opsiyonel, eager load edilirse gelir)\n    parent?: TWikiPage;\n    children?: TWikiPage[];\n\n    // revisions (liste veya sayım için)\n    revisions?: TWikiRevision[];\n    revisionCount?: number;\n\n    // ---- frontend-only / derived fields ----\n\n    // aktif içerik (latest revision’dan gelir)\n    content?: any;\n\n    // liste / arama için\n    contentText?: string;\n\n    // permission cache (ACL UI için)\n    canView?: boolean;\n    canEdit?: boolean;\n    canDelete?: boolean;\n    canManage?: boolean;\n}\n\nexport interface TWikiRevision {\n    id: string;\n    wikiPageId: string;\n\n    content: any;\n\n    createdBy: string;\n    createdAt: string;\n}\n\nexport interface TWikiCommentUser {\n    id: string;\n    name: string;\n    avatarUrl: string;\n}\n\nexport interface TWikiComment {\n    id: string;\n    pageId: string;\n    parentCommentId?: string | null;\n    content: string;\n    selection?: string | null;\n    creatorId: string;\n    workspaceId: string;\n    resolvedAt?: string | null;\n    resolvedById?: string | null;\n    createdAt: string;\n    editedAt?: string | null;\n    deletedAt?: string | null;\n    creator: TWikiCommentUser;\n    resolvedBy?: TWikiCommentUser | null;\n}\n\nexport interface TWikiCommentPagination {\n    items: TWikiComment[];\n    meta: {\n        page: number;\n        limit: number;\n        hasNextPage: boolean;\n        hasPrevPage: boolean;\n    };\n}\n\n\nexport type TDataModel = {\n    id: string;\n    name: string;\n    displayName: string;\n    description?: string | null;\n    importSource?: string | null;\n}\n\nexport type TCollection = {\n    tenantId: string;\n    dataModel: TDataModel;\n    id: string;\n    name: string;\n    displayName: string;\n    description: string;\n    stats: {\n        totalFields: number;\n        activeFields: number;\n        deletedFields: number;\n        data: string;\n        storage: string;\n    }\n}\n\nexport type TCollectionField = {\n    id: string;\n    collectionId: string;\n    dataModelId: string;\n    name: string;\n    displayName: string;\n    type: string;\n    required: boolean;\n    config?: any;\n    order?: number;\n    deletedAt?: string;\n    deletedBy?: string;\n}\n\nexport type TCollectionRelation = {\n    id: string;\n    fieldId: string;\n    fieldName: string;\n    displayName: string;\n    description?: string;\n    cardinality: \"one\" | \"many\";\n    inverseCardinality: \"one\" | \"many\";\n    targetCollectionId: string;\n    targetCollection?: {\n        id: string;\n        name: string;\n        displayName: string;\n    } | null;\n    targetFieldId?: string | null;\n    targetFieldName?: string | null;\n    targetFieldDisplayName?: string | null;\n}\n\nexport type TAutomationRuleTriggerType =\n    | \"created\"\n    | \"updated\"\n    | \"linked\"\n    | \"unlinked\"\n    | \"schedule\";\n\nexport type TCollectionAutomationRuleConditionOperator =\n    | \"is\"\n    | \"is-not\"\n    | \"contains\"\n    | \"is-empty\"\n    | \"is-not-empty\";\n\nexport type TCollectionAutomationRuleTriggerConfig = {\n    updatedFieldId?: string | null;\n}\n\nexport type TCollectionAutomationRuleCondition = {\n    id: string;\n    fieldId: string;\n    operator: TCollectionAutomationRuleConditionOperator;\n    value?: string | string[] | boolean | null;\n}\n\nexport type TAutomationRuleActionType =\n    | \"create\"\n    | \"update\"\n    | \"delete\"\n    | \"append-description\"\n    | \"script\";\n\nexport type TAutomationRuleAction = {\n    id: string;\n    type: TAutomationRuleActionType | null;\n    fieldId?: string | null;\n    value?: string;\n    valueMode?: \"literal\" | \"formula\";\n    formula?: string;\n    template?: string;\n    script?: string;\n}\n\nexport type TAutomationRuleActivityItem = {\n    id: string;\n    message: string;\n    createdAt: string;\n}\n\nexport type TCollectionAutomationRule = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    description: string;\n    enabled: boolean;\n    trigger: TAutomationRuleTriggerType;\n    triggerConfig?: TCollectionAutomationRuleTriggerConfig | null;\n    conditions?: TCollectionAutomationRuleCondition[];\n    actions: TAutomationRuleAction[];\n    activity: TAutomationRuleActivityItem[];\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TCollectionViewColumn = {\n    fieldName: string;\n    visible: boolean;\n    width?: number;\n}\n\nexport type TCollectionGridViewConfig = {\n    version: 1;\n    columns: TCollectionViewColumn[];\n    filters: TCollectionBoardFilterRule[];\n}\n\nexport type TCollectionBoardCardSize = \"small\" | \"medium\" | \"large\";\n\nexport type TCollectionBoardColorMode = \"group\" | \"none\";\n\nexport type TCollectionBoardFilterOperator =\n    | \"is\"\n    | \"is-not\"\n    | \"contains\"\n    | \"is-empty\"\n    | \"is-not-empty\";\n\nexport type TCollectionBoardFilterRule = {\n    id: string;\n    fieldName: string;\n    operator: TCollectionBoardFilterOperator;\n    value?: string | string[] | boolean | null;\n}\n\nexport type TCollectionBoardSortRule = {\n    id: string;\n    fieldName: string;\n    direction: \"asc\" | \"desc\";\n}\n\nexport type TCollectionBoardGroupVisibleFieldOverride = {\n    groupId: string;\n    visibleFieldNames: string[];\n}\n\nexport type TCollectionBoardViewConfig = {\n    version: 1;\n    columns: TCollectionViewColumn[];\n    titleFieldName: string;\n    groupByFieldName: string;\n    columnOrder: string[];\n    cardOrderByColumn?: Record<string, string[]>;\n    cardSize: TCollectionBoardCardSize;\n    filters: TCollectionBoardFilterRule[];\n    sorts: TCollectionBoardSortRule[];\n    colorMode: TCollectionBoardColorMode;\n    groupVisibleFieldOverrides: TCollectionBoardGroupVisibleFieldOverride[];\n}\n\nexport type TCollectionViewConfig = TCollectionGridViewConfig | TCollectionBoardViewConfig;\n\nexport type TCollectionView = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    type: string;\n    config: TCollectionViewConfig;\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TCollectionButtonAction = TAutomationRuleAction;\n\nexport type TCollectionButtonActivityItem = TAutomationRuleActivityItem;\n\nexport type TCollectionButton = {\n    id: string;\n    tenantId: string;\n    dataModelId: string;\n    collectionId: string;\n    name: string;\n    description: string;\n    enabled: boolean;\n    actions: TCollectionButtonAction[];\n    activity: TCollectionButtonActivityItem[];\n    createdAt: string;\n    updatedAt: string;\n}\n\nexport type TRelationRecordOption = {\n    id: string;\n    label: string;\n    collectionId: string;\n}\n\nexport type TDatasource = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TSkill = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TChannel = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    name: string;\n    description: string;\n    type: string;\n    config: any;\n}\n\nexport type TKnowledge = {\n    id: string;\n    tenantId: string;\n    entityId: string;\n    entityType: string;\n    name: string;\n    description: string;\n    loaderId: string;\n    config: any;\n}\n\nexport type TWorkerTopic = {\n    tenantId: string;\n    workerId: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n}\n\nexport type TTopic = {\n    tenantId: string;\n    entityId: string;\n    entityType: string;\n    id: string;\n    title: string;\n    prompt: string;\n    instructions: string[];\n    category: string;\n}\n\nexport type TPublishDomain = {\n    id: string;\n    tenantId: string;\n    occupationId: string;\n    version: number;\n    prompt: string;\n    data: any;\n}\n\nexport type TPublishEmploid = {\n    id: string;\n    tenantId: string;\n    emploidId: string;\n    version: number;\n    prompt: string;\n    data: any;\n}\n\nexport type TMarketStoreItem = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    itemType: \"worker\";\n    title: string;\n    description: string;\n    avatar: string;\n    summary: Record<string, number>;\n    package: any;\n    createdAt: string;\n    updatedAt: string;\n    publishedAt: string;\n}\n\nexport type TPublishWorkerToMarketStore = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    itemType: \"worker\";\n    title: string;\n    description: string;\n    avatar: string;\n    summary: Record<string, number>;\n    package: any;\n    createdAt: string;\n    updatedAt: string;\n    publishedAt: string;\n}\n\n\nexport type TEnhanceTopic = {\n    tone: string[];\n}\n"]}
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@appconda/sdk",
3
3
  "homepage": "https://appconda.io/support",
4
4
  "description": "Appconda is an open-source self-hosted backend server that abstract and simplify complex and repetitive development tasks behind a very simple REST API",
5
- "version": "1.0.634",
5
+ "version": "1.0.636",
6
6
  "license": "BSD-3-Clause",
7
7
  "main": "dist/index.js",
8
8
  "types": "dist/index.d.ts",
@@ -92,4 +92,19 @@ export const UpdateEditorConfigSchema = z.object({
92
92
  export const GetPageBySlugSchema = z.object({
93
93
  appId: z.string(),
94
94
  slug: z.string()
95
- });
95
+ });
96
+
97
+ export const PublishAppSchema = z.object({
98
+ appId: z.string(),
99
+ subdomain: z.string(),
100
+ defaultPageId: z.string(),
101
+ });
102
+
103
+ export const GetPublishedSettingsSchema = z.object({
104
+ appId: z.string(),
105
+ });
106
+
107
+ export const ResolvePublishedRouteSchema = z.object({
108
+ subdomain: z.string(),
109
+ slug: z.string().optional(),
110
+ });
@@ -1,8 +1,8 @@
1
1
 
2
2
  import z from "zod";
3
3
  import { ServiceClient } from "../../service-client";
4
- import { CreateAppSchema, CreateModuleSchema, CreatePageSchema, CreatePageSchemaSchema, GetAppSchema, GetPageBySlugSchema, GetPageSchemaSchema, ListAppsSchema, ListModulesSchema, ListPagesSchema, UpdateAppSchema, UpdateEditorConfigSchema, UpdatePageSchemaSchema } from "./schema";
5
- import { App, Config, Module, Page, PageSchema } from "./types";
4
+ import { CreateAppSchema, CreateModuleSchema, CreatePageSchema, CreatePageSchemaSchema, GetAppSchema, GetPageBySlugSchema, GetPageSchemaSchema, GetPublishedSettingsSchema, ListAppsSchema, ListModulesSchema, ListPagesSchema, PublishAppSchema, ResolvePublishedRouteSchema, UpdateAppSchema, UpdateEditorConfigSchema, UpdatePageSchemaSchema } from "./schema";
5
+ import { App, Config, Module, Page, PageSchema, PublishedRouteResponse, PublishedSettingsResponse, PublishAppResult } from "./types";
6
6
 
7
7
 
8
8
  export class BuilderService extends ServiceClient {
@@ -71,4 +71,16 @@ export class BuilderService extends ServiceClient {
71
71
  return this.actionCall('publish', 'GetPageBySlug', payload);
72
72
  }
73
73
 
74
+ public async PublishApp(payload: z.infer<typeof PublishAppSchema>): Promise<PublishAppResult> {
75
+ return this.actionCall('publish', 'PublishApp', payload);
76
+ }
77
+
78
+ public async GetPublishedSettings(payload: z.infer<typeof GetPublishedSettingsSchema>): Promise<PublishedSettingsResponse> {
79
+ return this.actionCall('publish', 'GetPublishedSettings', payload);
80
+ }
81
+
82
+ public async ResolvePublishedRoute(payload: z.infer<typeof ResolvePublishedRouteSchema>): Promise<PublishedRouteResponse> {
83
+ return this.actionCall('publish', 'ResolvePublishedRoute', payload);
84
+ }
85
+
74
86
  }
@@ -25,6 +25,7 @@ export type App = {
25
25
  viewTitle?: string;
26
26
  position?: number;
27
27
  schema?: AppSchema;
28
+ config?: any;
28
29
  }
29
30
 
30
31
  export type Page = {
@@ -32,6 +33,7 @@ export type Page = {
32
33
  tenantId: string;
33
34
  appId: string;
34
35
  moduleId: string;
36
+ slug: string;
35
37
  title: string;
36
38
  description?: string;
37
39
  createdDate: Date;
@@ -65,4 +67,45 @@ export type Extensions = {
65
67
 
66
68
  export type Config = {
67
69
  extensions: Extensions[];
68
- }
70
+ }
71
+
72
+ export type PublishedPageOption = {
73
+ id: string;
74
+ slug: string;
75
+ title: string;
76
+ moduleId?: string;
77
+ moduleName?: string;
78
+ }
79
+
80
+ export type PublishedAppSettings = {
81
+ id: string;
82
+ appId: string;
83
+ subdomain: string;
84
+ publishedVersion: number;
85
+ defaultPageSlug: string;
86
+ publishedAt: Date;
87
+ updatedAt: Date;
88
+ }
89
+
90
+ export type PublishAppResult = {
91
+ appId: string;
92
+ subdomain: string;
93
+ publishedVersion: number;
94
+ defaultPageSlug: string;
95
+ title: string;
96
+ pages: PublishedPageOption[];
97
+ }
98
+
99
+ export type PublishedSettingsResponse = {
100
+ published: PublishedAppSettings | null;
101
+ pages: PublishedPageOption[];
102
+ }
103
+
104
+ export type PublishedRouteResponse = {
105
+ published: PublishedAppSettings;
106
+ app: App;
107
+ page: Page;
108
+ pages: Page[];
109
+ resolvedSlug: string;
110
+ isDefaultPage: boolean;
111
+ }
@@ -295,6 +295,109 @@ export const ResolveDriveDownloadSchema = z.object({
295
295
  itemId: z.string(),
296
296
  });
297
297
 
298
+ export const ListDriveRootsSchema = z.object({
299
+ tenantId: z.string(),
300
+ });
301
+
302
+ export const EnsureDriveProviderCredentialSchema = z.object({
303
+ tenantId: z.string(),
304
+ provider: z.enum(["LOCAL", "GOOGLE_DRIVE", "DROPBOX"]),
305
+ });
306
+
307
+ export const ListDriveProviderFoldersSchema = z.object({
308
+ tenantId: z.string(),
309
+ provider: z.enum(["LOCAL", "GOOGLE_DRIVE", "DROPBOX"]),
310
+ parentId: z.string().nullable().optional(),
311
+ credentialId: z.string().nullable().optional(),
312
+ });
313
+
314
+ export const CreateDriveRootSchema = z.object({
315
+ tenantId: z.string(),
316
+ provider: z.enum(["LOCAL", "GOOGLE_DRIVE", "DROPBOX"]),
317
+ name: z.string(),
318
+ credentialId: z.string().nullable().optional(),
319
+ remoteRootId: z.string().nullable().optional(),
320
+ remoteRootPath: z.string().nullable().optional(),
321
+ });
322
+
323
+ export const DeleteDriveRootSchema = z.object({
324
+ tenantId: z.string(),
325
+ rootId: z.string(),
326
+ });
327
+
328
+ export const ListDriveRootItemsSchema = z.object({
329
+ tenantId: z.string(),
330
+ rootId: z.string(),
331
+ folderId: z.string().optional(),
332
+ });
333
+
334
+ export const ListDriveRootTreeSchema = z.object({
335
+ tenantId: z.string(),
336
+ rootId: z.string(),
337
+ });
338
+
339
+ export const SearchDriveRootItemsSchema = z.object({
340
+ tenantId: z.string(),
341
+ rootId: z.string(),
342
+ query: z.string(),
343
+ });
344
+
345
+ export const CreateDriveRootFolderSchema = z.object({
346
+ tenantId: z.string(),
347
+ rootId: z.string(),
348
+ name: z.string(),
349
+ parentId: z.string().optional(),
350
+ });
351
+
352
+ export const UploadDriveRootFilesSchema = z.object({
353
+ tenantId: z.string(),
354
+ rootId: z.string(),
355
+ parentId: z.string().optional(),
356
+ files: z.array(z.object({
357
+ name: z.string(),
358
+ base64: z.string(),
359
+ mimeType: z.string().nullable().optional(),
360
+ })),
361
+ });
362
+
363
+ export const RenameDriveRootItemSchema = z.object({
364
+ tenantId: z.string(),
365
+ rootId: z.string(),
366
+ itemId: z.string(),
367
+ name: z.string(),
368
+ });
369
+
370
+ export const MoveDriveRootItemSchema = z.object({
371
+ tenantId: z.string(),
372
+ rootId: z.string(),
373
+ itemId: z.string(),
374
+ targetParentId: z.string().optional(),
375
+ });
376
+
377
+ export const GetDriveRootDeleteImpactSchema = z.object({
378
+ tenantId: z.string(),
379
+ rootId: z.string(),
380
+ itemId: z.string(),
381
+ });
382
+
383
+ export const DeleteDriveRootItemSchema = z.object({
384
+ tenantId: z.string(),
385
+ rootId: z.string(),
386
+ itemId: z.string(),
387
+ });
388
+
389
+ export const ReadDriveRootFileContentSchema = z.object({
390
+ tenantId: z.string(),
391
+ rootId: z.string(),
392
+ itemId: z.string(),
393
+ });
394
+
395
+ export const ResolveDriveRootDownloadSchema = z.object({
396
+ tenantId: z.string(),
397
+ rootId: z.string(),
398
+ itemId: z.string(),
399
+ });
400
+
298
401
  export const CreateExtensionSchema = z.object({
299
402
  extensionId: z.string(),
300
403
  tenantId: z.string(),
@@ -752,6 +855,7 @@ export const CreateDataModelSchema = z.object({
752
855
  tenantId: z.string(),
753
856
  displayName: z.string(),
754
857
  name: z.string(), // data model name
858
+ description: z.string().optional(),
755
859
  });
756
860
 
757
861
  /**
@@ -760,9 +864,11 @@ export const CreateDataModelSchema = z.object({
760
864
  export const UpdateDataModelSchema = z.object({
761
865
  tenantId: z.string(),
762
866
  dataModelId: z.string(),
763
-
764
- // opsiyonel alanlar
765
- displayName: z.string().optional(),
867
+ data: z.object({
868
+ name: z.string().optional(),
869
+ displayName: z.string().optional(),
870
+ description: z.string().optional(),
871
+ }).passthrough(),
766
872
  });
767
873
 
768
874
  /**
@@ -1453,6 +1559,17 @@ export const ListCollectionAutomationRulesSchema = z.object({
1453
1559
  dataModelId: z.string().optional(),
1454
1560
  });
1455
1561
 
1562
+ const CollectionAutomationRuleTriggerConfigSchema = z.object({
1563
+ updatedFieldId: z.string().nullable().optional(),
1564
+ });
1565
+
1566
+ const CollectionAutomationRuleConditionSchema = z.object({
1567
+ id: z.string(),
1568
+ fieldId: z.string(),
1569
+ operator: z.enum(["is", "is-not", "contains", "is-empty", "is-not-empty"]),
1570
+ value: z.union([z.string(), z.array(z.string()), z.boolean(), z.null()]).optional(),
1571
+ });
1572
+
1456
1573
  export const CreateCollectionAutomationRuleSchema = z.object({
1457
1574
  tenantId: z.string(),
1458
1575
  dataModelId: z.string(),
@@ -1461,6 +1578,8 @@ export const CreateCollectionAutomationRuleSchema = z.object({
1461
1578
  description: z.string().optional(),
1462
1579
  enabled: z.boolean().optional(),
1463
1580
  trigger: z.enum(["created", "updated", "linked", "unlinked", "schedule"]),
1581
+ triggerConfig: CollectionAutomationRuleTriggerConfigSchema.nullable().optional(),
1582
+ conditions: z.array(CollectionAutomationRuleConditionSchema).optional(),
1464
1583
  actions: z.array(z.object({}).catchall(z.any())),
1465
1584
  });
1466
1585
 
@@ -1472,6 +1591,8 @@ export const UpdateCollectionAutomationRuleSchema = z.object({
1472
1591
  description: z.string().optional(),
1473
1592
  enabled: z.boolean().optional(),
1474
1593
  trigger: z.enum(["created", "updated", "linked", "unlinked", "schedule"]).optional(),
1594
+ triggerConfig: CollectionAutomationRuleTriggerConfigSchema.nullable().optional(),
1595
+ conditions: z.array(CollectionAutomationRuleConditionSchema).optional(),
1475
1596
  actions: z.array(z.object({}).catchall(z.any())).optional(),
1476
1597
  });
1477
1598