@appconda/sdk 1.0.601 → 1.0.605
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/client.d.ts +8 -0
- package/dist/client.js +75 -8
- package/dist/getAppcondaClient.d.ts +14 -3
- package/dist/getAppcondaClient.js +51 -59
- package/dist/getSDKForService.d.ts +3 -1
- package/dist/getSDKForService.js +4 -4
- package/dist/index.d.ts +5 -1
- package/dist/index.js +3 -1
- package/dist/modules/accounv1/schema.d.ts +1 -1
- package/dist/modules/accounv1/schema.js +2 -2
- package/dist/modules/accounv1/types.d.ts +1 -1
- package/dist/modules/accounv1/types.js +1 -1
- package/dist/modules/emploid/schema.d.ts +62 -8
- package/dist/modules/emploid/schema.js +64 -10
- package/dist/modules/emploid/service.d.ts +20 -3
- package/dist/modules/emploid/service.js +121 -1
- package/dist/modules/emploid/types.d.ts +67 -1
- package/dist/modules/emploid/types.js +1 -1
- package/dist/modules/organization/schema.d.ts +35 -1
- package/dist/modules/organization/schema.js +31 -2
- package/dist/modules/organization/service.d.ts +9 -2
- package/dist/modules/organization/service.js +29 -8
- package/dist/modules/organization/types.d.ts +45 -1
- package/dist/modules/organization/types.js +1 -1
- package/package.json +1 -1
- package/src/client.ts +96 -8
- package/src/getAppcondaClient.ts +69 -58
- package/src/getSDKForService.ts +7 -4
- package/src/index.ts +5 -2
- package/src/modules/accounv1/schema.ts +2 -2
- package/src/modules/accounv1/types.ts +2 -2
- package/src/modules/emploid/schema.ts +74 -10
- package/src/modules/emploid/service.ts +169 -3
- package/src/modules/emploid/types.ts +74 -1
- package/src/modules/organization/schema.ts +38 -2
- package/src/modules/organization/service.ts +67 -13
- package/src/modules/organization/types.ts +51 -2
- package/dist/inputFile.d.ts +0 -6
- package/dist/inputFile.js +0 -16
- package/dist/modules/agent/action.d.ts +0 -29
- package/dist/modules/agent/action.js +0 -53
- package/dist/modules/ai/node/actions.d.ts +0 -4
- package/dist/modules/ai/node/actions.js +0 -14
- package/dist/modules/builder/action.d.ts +0 -18
- package/dist/modules/builder/action.js +0 -214
- package/dist/modules/datasource/action.d.ts +0 -14
- package/dist/modules/datasource/action.js +0 -172
- package/dist/modules/emploid/action.d.ts +0 -73
- package/dist/modules/emploid/action.js +0 -984
- package/dist/modules/google/action.d.ts +0 -5
- package/dist/modules/google/action.js +0 -46
- package/dist/modules/hooks/lib/handler.d.ts +0 -3
- package/dist/modules/hooks/lib/handler.js +0 -23
- package/dist/modules/mail/action.d.ts +0 -3
- package/dist/modules/mail/action.js +0 -18
- package/dist/modules/notion/action.d.ts +0 -5
- package/dist/modules/notion/action.js +0 -46
- package/dist/modules/organization/action.d.ts +0 -7
- package/dist/modules/organization/action.js +0 -60
- package/dist/modules/scheduled-job/action.d.ts +0 -70
- package/dist/modules/scheduled-job/action.js +0 -173
- package/dist/modules/scheduled-job/lib/handler.d.ts +0 -3
- package/dist/modules/scheduled-job/lib/handler.js +0 -23
- package/dist/modules/task/action.d.ts +0 -64
- package/dist/modules/task/action.js +0 -758
- package/dist/modules/tenant/actions.d.ts +0 -10
- package/dist/modules/tenant/actions.js +0 -160
- package/dist/modules/waitlist/action.d.ts +0 -6
- package/dist/modules/waitlist/action.js +0 -78
|
@@ -15,9 +15,17 @@ export type TPaginatedEmploidsResult = {
|
|
|
15
15
|
};
|
|
16
16
|
export type TScope = {
|
|
17
17
|
id: string;
|
|
18
|
-
|
|
18
|
+
tenantId: string;
|
|
19
|
+
workerId: string;
|
|
20
|
+
parentScopeId?: string | null;
|
|
19
21
|
name: string;
|
|
20
22
|
description: string;
|
|
23
|
+
type?: string;
|
|
24
|
+
isFolderType?: boolean;
|
|
25
|
+
content?: any;
|
|
26
|
+
markdownContent?: string;
|
|
27
|
+
createdAt?: string;
|
|
28
|
+
updatedAt?: string;
|
|
21
29
|
};
|
|
22
30
|
export type TOccupation = {
|
|
23
31
|
tenantId: string;
|
|
@@ -166,6 +174,31 @@ export type TDocument = {
|
|
|
166
174
|
kind: string;
|
|
167
175
|
userId: string;
|
|
168
176
|
};
|
|
177
|
+
export type TUploadedFile = {
|
|
178
|
+
id?: string;
|
|
179
|
+
fileId?: string;
|
|
180
|
+
bucketId?: string;
|
|
181
|
+
fileName?: string;
|
|
182
|
+
path?: string;
|
|
183
|
+
pathname?: string;
|
|
184
|
+
url?: string;
|
|
185
|
+
filePath?: string;
|
|
186
|
+
contentType?: string;
|
|
187
|
+
mimeType?: string;
|
|
188
|
+
fileSize?: number;
|
|
189
|
+
size?: number;
|
|
190
|
+
type?: string;
|
|
191
|
+
createdAt?: string;
|
|
192
|
+
updatedAt?: string;
|
|
193
|
+
[key: string]: any;
|
|
194
|
+
};
|
|
195
|
+
export type TWikiFileViewResolution = {
|
|
196
|
+
fileId: string;
|
|
197
|
+
path: string;
|
|
198
|
+
url: string;
|
|
199
|
+
filePath: string;
|
|
200
|
+
[key: string]: any;
|
|
201
|
+
};
|
|
169
202
|
export type TStreamId = {
|
|
170
203
|
id: string;
|
|
171
204
|
chatId: string;
|
|
@@ -232,6 +265,36 @@ export interface TWikiRevision {
|
|
|
232
265
|
createdBy: string;
|
|
233
266
|
createdAt: string;
|
|
234
267
|
}
|
|
268
|
+
export interface TWikiCommentUser {
|
|
269
|
+
id: string;
|
|
270
|
+
name: string;
|
|
271
|
+
avatarUrl: string;
|
|
272
|
+
}
|
|
273
|
+
export interface TWikiComment {
|
|
274
|
+
id: string;
|
|
275
|
+
pageId: string;
|
|
276
|
+
parentCommentId?: string | null;
|
|
277
|
+
content: string;
|
|
278
|
+
selection?: string | null;
|
|
279
|
+
creatorId: string;
|
|
280
|
+
workspaceId: string;
|
|
281
|
+
resolvedAt?: string | null;
|
|
282
|
+
resolvedById?: string | null;
|
|
283
|
+
createdAt: string;
|
|
284
|
+
editedAt?: string | null;
|
|
285
|
+
deletedAt?: string | null;
|
|
286
|
+
creator: TWikiCommentUser;
|
|
287
|
+
resolvedBy?: TWikiCommentUser | null;
|
|
288
|
+
}
|
|
289
|
+
export interface TWikiCommentPagination {
|
|
290
|
+
items: TWikiComment[];
|
|
291
|
+
meta: {
|
|
292
|
+
page: number;
|
|
293
|
+
limit: number;
|
|
294
|
+
hasNextPage: boolean;
|
|
295
|
+
hasPrevPage: boolean;
|
|
296
|
+
};
|
|
297
|
+
}
|
|
235
298
|
export type TDataModel = {
|
|
236
299
|
id: string;
|
|
237
300
|
name: string;
|
|
@@ -345,3 +408,6 @@ export type TPublishWorker = {
|
|
|
345
408
|
prompt: string;
|
|
346
409
|
data: any;
|
|
347
410
|
};
|
|
411
|
+
export type TEnhanceTopic = {
|
|
412
|
+
tone: string[];
|
|
413
|
+
};
|
|
@@ -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    emploidId: string;\n    name: string;\n    description: 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 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    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 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\n\nexport type TDataModel = {\n    id: string;\n    name: string;\n    displayName: string;\n    description: string;\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 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 TPublishWorker = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    version: number;\n    prompt: string;\n    data: any;\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 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    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 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}\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 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 TPublishWorker = {\n    id: string;\n    tenantId: string;\n    workerId: string;\n    version: number;\n    prompt: string;\n    data: any;\n}\n\n\nexport type TEnhanceTopic = {\n    tone: string[];\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
export declare const CreateOrganizationSchema: z.ZodObject<{
|
|
3
|
-
id: z.ZodString
|
|
3
|
+
id: z.ZodOptional<z.ZodString>;
|
|
4
4
|
name: z.ZodString;
|
|
5
5
|
}, z.core.$strip>;
|
|
6
6
|
export declare const CreateMembershipSchema: z.ZodObject<{
|
|
@@ -29,3 +29,37 @@ export declare const UpdateOrganizationSchema: z.ZodObject<{
|
|
|
29
29
|
id: z.ZodString;
|
|
30
30
|
name: z.ZodString;
|
|
31
31
|
}, z.core.$strip>;
|
|
32
|
+
export declare const ListOrganizationMembersSchema: z.ZodObject<{
|
|
33
|
+
organizationId: z.ZodString;
|
|
34
|
+
}, z.core.$strip>;
|
|
35
|
+
export declare const ListOrganizationInvitesSchema: z.ZodObject<{
|
|
36
|
+
organizationId: z.ZodString;
|
|
37
|
+
}, z.core.$strip>;
|
|
38
|
+
export declare const InviteOrganizationMemberSchema: z.ZodObject<{
|
|
39
|
+
organizationId: z.ZodString;
|
|
40
|
+
email: z.ZodString;
|
|
41
|
+
name: z.ZodOptional<z.ZodString>;
|
|
42
|
+
role: z.ZodEnum<{
|
|
43
|
+
owner: "owner";
|
|
44
|
+
manager: "manager";
|
|
45
|
+
member: "member";
|
|
46
|
+
billing: "billing";
|
|
47
|
+
}>;
|
|
48
|
+
creatorId: z.ZodString;
|
|
49
|
+
}, z.core.$strip>;
|
|
50
|
+
export declare const DeleteOrganizationMemberSchema: z.ZodObject<{
|
|
51
|
+
organizationId: z.ZodString;
|
|
52
|
+
userId: z.ZodString;
|
|
53
|
+
}, z.core.$strip>;
|
|
54
|
+
export declare const DeleteOrganizationInviteSchema: z.ZodObject<{
|
|
55
|
+
organizationId: z.ZodString;
|
|
56
|
+
inviteId: z.ZodString;
|
|
57
|
+
}, z.core.$strip>;
|
|
58
|
+
export declare const ListUserOrganizationInvitesSchema: z.ZodObject<{
|
|
59
|
+
email: z.ZodString;
|
|
60
|
+
}, z.core.$strip>;
|
|
61
|
+
export declare const AcceptOrganizationInviteSchema: z.ZodObject<{
|
|
62
|
+
inviteId: z.ZodString;
|
|
63
|
+
userId: z.ZodString;
|
|
64
|
+
email: z.ZodOptional<z.ZodString>;
|
|
65
|
+
}, z.core.$strip>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
export const CreateOrganizationSchema = z.object({
|
|
3
|
-
id: z.string(),
|
|
3
|
+
id: z.string().optional(),
|
|
4
4
|
name: z.string()
|
|
5
5
|
});
|
|
6
6
|
export const CreateMembershipSchema = z.object({
|
|
@@ -24,4 +24,33 @@ export const UpdateOrganizationSchema = z.object({
|
|
|
24
24
|
id: z.string(),
|
|
25
25
|
name: z.string()
|
|
26
26
|
});
|
|
27
|
-
|
|
27
|
+
export const ListOrganizationMembersSchema = z.object({
|
|
28
|
+
organizationId: z.string()
|
|
29
|
+
});
|
|
30
|
+
export const ListOrganizationInvitesSchema = z.object({
|
|
31
|
+
organizationId: z.string()
|
|
32
|
+
});
|
|
33
|
+
export const InviteOrganizationMemberSchema = z.object({
|
|
34
|
+
organizationId: z.string(),
|
|
35
|
+
email: z.string(),
|
|
36
|
+
name: z.string().optional(),
|
|
37
|
+
role: z.enum(['owner', 'manager', 'member', 'billing']),
|
|
38
|
+
creatorId: z.string()
|
|
39
|
+
});
|
|
40
|
+
export const DeleteOrganizationMemberSchema = z.object({
|
|
41
|
+
organizationId: z.string(),
|
|
42
|
+
userId: z.string()
|
|
43
|
+
});
|
|
44
|
+
export const DeleteOrganizationInviteSchema = z.object({
|
|
45
|
+
organizationId: z.string(),
|
|
46
|
+
inviteId: z.string()
|
|
47
|
+
});
|
|
48
|
+
export const ListUserOrganizationInvitesSchema = z.object({
|
|
49
|
+
email: z.string()
|
|
50
|
+
});
|
|
51
|
+
export const AcceptOrganizationInviteSchema = z.object({
|
|
52
|
+
inviteId: z.string(),
|
|
53
|
+
userId: z.string(),
|
|
54
|
+
email: z.string().optional()
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21vZHVsZXMvb3JnYW5pemF0aW9uL3NjaGVtYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsQ0FBQyxFQUFFLE1BQU0sS0FBSyxDQUFDO0FBRXhCLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDN0MsRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLEVBQUU7SUFDekIsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUMzQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUNsQixjQUFjLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUMxQixRQUFRLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRTtJQUNyQixJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0NBQzFELENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDL0MsTUFBTSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7SUFDbEIsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtDQUMvQixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ25ELE1BQU0sRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2xCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0NBQ25CLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDOUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDakIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUM3QyxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUNkLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0NBQ25CLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDbEQsY0FBYyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDN0IsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUNsRCxjQUFjLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtDQUM3QixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ25ELGNBQWMsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQzFCLEtBQUssRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2pCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxFQUFFO0lBQzNCLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDdkQsU0FBUyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDeEIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUNuRCxjQUFjLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUMxQixNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtDQUNyQixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ25ELGNBQWMsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQzFCLFFBQVEsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0NBQ3ZCLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLGlDQUFpQyxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDdEQsS0FBSyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDcEIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUNuRCxRQUFRLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUNwQixNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUNsQixLQUFLLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRTtDQUMvQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB6IH0gZnJvbSBcInpvZFwiO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlT3JnYW5pemF0aW9uU2NoZW1hID0gei5vYmplY3Qoe1xuICAgIGlkOiB6LnN0cmluZygpLm9wdGlvbmFsKCksXG4gICAgbmFtZTogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBDcmVhdGVNZW1iZXJzaGlwU2NoZW1hID0gei5vYmplY3Qoe1xuICAgIHVzZXJJZDogei5zdHJpbmcoKSxcbiAgICBvcmdhbml6YXRpb25JZDogei5zdHJpbmcoKSxcbiAgICBhY2NlcHRlZDogei5ib29sZWFuKCksXG4gICAgcm9sZTogei5lbnVtKFsnb3duZXInLCAnbWFuYWdlcicsICdtZW1iZXInLCAnYmlsbGluZyddKVxufSk7XG5cbmV4cG9ydCBjb25zdCBSZWdpc3Rlck9yZ2FuaXphdGlvblNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICB1c2VySWQ6IHouc3RyaW5nKCksXG4gICAgb3JnYW5pemF0aW9uTmFtZTogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBHZXRPcmdhbml6YXRpb25zQnlVc2VySWRTY2hlbWEgPSB6Lm9iamVjdCh7XG4gICAgdXNlcklkOiB6LnN0cmluZygpLFxuICAgIHBhZ2U6IHoubnVtYmVyKClcbn0pO1xuXG5leHBvcnQgY29uc3QgR2V0T3JnYW5pemF0aW9uQnlJZFNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBVcGRhdGVPcmdhbml6YXRpb25TY2hlbWEgPSB6Lm9iamVjdCh7XG4gICAgaWQ6IHouc3RyaW5nKCksXG4gICAgbmFtZTogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBMaXN0T3JnYW5pemF0aW9uTWVtYmVyc1NjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBvcmdhbml6YXRpb25JZDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBMaXN0T3JnYW5pemF0aW9uSW52aXRlc1NjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBvcmdhbml6YXRpb25JZDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBJbnZpdGVPcmdhbml6YXRpb25NZW1iZXJTY2hlbWEgPSB6Lm9iamVjdCh7XG4gICAgb3JnYW5pemF0aW9uSWQ6IHouc3RyaW5nKCksXG4gICAgZW1haWw6IHouc3RyaW5nKCksXG4gICAgbmFtZTogei5zdHJpbmcoKS5vcHRpb25hbCgpLFxuICAgIHJvbGU6IHouZW51bShbJ293bmVyJywgJ21hbmFnZXInLCAnbWVtYmVyJywgJ2JpbGxpbmcnXSksXG4gICAgY3JlYXRvcklkOiB6LnN0cmluZygpXG59KTtcblxuZXhwb3J0IGNvbnN0IERlbGV0ZU9yZ2FuaXphdGlvbk1lbWJlclNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBvcmdhbml6YXRpb25JZDogei5zdHJpbmcoKSxcbiAgICB1c2VySWQ6IHouc3RyaW5nKClcbn0pO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlT3JnYW5pemF0aW9uSW52aXRlU2NoZW1hID0gei5vYmplY3Qoe1xuICAgIG9yZ2FuaXphdGlvbklkOiB6LnN0cmluZygpLFxuICAgIGludml0ZUlkOiB6LnN0cmluZygpXG59KTtcblxuZXhwb3J0IGNvbnN0IExpc3RVc2VyT3JnYW5pemF0aW9uSW52aXRlc1NjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBlbWFpbDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBBY2NlcHRPcmdhbml6YXRpb25JbnZpdGVTY2hlbWEgPSB6Lm9iamVjdCh7XG4gICAgaW52aXRlSWQ6IHouc3RyaW5nKCksXG4gICAgdXNlcklkOiB6LnN0cmluZygpLFxuICAgIGVtYWlsOiB6LnN0cmluZygpLm9wdGlvbmFsKClcbn0pO1xuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import z from "zod";
|
|
2
2
|
import { ServiceClient } from "../../service-client";
|
|
3
|
-
import { CreateMembershipSchema, CreateOrganizationSchema, GetOrganizationByIdSchema, GetOrganizationsByUserIdSchema, RegisterOrganizationSchema, UpdateOrganizationSchema } from "./schema";
|
|
4
|
-
import { TMembership, TOrganization } from "./types";
|
|
3
|
+
import { AcceptOrganizationInviteSchema, CreateMembershipSchema, CreateOrganizationSchema, DeleteOrganizationInviteSchema, DeleteOrganizationMemberSchema, GetOrganizationByIdSchema, GetOrganizationsByUserIdSchema, InviteOrganizationMemberSchema, ListUserOrganizationInvitesSchema, ListOrganizationInvitesSchema, ListOrganizationMembersSchema, RegisterOrganizationSchema, UpdateOrganizationSchema } from "./schema";
|
|
4
|
+
import { TDeleteOrganizationInviteResult, TDeleteOrganizationMemberResult, TMembership, TOrganization, TOrganizationInvite, TOrganizationMember, TUserOrganizationInvite } from "./types";
|
|
5
5
|
export declare class OrganizationService extends ServiceClient {
|
|
6
6
|
protected getServiceName(): string;
|
|
7
7
|
CreateOrganization(payload: z.infer<typeof CreateOrganizationSchema>): Promise<TOrganization>;
|
|
@@ -10,4 +10,11 @@ export declare class OrganizationService extends ServiceClient {
|
|
|
10
10
|
CreateMembership(payload: z.infer<typeof CreateMembershipSchema>): Promise<TMembership>;
|
|
11
11
|
RegisterOrganization(payload: z.infer<typeof RegisterOrganizationSchema>): Promise<TOrganization>;
|
|
12
12
|
GetOrganizationsByUserId(payload: z.infer<typeof GetOrganizationsByUserIdSchema>): Promise<TOrganization[]>;
|
|
13
|
+
ListOrganizationMembers(payload: z.infer<typeof ListOrganizationMembersSchema>): Promise<TOrganizationMember[]>;
|
|
14
|
+
ListOrganizationInvites(payload: z.infer<typeof ListOrganizationInvitesSchema>): Promise<TOrganizationInvite[]>;
|
|
15
|
+
InviteOrganizationMember(payload: z.infer<typeof InviteOrganizationMemberSchema>): Promise<TOrganizationMember | TOrganizationInvite>;
|
|
16
|
+
DeleteOrganizationMember(payload: z.infer<typeof DeleteOrganizationMemberSchema>): Promise<TDeleteOrganizationMemberResult>;
|
|
17
|
+
DeleteOrganizationInvite(payload: z.infer<typeof DeleteOrganizationInviteSchema>): Promise<TDeleteOrganizationInviteResult>;
|
|
18
|
+
ListUserOrganizationInvites(payload: z.infer<typeof ListUserOrganizationInvitesSchema>): Promise<TUserOrganizationInvite[]>;
|
|
19
|
+
AcceptOrganizationInvite(payload: z.infer<typeof AcceptOrganizationInviteSchema>): Promise<TOrganizationMember>;
|
|
13
20
|
}
|
|
@@ -1,25 +1,46 @@
|
|
|
1
1
|
import { ServiceClient } from "../../service-client";
|
|
2
2
|
export class OrganizationService extends ServiceClient {
|
|
3
3
|
getServiceName() {
|
|
4
|
-
return
|
|
4
|
+
return "com.appconda.service.organization";
|
|
5
5
|
}
|
|
6
6
|
CreateOrganization(payload) {
|
|
7
|
-
return this.actionCall(
|
|
7
|
+
return this.actionCall("CreateOrganization", payload);
|
|
8
8
|
}
|
|
9
9
|
GetOrganizationById(payload) {
|
|
10
|
-
return this.actionCall(
|
|
10
|
+
return this.actionCall("GetOrganizationById", payload);
|
|
11
11
|
}
|
|
12
12
|
UpdateOrganization(payload) {
|
|
13
|
-
return this.actionCall(
|
|
13
|
+
return this.actionCall("UpdateOrganization", payload);
|
|
14
14
|
}
|
|
15
15
|
CreateMembership(payload) {
|
|
16
|
-
return this.actionCall(
|
|
16
|
+
return this.actionCall("CreateMembership", payload);
|
|
17
17
|
}
|
|
18
18
|
RegisterOrganization(payload) {
|
|
19
|
-
return this.actionCall(
|
|
19
|
+
return this.actionCall("RegisterOrganization", payload);
|
|
20
20
|
}
|
|
21
21
|
GetOrganizationsByUserId(payload) {
|
|
22
|
-
return this.actionCall(
|
|
22
|
+
return this.actionCall("GetOrganizationsByUserId", payload);
|
|
23
|
+
}
|
|
24
|
+
ListOrganizationMembers(payload) {
|
|
25
|
+
return this.actionCall("ListOrganizationMembers", payload);
|
|
26
|
+
}
|
|
27
|
+
ListOrganizationInvites(payload) {
|
|
28
|
+
return this.actionCall("ListOrganizationInvites", payload);
|
|
29
|
+
}
|
|
30
|
+
InviteOrganizationMember(payload) {
|
|
31
|
+
return this.actionCall("InviteOrganizationMember", payload);
|
|
32
|
+
}
|
|
33
|
+
DeleteOrganizationMember(payload) {
|
|
34
|
+
return this.actionCall("DeleteOrganizationMember", payload);
|
|
35
|
+
}
|
|
36
|
+
DeleteOrganizationInvite(payload) {
|
|
37
|
+
return this.actionCall("DeleteOrganizationInvite", payload);
|
|
38
|
+
}
|
|
39
|
+
ListUserOrganizationInvites(payload) {
|
|
40
|
+
return this.actionCall("ListUserOrganizationInvites", payload);
|
|
41
|
+
}
|
|
42
|
+
AcceptOrganizationInvite(payload) {
|
|
43
|
+
return this.actionCall("AcceptOrganizationInvite", payload);
|
|
23
44
|
}
|
|
24
45
|
}
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2R1bGVzL29yZ2FuaXphdGlvbi9zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQTBCckQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGFBQWE7SUFDeEMsY0FBYztRQUNwQixPQUFPLG1DQUFtQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxPQUFpRDtRQUNoRSxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsb0JBQW9CLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVELG1CQUFtQixDQUFDLE9BQWtEO1FBQ2xFLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxxQkFBcUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQsa0JBQWtCLENBQUMsT0FBaUQ7UUFDaEUsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLG9CQUFvQixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxPQUErQztRQUM1RCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQUVELG9CQUFvQixDQUFDLE9BQW1EO1FBQ3BFLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxzQkFBc0IsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBdUQ7UUFDNUUsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLDBCQUEwQixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFRCx1QkFBdUIsQ0FBQyxPQUFzRDtRQUMxRSxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMseUJBQXlCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELHVCQUF1QixDQUFDLE9BQXNEO1FBQzFFLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyx5QkFBeUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsd0JBQXdCLENBQ3BCLE9BQXVEO1FBRXZELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQywwQkFBMEIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRUQsd0JBQXdCLENBQ3BCLE9BQXVEO1FBRXZELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQywwQkFBMEIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRUQsd0JBQXdCLENBQ3BCLE9BQXVEO1FBRXZELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQywwQkFBMEIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRUQsMkJBQTJCLENBQ3ZCLE9BQTBEO1FBRTFELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyw2QkFBNkIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsd0JBQXdCLENBQ3BCLE9BQXVEO1FBRXZELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQywwQkFBMEIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNoRSxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeiBmcm9tIFwiem9kXCI7XG5pbXBvcnQgeyBTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50XCI7XG5pbXBvcnQge1xuICAgIEFjY2VwdE9yZ2FuaXphdGlvbkludml0ZVNjaGVtYSxcbiAgICBDcmVhdGVNZW1iZXJzaGlwU2NoZW1hLFxuICAgIENyZWF0ZU9yZ2FuaXphdGlvblNjaGVtYSxcbiAgICBEZWxldGVPcmdhbml6YXRpb25JbnZpdGVTY2hlbWEsXG4gICAgRGVsZXRlT3JnYW5pemF0aW9uTWVtYmVyU2NoZW1hLFxuICAgIEdldE9yZ2FuaXphdGlvbkJ5SWRTY2hlbWEsXG4gICAgR2V0T3JnYW5pemF0aW9uc0J5VXNlcklkU2NoZW1hLFxuICAgIEludml0ZU9yZ2FuaXphdGlvbk1lbWJlclNjaGVtYSxcbiAgICBMaXN0VXNlck9yZ2FuaXphdGlvbkludml0ZXNTY2hlbWEsXG4gICAgTGlzdE9yZ2FuaXphdGlvbkludml0ZXNTY2hlbWEsXG4gICAgTGlzdE9yZ2FuaXphdGlvbk1lbWJlcnNTY2hlbWEsXG4gICAgUmVnaXN0ZXJPcmdhbml6YXRpb25TY2hlbWEsXG4gICAgVXBkYXRlT3JnYW5pemF0aW9uU2NoZW1hXG59IGZyb20gXCIuL3NjaGVtYVwiO1xuaW1wb3J0IHtcbiAgICBURGVsZXRlT3JnYW5pemF0aW9uSW52aXRlUmVzdWx0LFxuICAgIFREZWxldGVPcmdhbml6YXRpb25NZW1iZXJSZXN1bHQsXG4gICAgVE1lbWJlcnNoaXAsXG4gICAgVE9yZ2FuaXphdGlvbixcbiAgICBUT3JnYW5pemF0aW9uSW52aXRlLFxuICAgIFRPcmdhbml6YXRpb25NZW1iZXIsXG4gICAgVFVzZXJPcmdhbml6YXRpb25JbnZpdGVcbn0gZnJvbSBcIi4vdHlwZXNcIjtcblxuZXhwb3J0IGNsYXNzIE9yZ2FuaXphdGlvblNlcnZpY2UgZXh0ZW5kcyBTZXJ2aWNlQ2xpZW50IHtcbiAgICBwcm90ZWN0ZWQgZ2V0U2VydmljZU5hbWUoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIFwiY29tLmFwcGNvbmRhLnNlcnZpY2Uub3JnYW5pemF0aW9uXCI7XG4gICAgfVxuXG4gICAgQ3JlYXRlT3JnYW5pemF0aW9uKHBheWxvYWQ6IHouaW5mZXI8dHlwZW9mIENyZWF0ZU9yZ2FuaXphdGlvblNjaGVtYT4pOiBQcm9taXNlPFRPcmdhbml6YXRpb24+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aW9uQ2FsbChcIkNyZWF0ZU9yZ2FuaXphdGlvblwiLCBwYXlsb2FkKTtcbiAgICB9XG5cbiAgICBHZXRPcmdhbml6YXRpb25CeUlkKHBheWxvYWQ6IHouaW5mZXI8dHlwZW9mIEdldE9yZ2FuaXphdGlvbkJ5SWRTY2hlbWE+KTogUHJvbWlzZTxUT3JnYW5pemF0aW9uPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJHZXRPcmdhbml6YXRpb25CeUlkXCIsIHBheWxvYWQpO1xuICAgIH1cblxuICAgIFVwZGF0ZU9yZ2FuaXphdGlvbihwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBVcGRhdGVPcmdhbml6YXRpb25TY2hlbWE+KTogUHJvbWlzZTxUT3JnYW5pemF0aW9uPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJVcGRhdGVPcmdhbml6YXRpb25cIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgQ3JlYXRlTWVtYmVyc2hpcChwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBDcmVhdGVNZW1iZXJzaGlwU2NoZW1hPik6IFByb21pc2U8VE1lbWJlcnNoaXA+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aW9uQ2FsbChcIkNyZWF0ZU1lbWJlcnNoaXBcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgUmVnaXN0ZXJPcmdhbml6YXRpb24ocGF5bG9hZDogei5pbmZlcjx0eXBlb2YgUmVnaXN0ZXJPcmdhbml6YXRpb25TY2hlbWE+KTogUHJvbWlzZTxUT3JnYW5pemF0aW9uPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJSZWdpc3Rlck9yZ2FuaXphdGlvblwiLCBwYXlsb2FkKTtcbiAgICB9XG5cbiAgICBHZXRPcmdhbml6YXRpb25zQnlVc2VySWQocGF5bG9hZDogei5pbmZlcjx0eXBlb2YgR2V0T3JnYW5pemF0aW9uc0J5VXNlcklkU2NoZW1hPik6IFByb21pc2U8VE9yZ2FuaXphdGlvbltdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJHZXRPcmdhbml6YXRpb25zQnlVc2VySWRcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgTGlzdE9yZ2FuaXphdGlvbk1lbWJlcnMocGF5bG9hZDogei5pbmZlcjx0eXBlb2YgTGlzdE9yZ2FuaXphdGlvbk1lbWJlcnNTY2hlbWE+KTogUHJvbWlzZTxUT3JnYW5pemF0aW9uTWVtYmVyW10+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aW9uQ2FsbChcIkxpc3RPcmdhbml6YXRpb25NZW1iZXJzXCIsIHBheWxvYWQpO1xuICAgIH1cblxuICAgIExpc3RPcmdhbml6YXRpb25JbnZpdGVzKHBheWxvYWQ6IHouaW5mZXI8dHlwZW9mIExpc3RPcmdhbml6YXRpb25JbnZpdGVzU2NoZW1hPik6IFByb21pc2U8VE9yZ2FuaXphdGlvbkludml0ZVtdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJMaXN0T3JnYW5pemF0aW9uSW52aXRlc1wiLCBwYXlsb2FkKTtcbiAgICB9XG5cbiAgICBJbnZpdGVPcmdhbml6YXRpb25NZW1iZXIoXG4gICAgICAgIHBheWxvYWQ6IHouaW5mZXI8dHlwZW9mIEludml0ZU9yZ2FuaXphdGlvbk1lbWJlclNjaGVtYT5cbiAgICApOiBQcm9taXNlPFRPcmdhbml6YXRpb25NZW1iZXIgfCBUT3JnYW5pemF0aW9uSW52aXRlPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJJbnZpdGVPcmdhbml6YXRpb25NZW1iZXJcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgRGVsZXRlT3JnYW5pemF0aW9uTWVtYmVyKFxuICAgICAgICBwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBEZWxldGVPcmdhbml6YXRpb25NZW1iZXJTY2hlbWE+XG4gICAgKTogUHJvbWlzZTxURGVsZXRlT3JnYW5pemF0aW9uTWVtYmVyUmVzdWx0PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJEZWxldGVPcmdhbml6YXRpb25NZW1iZXJcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgRGVsZXRlT3JnYW5pemF0aW9uSW52aXRlKFxuICAgICAgICBwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBEZWxldGVPcmdhbml6YXRpb25JbnZpdGVTY2hlbWE+XG4gICAgKTogUHJvbWlzZTxURGVsZXRlT3JnYW5pemF0aW9uSW52aXRlUmVzdWx0PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJEZWxldGVPcmdhbml6YXRpb25JbnZpdGVcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgTGlzdFVzZXJPcmdhbml6YXRpb25JbnZpdGVzKFxuICAgICAgICBwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBMaXN0VXNlck9yZ2FuaXphdGlvbkludml0ZXNTY2hlbWE+XG4gICAgKTogUHJvbWlzZTxUVXNlck9yZ2FuaXphdGlvbkludml0ZVtdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJMaXN0VXNlck9yZ2FuaXphdGlvbkludml0ZXNcIiwgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgQWNjZXB0T3JnYW5pemF0aW9uSW52aXRlKFxuICAgICAgICBwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBBY2NlcHRPcmdhbml6YXRpb25JbnZpdGVTY2hlbWE+XG4gICAgKTogUHJvbWlzZTxUT3JnYW5pemF0aW9uTWVtYmVyPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGlvbkNhbGwoXCJBY2NlcHRPcmdhbml6YXRpb25JbnZpdGVcIiwgcGF5bG9hZCk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,11 +1,55 @@
|
|
|
1
1
|
export type TOrganization = {
|
|
2
2
|
id: string;
|
|
3
3
|
name: string;
|
|
4
|
+
createdAt?: string;
|
|
5
|
+
updatedAt?: string;
|
|
6
|
+
billing?: unknown;
|
|
7
|
+
isAIEnabled?: boolean;
|
|
8
|
+
whitelabel?: unknown;
|
|
4
9
|
};
|
|
5
10
|
export type TMembership = {
|
|
6
11
|
userId: string;
|
|
7
12
|
organizationId: string;
|
|
8
13
|
accepted: boolean;
|
|
9
14
|
role: string;
|
|
10
|
-
deprecatedRole
|
|
15
|
+
deprecatedRole?: string | null;
|
|
16
|
+
};
|
|
17
|
+
export type TOrganizationMember = {
|
|
18
|
+
userId: string;
|
|
19
|
+
organizationId: string;
|
|
20
|
+
accepted: boolean;
|
|
21
|
+
role: string;
|
|
22
|
+
email: string;
|
|
23
|
+
name: string;
|
|
24
|
+
avatar?: string | null;
|
|
25
|
+
};
|
|
26
|
+
export type TOrganizationInvite = {
|
|
27
|
+
id: string;
|
|
28
|
+
email: string;
|
|
29
|
+
name?: string | null;
|
|
30
|
+
role?: string | null;
|
|
31
|
+
createdAt: string;
|
|
32
|
+
expiresAt: string;
|
|
33
|
+
};
|
|
34
|
+
export type TDeleteOrganizationMemberResult = {
|
|
35
|
+
organizationId: string;
|
|
36
|
+
userId: string;
|
|
37
|
+
deleted: boolean;
|
|
38
|
+
};
|
|
39
|
+
export type TDeleteOrganizationInviteResult = {
|
|
40
|
+
organizationId: string;
|
|
41
|
+
inviteId: string;
|
|
42
|
+
deleted: boolean;
|
|
43
|
+
};
|
|
44
|
+
export type TUserOrganizationInvite = {
|
|
45
|
+
id: string;
|
|
46
|
+
email: string;
|
|
47
|
+
name?: string | null;
|
|
48
|
+
role?: string | null;
|
|
49
|
+
createdAt: string;
|
|
50
|
+
expiresAt: string;
|
|
51
|
+
organizationId: string;
|
|
52
|
+
organizationName: string;
|
|
53
|
+
inviterName?: string | null;
|
|
54
|
+
inviterEmail?: string | null;
|
|
11
55
|
};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kdWxlcy9vcmdhbml6YXRpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5cbmV4cG9ydCB0eXBlIFRPcmdhbml6YXRpb24gPSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgY3JlYXRlZEF0Pzogc3RyaW5nO1xuICAgIHVwZGF0ZWRBdD86IHN0cmluZztcbiAgICBiaWxsaW5nPzogdW5rbm93bjtcbiAgICBpc0FJRW5hYmxlZD86IGJvb2xlYW47XG4gICAgd2hpdGVsYWJlbD86IHVua25vd247XG59O1xuXG5leHBvcnQgdHlwZSBUTWVtYmVyc2hpcCA9IHtcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBvcmdhbml6YXRpb25JZDogc3RyaW5nO1xuICAgIGFjY2VwdGVkOiBib29sZWFuO1xuICAgIHJvbGU6IHN0cmluZztcbiAgICBkZXByZWNhdGVkUm9sZT86IHN0cmluZyB8IG51bGw7XG59O1xuXG5leHBvcnQgdHlwZSBUT3JnYW5pemF0aW9uTWVtYmVyID0ge1xuICAgIHVzZXJJZDogc3RyaW5nO1xuICAgIG9yZ2FuaXphdGlvbklkOiBzdHJpbmc7XG4gICAgYWNjZXB0ZWQ6IGJvb2xlYW47XG4gICAgcm9sZTogc3RyaW5nO1xuICAgIGVtYWlsOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGF2YXRhcj86IHN0cmluZyB8IG51bGw7XG59O1xuXG5leHBvcnQgdHlwZSBUT3JnYW5pemF0aW9uSW52aXRlID0ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgZW1haWw6IHN0cmluZztcbiAgICBuYW1lPzogc3RyaW5nIHwgbnVsbDtcbiAgICByb2xlPzogc3RyaW5nIHwgbnVsbDtcbiAgICBjcmVhdGVkQXQ6IHN0cmluZztcbiAgICBleHBpcmVzQXQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIFREZWxldGVPcmdhbml6YXRpb25NZW1iZXJSZXN1bHQgPSB7XG4gICAgb3JnYW5pemF0aW9uSWQ6IHN0cmluZztcbiAgICB1c2VySWQ6IHN0cmluZztcbiAgICBkZWxldGVkOiBib29sZWFuO1xufTtcblxuZXhwb3J0IHR5cGUgVERlbGV0ZU9yZ2FuaXphdGlvbkludml0ZVJlc3VsdCA9IHtcbiAgICBvcmdhbml6YXRpb25JZDogc3RyaW5nO1xuICAgIGludml0ZUlkOiBzdHJpbmc7XG4gICAgZGVsZXRlZDogYm9vbGVhbjtcbn07XG5cbmV4cG9ydCB0eXBlIFRVc2VyT3JnYW5pemF0aW9uSW52aXRlID0ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgZW1haWw6IHN0cmluZztcbiAgICBuYW1lPzogc3RyaW5nIHwgbnVsbDtcbiAgICByb2xlPzogc3RyaW5nIHwgbnVsbDtcbiAgICBjcmVhdGVkQXQ6IHN0cmluZztcbiAgICBleHBpcmVzQXQ6IHN0cmluZztcbiAgICBvcmdhbml6YXRpb25JZDogc3RyaW5nO1xuICAgIG9yZ2FuaXphdGlvbk5hbWU6IHN0cmluZztcbiAgICBpbnZpdGVyTmFtZT86IHN0cmluZyB8IG51bGw7XG4gICAgaW52aXRlckVtYWlsPzogc3RyaW5nIHwgbnVsbDtcbn07XG4iXX0=
|
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.
|
|
5
|
+
"version": "1.0.605",
|
|
6
6
|
"license": "BSD-3-Clause",
|
|
7
7
|
"main": "dist/index.js",
|
|
8
8
|
"types": "dist/index.d.ts",
|
package/src/client.ts
CHANGED
|
@@ -31,6 +31,60 @@ class AppcondaException extends Error {
|
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
|
|
34
|
+
type FileLike = {
|
|
35
|
+
size: number;
|
|
36
|
+
slice: (start?: number, end?: number) => Blob;
|
|
37
|
+
name?: string;
|
|
38
|
+
type?: string;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function hasGlobalFileConstructor(): boolean {
|
|
42
|
+
return typeof globalThis !== 'undefined' && typeof (globalThis as any).File !== 'undefined';
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function isFileLike(value: unknown): value is FileLike {
|
|
46
|
+
if (!value || typeof value !== 'object') {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
if (hasGlobalFileConstructor() && value instanceof (globalThis as any).File) {
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return typeof (value as FileLike).size === 'number' && typeof (value as FileLike).slice === 'function';
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
function getFileName(file: FileLike, fallbackName = 'upload.bin'): string {
|
|
58
|
+
if (typeof file.name === 'string' && file.name.length > 0) {
|
|
59
|
+
return file.name;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
return fallbackName;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function createChunkFile(chunk: Blob, filename: string): Blob | File {
|
|
66
|
+
if (hasGlobalFileConstructor()) {
|
|
67
|
+
return new (globalThis as any).File([chunk], filename, {
|
|
68
|
+
type: chunk.type || 'application/octet-stream',
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const blob = new Blob([chunk], {
|
|
73
|
+
type: chunk.type || 'application/octet-stream',
|
|
74
|
+
}) as Blob & { name?: string };
|
|
75
|
+
|
|
76
|
+
try {
|
|
77
|
+
Object.defineProperty(blob, 'name', {
|
|
78
|
+
value: filename,
|
|
79
|
+
configurable: true,
|
|
80
|
+
});
|
|
81
|
+
} catch {
|
|
82
|
+
// Fallback for runtimes where Blob is not extensible.
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
return blob;
|
|
86
|
+
}
|
|
87
|
+
|
|
34
88
|
function getUserAgent() {
|
|
35
89
|
let ua = 'AppcondaNodeJSSDK/14.1.0';
|
|
36
90
|
|
|
@@ -86,6 +140,7 @@ class Client {
|
|
|
86
140
|
'user-agent': getUserAgent(),
|
|
87
141
|
'X-Appconda-Response-Format': '1.6.0',
|
|
88
142
|
};
|
|
143
|
+
private fetchImpl?: typeof fetch;
|
|
89
144
|
|
|
90
145
|
/**
|
|
91
146
|
* Set Endpoint
|
|
@@ -134,6 +189,26 @@ class Client {
|
|
|
134
189
|
return this;
|
|
135
190
|
}
|
|
136
191
|
|
|
192
|
+
/**
|
|
193
|
+
* Set custom fetch implementation.
|
|
194
|
+
*
|
|
195
|
+
* Useful for Node.js versions without a global fetch.
|
|
196
|
+
*/
|
|
197
|
+
setFetch(fetchImpl: typeof fetch): this {
|
|
198
|
+
this.fetchImpl = fetchImpl;
|
|
199
|
+
return this;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
private getFetch(): typeof fetch {
|
|
203
|
+
const runtimeFetch = this.fetchImpl ?? (typeof globalThis !== 'undefined' ? globalThis.fetch : undefined);
|
|
204
|
+
|
|
205
|
+
if (!runtimeFetch) {
|
|
206
|
+
throw new AppcondaException('Fetch API is not available. Use Node.js 18+ or set a custom fetch with client.setFetch().');
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
return runtimeFetch.bind(globalThis);
|
|
210
|
+
}
|
|
211
|
+
|
|
137
212
|
/**
|
|
138
213
|
* Set Project
|
|
139
214
|
*
|
|
@@ -272,14 +347,18 @@ class Client {
|
|
|
272
347
|
const formData = new FormData();
|
|
273
348
|
|
|
274
349
|
for (const [key, value] of Object.entries(params)) {
|
|
275
|
-
if (value
|
|
276
|
-
formData.append(key, value, value
|
|
350
|
+
if (isFileLike(value)) {
|
|
351
|
+
formData.append(key, value as unknown as Blob, getFileName(value));
|
|
277
352
|
} else if (Array.isArray(value)) {
|
|
278
353
|
for (const nestedValue of value) {
|
|
279
|
-
|
|
354
|
+
if (isFileLike(nestedValue)) {
|
|
355
|
+
formData.append(`${key}[]`, nestedValue as unknown as Blob, getFileName(nestedValue));
|
|
356
|
+
} else {
|
|
357
|
+
formData.append(`${key}[]`, nestedValue as any);
|
|
358
|
+
}
|
|
280
359
|
}
|
|
281
360
|
} else {
|
|
282
|
-
formData.append(key, value);
|
|
361
|
+
formData.append(key, value as any);
|
|
283
362
|
}
|
|
284
363
|
}
|
|
285
364
|
|
|
@@ -293,7 +372,11 @@ class Client {
|
|
|
293
372
|
}
|
|
294
373
|
|
|
295
374
|
async chunkedUpload(method: string, url: URL, headers: Headers = {}, originalPayload: Payload = {}, onProgress: (progress: UploadProgress) => void) {
|
|
296
|
-
const file
|
|
375
|
+
const file = Object.values(originalPayload).find((value) => isFileLike(value)) as FileLike | undefined;
|
|
376
|
+
|
|
377
|
+
if (!file) {
|
|
378
|
+
return await this.call(method, url, headers, originalPayload);
|
|
379
|
+
}
|
|
297
380
|
|
|
298
381
|
if (file.size <= Client.CHUNK_SIZE) {
|
|
299
382
|
return await this.call(method, url, headers, originalPayload);
|
|
@@ -311,7 +394,10 @@ class Client {
|
|
|
311
394
|
headers['content-range'] = `bytes ${start}-${end - 1}/${file.size}`;
|
|
312
395
|
const chunk = file.slice(start, end);
|
|
313
396
|
|
|
314
|
-
|
|
397
|
+
const payload = {
|
|
398
|
+
...originalPayload,
|
|
399
|
+
file: createChunkFile(chunk, getFileName(file)),
|
|
400
|
+
};
|
|
315
401
|
|
|
316
402
|
response = await this.call(method, url, headers, payload);
|
|
317
403
|
|
|
@@ -337,8 +423,9 @@ class Client {
|
|
|
337
423
|
|
|
338
424
|
async redirect(method: string, url: URL, headers: Headers = {}, params: Payload = {}): Promise<string> {
|
|
339
425
|
const { uri, options } = this.prepareRequest(method, url, headers, params);
|
|
426
|
+
const runtimeFetch = this.getFetch();
|
|
340
427
|
|
|
341
|
-
const response = await
|
|
428
|
+
const response = await runtimeFetch(uri, {
|
|
342
429
|
...options,
|
|
343
430
|
redirect: 'manual'
|
|
344
431
|
});
|
|
@@ -352,11 +439,12 @@ class Client {
|
|
|
352
439
|
|
|
353
440
|
async call(method: string, url: URL, headers: Headers = {}, params: Payload = {}, responseType = 'json'): Promise<any> {
|
|
354
441
|
const { uri, options } = this.prepareRequest(method, url, headers, params);
|
|
442
|
+
const runtimeFetch = this.getFetch();
|
|
355
443
|
|
|
356
444
|
let data: any = null;
|
|
357
445
|
|
|
358
446
|
try {
|
|
359
|
-
const response = await
|
|
447
|
+
const response = await runtimeFetch(uri, options);
|
|
360
448
|
|
|
361
449
|
const warnings = response.headers.get('x-appconda-warning');
|
|
362
450
|
if (warnings) {
|