@lssm/lib.files 0.0.0-canary-20251207012602 → 0.0.0-canary-20251207043720
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/README.md +1 -0
- package/dist/contracts/index.js +1 -1
- package/dist/entities/index.js +1 -1
- package/dist/events.js +1 -1
- package/dist/storage/index.js +1 -1
- package/package.json +15 -7
- package/dist/contracts/dist/capabilities/openbanking.js +0 -1
- package/dist/contracts/dist/client/index.js +0 -1
- package/dist/contracts/dist/client/react/feature-render.js +0 -1
- package/dist/contracts/dist/client/react/form-render.js +0 -1
- package/dist/contracts/dist/client/react/index.js +0 -1
- package/dist/contracts/dist/events.js +0 -1
- package/dist/contracts/dist/experiments/evaluator.js +0 -1
- package/dist/contracts/dist/graphql-federation/dist/index.js +0 -1
- package/dist/contracts/dist/index.js +0 -1
- package/dist/contracts/dist/install.js +0 -1
- package/dist/contracts/dist/integrations/contracts.js +0 -1
- package/dist/contracts/dist/integrations/index.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/contracts/accounts.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/contracts/balances.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/contracts/index.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/contracts/transactions.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/models.js +0 -1
- package/dist/contracts/dist/integrations/openbanking/telemetry.js +0 -1
- package/dist/contracts/dist/integrations/providers/elevenlabs.js +0 -1
- package/dist/contracts/dist/integrations/providers/gcs-storage.js +0 -1
- package/dist/contracts/dist/integrations/providers/gmail.js +0 -1
- package/dist/contracts/dist/integrations/providers/google-calendar.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/elevenlabs-voice.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/gcs-storage.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/gmail-inbound.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/gmail-outbound.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/google-calendar.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/index.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/mistral-embedding.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/mistral-llm.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/postmark-email.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/powens-client.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/powens-openbanking.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/provider-factory.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/qdrant-vector.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/stripe-payments.js +0 -1
- package/dist/contracts/dist/integrations/providers/impls/twilio-sms.js +0 -1
- package/dist/contracts/dist/integrations/providers/index.js +0 -1
- package/dist/contracts/dist/integrations/providers/mistral.js +0 -1
- package/dist/contracts/dist/integrations/providers/postmark.js +0 -1
- package/dist/contracts/dist/integrations/providers/powens.js +0 -1
- package/dist/contracts/dist/integrations/providers/qdrant.js +0 -1
- package/dist/contracts/dist/integrations/providers/stripe.js +0 -1
- package/dist/contracts/dist/integrations/providers/twilio-sms.js +0 -1
- package/dist/contracts/dist/integrations/runtime.js +0 -1
- package/dist/contracts/dist/integrations/secrets/env-secret-provider.js +0 -1
- package/dist/contracts/dist/integrations/secrets/gcp-secret-manager.js +0 -1
- package/dist/contracts/dist/integrations/secrets/index.js +0 -1
- package/dist/contracts/dist/integrations/secrets/manager.js +0 -1
- package/dist/contracts/dist/integrations/secrets/provider.js +0 -1
- package/dist/contracts/dist/jsonschema.js +0 -1
- package/dist/contracts/dist/knowledge/contracts.js +0 -1
- package/dist/contracts/dist/knowledge/index.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/email-threads.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/financial-docs.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/financial-overview.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/index.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/product-canon.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/support-faq.js +0 -1
- package/dist/contracts/dist/knowledge/spaces/uploaded-docs.js +0 -1
- package/dist/contracts/dist/onboarding-base.js +0 -1
- package/dist/contracts/dist/ownership.js +0 -1
- package/dist/contracts/dist/presentations.js +0 -1
- package/dist/contracts/dist/presentations.v2.js +0 -1
- package/dist/contracts/dist/prompt.js +0 -1
- package/dist/contracts/dist/promptRegistry.js +0 -1
- package/dist/contracts/dist/regenerator/index.js +0 -1
- package/dist/contracts/dist/regenerator/service.js +0 -1
- package/dist/contracts/dist/registry.js +0 -1
- package/dist/contracts/dist/resources.js +0 -1
- package/dist/contracts/dist/schema/dist/EnumType.js +0 -1
- package/dist/contracts/dist/schema/dist/FieldType.js +0 -1
- package/dist/contracts/dist/schema/dist/ScalarTypeEnum.js +0 -1
- package/dist/contracts/dist/schema/dist/SchemaModel.js +0 -1
- package/dist/contracts/dist/schema/dist/entity/defineEntity.js +0 -1
- package/dist/contracts/dist/schema/dist/entity/index.js +0 -1
- package/dist/contracts/dist/schema/dist/entity/types.js +0 -1
- package/dist/contracts/dist/schema/dist/index.js +0 -1
- package/dist/contracts/dist/server/graphql-pothos.js +0 -1
- package/dist/contracts/dist/server/graphql-schema-export.js +0 -1
- package/dist/contracts/dist/server/index.js +0 -1
- package/dist/contracts/dist/server/provider-mcp.js +0 -1
- package/dist/contracts/dist/server/rest-elysia.js +0 -1
- package/dist/contracts/dist/server/rest-express.js +0 -1
- package/dist/contracts/dist/server/rest-generic.js +0 -1
- package/dist/contracts/dist/server/rest-next-app.js +0 -1
- package/dist/contracts/dist/server/rest-next-pages.js +0 -1
- package/dist/contracts/dist/spec.js +0 -1
- package/dist/contracts/dist/telemetry/index.js +0 -1
- package/dist/contracts/dist/telemetry/tracker.js +0 -1
- package/dist/contracts/dist/tests/index.js +0 -1
- package/dist/contracts/dist/tests/runner.js +0 -1
- package/dist/contracts/dist/workflow/index.js +0 -1
- package/dist/contracts/dist/workflow/runner.js +0 -1
- package/dist/contracts/index.d.ts +0 -1139
- package/dist/entities/index.d.ts +0 -168
- package/dist/events.d.ts +0 -467
- package/dist/index.d.ts +0 -5
- package/dist/schema/dist/EnumType.js +0 -1
- package/dist/schema/dist/FieldType.js +0 -1
- package/dist/schema/dist/ScalarTypeEnum.js +0 -1
- package/dist/schema/dist/SchemaModel.js +0 -1
- package/dist/schema/dist/entity/defineEntity.js +0 -1
- package/dist/schema/dist/entity/index.js +0 -1
- package/dist/schema/dist/entity/types.js +0 -1
- package/dist/schema/dist/index.js +0 -1
- package/dist/storage/index.d.ts +0 -200
package/README.md
CHANGED
package/dist/contracts/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{l as e}from"../schema/dist/ScalarTypeEnum.js";import{n as t}from"../schema/dist/SchemaModel.js";import"../schema/dist/index.js";import{n,t as r}from"./dist/spec.js";import"./dist/index.js";const i=[`platform.files`],a=t({name:`File`,description:`Represents an uploaded file`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},storageProvider:{type:e.String_unsecure(),isOptional:!1},storagePath:{type:e.String_unsecure(),isOptional:!1},checksum:{type:e.String_unsecure(),isOptional:!0},status:{type:e.String_unsecure(),isOptional:!1},isPublic:{type:e.Boolean(),isOptional:!1},ownerId:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},width:{type:e.Int_unsecure(),isOptional:!0},height:{type:e.Int_unsecure(),isOptional:!0},createdAt:{type:e.DateTime(),isOptional:!1},updatedAt:{type:e.DateTime(),isOptional:!1}}}),o=t({name:`FileVersion`,description:`Represents a file version`,fields:{id:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},version:{type:e.Int_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},storagePath:{type:e.String_unsecure(),isOptional:!1},checksum:{type:e.String_unsecure(),isOptional:!0},comment:{type:e.String_unsecure(),isOptional:!0},createdBy:{type:e.String_unsecure(),isOptional:!1},createdAt:{type:e.DateTime(),isOptional:!1}}}),s=t({name:`Attachment`,description:`Represents an attachment`,fields:{id:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!0},description:{type:e.String_unsecure(),isOptional:!0},order:{type:e.Int_unsecure(),isOptional:!1},metadata:{type:e.JSON(),isOptional:!0},createdBy:{type:e.String_unsecure(),isOptional:!1},createdAt:{type:e.DateTime(),isOptional:!1},file:{type:a,isOptional:!0}}}),c=t({name:`PresignedUrl`,description:`A presigned URL for file operations`,fields:{url:{type:e.String_unsecure(),isOptional:!1},fields:{type:e.JSON(),isOptional:!0},expiresAt:{type:e.DateTime(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!0},sessionId:{type:e.String_unsecure(),isOptional:!0}}}),l=t({name:`UploadFileInput`,description:`Input for uploading a file`,fields:{name:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},content:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},isPublic:{type:e.Boolean(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0}}}),u=t({name:`UpdateFileInput`,description:`Input for updating a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!0},isPublic:{type:e.Boolean(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0}}}),d=t({name:`DeleteFileInput`,description:`Input for deleting a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1}}}),f=t({name:`GetFileInput`,description:`Input for getting a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1}}}),p=t({name:`ListFilesInput`,description:`Input for listing files`,fields:{orgId:{type:e.String_unsecure(),isOptional:!0},ownerId:{type:e.String_unsecure(),isOptional:!0},mimeType:{type:e.String_unsecure(),isOptional:!0},status:{type:e.String_unsecure(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0},limit:{type:e.Int_unsecure(),isOptional:!0},offset:{type:e.Int_unsecure(),isOptional:!0}}}),m=t({name:`ListFilesOutput`,description:`Output for listing files`,fields:{files:{type:a,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),h=t({name:`GetDownloadUrlInput`,description:`Input for getting a download URL`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},expiresInSeconds:{type:e.Int_unsecure(),isOptional:!0}}}),g=t({name:`CreateVersionInput`,description:`Input for creating a file version`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},content:{type:e.String_unsecure(),isOptional:!1},comment:{type:e.String_unsecure(),isOptional:!0}}}),_=t({name:`GetVersionsInput`,description:`Input for getting file versions`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},limit:{type:e.Int_unsecure(),isOptional:!0},offset:{type:e.Int_unsecure(),isOptional:!0}}}),v=t({name:`GetVersionsOutput`,description:`Output for getting file versions`,fields:{versions:{type:o,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),y=t({name:`AttachFileInput`,description:`Input for attaching a file to an entity`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!0},description:{type:e.String_unsecure(),isOptional:!0},order:{type:e.Int_unsecure(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0}}}),b=t({name:`DetachFileInput`,description:`Input for detaching a file`,fields:{attachmentId:{type:e.String_unsecure(),isOptional:!1}}}),x=t({name:`ListAttachmentsInput`,description:`Input for listing attachments`,fields:{entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0}}}),S=t({name:`ListAttachmentsOutput`,description:`Output for listing attachments`,fields:{attachments:{type:s,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),C=t({name:`CreatePresignedUrlInput`,description:`Input for creating a presigned upload URL`,fields:{fileName:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},expiresInSeconds:{type:e.Int_unsecure(),isOptional:!0}}}),w=t({name:`SuccessOutput`,description:`Generic success output`,fields:{success:{type:e.Boolean(),isOptional:!1}}}),T=r({meta:{name:`file.upload`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`upload`],description:`Upload a new file.`,goal:`Store a file and create a file record.`,context:`Called when uploading files directly.`},io:{input:l,output:a,errors:{FILE_TOO_LARGE:{description:`File exceeds size limit`,http:413,gqlCode:`FILE_TOO_LARGE`,when:`File size exceeds configured limit`},INVALID_MIME_TYPE:{description:`MIME type not allowed`,http:415,gqlCode:`INVALID_MIME_TYPE`,when:`File type is not in allowed list`}}},policy:{auth:`user`}}),E=r({meta:{name:`file.update`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`update`],description:`Update file metadata.`,goal:`Modify file properties without replacing content.`,context:`Called when renaming or updating file metadata.`},io:{input:u,output:a,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),D=r({meta:{name:`file.delete`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`delete`],description:`Delete a file.`,goal:`Remove a file and all its versions and attachments.`,context:`Called when removing a file permanently.`},io:{input:d,output:w,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),O=n({meta:{name:`file.get`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`get`],description:`Get a file by ID.`,goal:`Retrieve file metadata.`,context:`Called to inspect file details.`},io:{input:f,output:a,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),k=n({meta:{name:`file.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`list`],description:`List files with filtering.`,goal:`Browse uploaded files.`,context:`Called to browse file library.`},io:{input:p,output:m},policy:{auth:`user`}}),A=n({meta:{name:`file.downloadUrl`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`download`],description:`Get a presigned download URL.`,goal:`Generate a temporary URL for downloading.`,context:`Called when user wants to download a file.`},io:{input:h,output:c,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),j=r({meta:{name:`file.version.create`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`version`,`create`],description:`Create a new version of a file.`,goal:`Upload a new version while preserving history.`,context:`Called when updating a document.`},io:{input:g,output:o,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),M=n({meta:{name:`file.version.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`version`,`list`],description:`Get file version history.`,goal:`View all versions of a file.`,context:`Called to browse file history.`},io:{input:_,output:v,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),N=r({meta:{name:`attachment.attach`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`attach`],description:`Attach a file to an entity.`,goal:`Link a file to a business entity.`,context:`Called when associating files with entities.`},io:{input:y,output:s,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`},ATTACHMENT_EXISTS:{description:`Attachment already exists`,http:409,gqlCode:`ATTACHMENT_EXISTS`,when:`File is already attached to this entity`}}},policy:{auth:`user`}}),P=r({meta:{name:`attachment.detach`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`detach`],description:`Detach a file from an entity.`,goal:`Remove a file association.`,context:`Called when removing file from entity.`},io:{input:b,output:w,errors:{ATTACHMENT_NOT_FOUND:{description:`Attachment does not exist`,http:404,gqlCode:`ATTACHMENT_NOT_FOUND`,when:`Attachment ID is invalid`}}},policy:{auth:`user`}}),F=n({meta:{name:`attachment.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`list`],description:`List attachments for an entity.`,goal:`Get all files attached to an entity.`,context:`Called to display attached files.`},io:{input:x,output:S},policy:{auth:`user`}}),I=r({meta:{name:`file.presignedUrl.create`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`presigned`,`upload`],description:`Create a presigned URL for direct upload.`,goal:`Enable direct-to-storage uploads.`,context:`Called for large file uploads.`},io:{input:C,output:c,errors:{FILE_TOO_LARGE:{description:`File exceeds size limit`,http:413,gqlCode:`FILE_TOO_LARGE`,when:`Requested file size exceeds limit`},INVALID_MIME_TYPE:{description:`MIME type not allowed`,http:415,gqlCode:`INVALID_MIME_TYPE`,when:`File type is not in allowed list`}}},policy:{auth:`user`}});export{N as AttachFileContract,s as AttachmentModel,I as CreatePresignedUrlContract,j as CreateVersionContract,D as DeleteFileContract,P as DetachFileContract,a as FileModel,o as FileVersionModel,A as GetDownloadUrlContract,O as GetFileContract,M as GetVersionsContract,F as ListAttachmentsContract,k as ListFilesContract,c as PresignedUrlModel,E as UpdateFileContract,T as UploadFileContract};
|
|
1
|
+
import{ScalarTypeEnum as e,defineSchemaModel as t}from"@lssm/lib.schema";import{defineCommand as n,defineQuery as r}from"@lssm/lib.contracts";const i=[`platform.files`],a=t({name:`File`,description:`Represents an uploaded file`,fields:{id:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},storageProvider:{type:e.String_unsecure(),isOptional:!1},storagePath:{type:e.String_unsecure(),isOptional:!1},checksum:{type:e.String_unsecure(),isOptional:!0},status:{type:e.String_unsecure(),isOptional:!1},isPublic:{type:e.Boolean(),isOptional:!1},ownerId:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},width:{type:e.Int_unsecure(),isOptional:!0},height:{type:e.Int_unsecure(),isOptional:!0},createdAt:{type:e.DateTime(),isOptional:!1},updatedAt:{type:e.DateTime(),isOptional:!1}}}),o=t({name:`FileVersion`,description:`Represents a file version`,fields:{id:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},version:{type:e.Int_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},storagePath:{type:e.String_unsecure(),isOptional:!1},checksum:{type:e.String_unsecure(),isOptional:!0},comment:{type:e.String_unsecure(),isOptional:!0},createdBy:{type:e.String_unsecure(),isOptional:!1},createdAt:{type:e.DateTime(),isOptional:!1}}}),s=t({name:`Attachment`,description:`Represents an attachment`,fields:{id:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!0},description:{type:e.String_unsecure(),isOptional:!0},order:{type:e.Int_unsecure(),isOptional:!1},metadata:{type:e.JSON(),isOptional:!0},createdBy:{type:e.String_unsecure(),isOptional:!1},createdAt:{type:e.DateTime(),isOptional:!1},file:{type:a,isOptional:!0}}}),c=t({name:`PresignedUrl`,description:`A presigned URL for file operations`,fields:{url:{type:e.String_unsecure(),isOptional:!1},fields:{type:e.JSON(),isOptional:!0},expiresAt:{type:e.DateTime(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!0},sessionId:{type:e.String_unsecure(),isOptional:!0}}}),l=t({name:`UploadFileInput`,description:`Input for uploading a file`,fields:{name:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},content:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},isPublic:{type:e.Boolean(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0}}}),u=t({name:`UpdateFileInput`,description:`Input for updating a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!0},isPublic:{type:e.Boolean(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0}}}),d=t({name:`DeleteFileInput`,description:`Input for deleting a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1}}}),f=t({name:`GetFileInput`,description:`Input for getting a file`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1}}}),p=t({name:`ListFilesInput`,description:`Input for listing files`,fields:{orgId:{type:e.String_unsecure(),isOptional:!0},ownerId:{type:e.String_unsecure(),isOptional:!0},mimeType:{type:e.String_unsecure(),isOptional:!0},status:{type:e.String_unsecure(),isOptional:!0},tags:{type:e.JSON(),isOptional:!0},limit:{type:e.Int_unsecure(),isOptional:!0},offset:{type:e.Int_unsecure(),isOptional:!0}}}),m=t({name:`ListFilesOutput`,description:`Output for listing files`,fields:{files:{type:a,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),h=t({name:`GetDownloadUrlInput`,description:`Input for getting a download URL`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},expiresInSeconds:{type:e.Int_unsecure(),isOptional:!0}}}),g=t({name:`CreateVersionInput`,description:`Input for creating a file version`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},content:{type:e.String_unsecure(),isOptional:!1},comment:{type:e.String_unsecure(),isOptional:!0}}}),_=t({name:`GetVersionsInput`,description:`Input for getting file versions`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},limit:{type:e.Int_unsecure(),isOptional:!0},offset:{type:e.Int_unsecure(),isOptional:!0}}}),v=t({name:`GetVersionsOutput`,description:`Output for getting file versions`,fields:{versions:{type:o,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),y=t({name:`AttachFileInput`,description:`Input for attaching a file to an entity`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0},name:{type:e.String_unsecure(),isOptional:!0},description:{type:e.String_unsecure(),isOptional:!0},order:{type:e.Int_unsecure(),isOptional:!0},metadata:{type:e.JSON(),isOptional:!0}}}),b=t({name:`DetachFileInput`,description:`Input for detaching a file`,fields:{attachmentId:{type:e.String_unsecure(),isOptional:!1}}}),x=t({name:`ListAttachmentsInput`,description:`Input for listing attachments`,fields:{entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0}}}),S=t({name:`ListAttachmentsOutput`,description:`Output for listing attachments`,fields:{attachments:{type:s,isArray:!0,isOptional:!1},total:{type:e.Int_unsecure(),isOptional:!1}}}),C=t({name:`CreatePresignedUrlInput`,description:`Input for creating a presigned upload URL`,fields:{fileName:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},expiresInSeconds:{type:e.Int_unsecure(),isOptional:!0}}}),w=t({name:`SuccessOutput`,description:`Generic success output`,fields:{success:{type:e.Boolean(),isOptional:!1}}}),T=n({meta:{name:`file.upload`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`upload`],description:`Upload a new file.`,goal:`Store a file and create a file record.`,context:`Called when uploading files directly.`},io:{input:l,output:a,errors:{FILE_TOO_LARGE:{description:`File exceeds size limit`,http:413,gqlCode:`FILE_TOO_LARGE`,when:`File size exceeds configured limit`},INVALID_MIME_TYPE:{description:`MIME type not allowed`,http:415,gqlCode:`INVALID_MIME_TYPE`,when:`File type is not in allowed list`}}},policy:{auth:`user`}}),E=n({meta:{name:`file.update`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`update`],description:`Update file metadata.`,goal:`Modify file properties without replacing content.`,context:`Called when renaming or updating file metadata.`},io:{input:u,output:a,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),D=n({meta:{name:`file.delete`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`delete`],description:`Delete a file.`,goal:`Remove a file and all its versions and attachments.`,context:`Called when removing a file permanently.`},io:{input:d,output:w,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),O=r({meta:{name:`file.get`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`get`],description:`Get a file by ID.`,goal:`Retrieve file metadata.`,context:`Called to inspect file details.`},io:{input:f,output:a,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),k=r({meta:{name:`file.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`list`],description:`List files with filtering.`,goal:`Browse uploaded files.`,context:`Called to browse file library.`},io:{input:p,output:m},policy:{auth:`user`}}),A=r({meta:{name:`file.downloadUrl`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`download`],description:`Get a presigned download URL.`,goal:`Generate a temporary URL for downloading.`,context:`Called when user wants to download a file.`},io:{input:h,output:c,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),j=n({meta:{name:`file.version.create`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`version`,`create`],description:`Create a new version of a file.`,goal:`Upload a new version while preserving history.`,context:`Called when updating a document.`},io:{input:g,output:o,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),M=r({meta:{name:`file.version.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`version`,`list`],description:`Get file version history.`,goal:`View all versions of a file.`,context:`Called to browse file history.`},io:{input:_,output:v,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`}}},policy:{auth:`user`}}),N=n({meta:{name:`attachment.attach`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`attach`],description:`Attach a file to an entity.`,goal:`Link a file to a business entity.`,context:`Called when associating files with entities.`},io:{input:y,output:s,errors:{FILE_NOT_FOUND:{description:`File does not exist`,http:404,gqlCode:`FILE_NOT_FOUND`,when:`File ID is invalid`},ATTACHMENT_EXISTS:{description:`Attachment already exists`,http:409,gqlCode:`ATTACHMENT_EXISTS`,when:`File is already attached to this entity`}}},policy:{auth:`user`}}),P=n({meta:{name:`attachment.detach`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`detach`],description:`Detach a file from an entity.`,goal:`Remove a file association.`,context:`Called when removing file from entity.`},io:{input:b,output:w,errors:{ATTACHMENT_NOT_FOUND:{description:`Attachment does not exist`,http:404,gqlCode:`ATTACHMENT_NOT_FOUND`,when:`Attachment ID is invalid`}}},policy:{auth:`user`}}),F=r({meta:{name:`attachment.list`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`attachment`,`list`],description:`List attachments for an entity.`,goal:`Get all files attached to an entity.`,context:`Called to display attached files.`},io:{input:x,output:S},policy:{auth:`user`}}),I=n({meta:{name:`file.presignedUrl.create`,version:1,stability:`stable`,owners:[...i],tags:[`files`,`presigned`,`upload`],description:`Create a presigned URL for direct upload.`,goal:`Enable direct-to-storage uploads.`,context:`Called for large file uploads.`},io:{input:C,output:c,errors:{FILE_TOO_LARGE:{description:`File exceeds size limit`,http:413,gqlCode:`FILE_TOO_LARGE`,when:`Requested file size exceeds limit`},INVALID_MIME_TYPE:{description:`MIME type not allowed`,http:415,gqlCode:`INVALID_MIME_TYPE`,when:`File type is not in allowed list`}}},policy:{auth:`user`}});export{N as AttachFileContract,s as AttachmentModel,I as CreatePresignedUrlContract,j as CreateVersionContract,D as DeleteFileContract,P as DetachFileContract,a as FileModel,o as FileVersionModel,A as GetDownloadUrlContract,O as GetFileContract,M as GetVersionsContract,F as ListAttachmentsContract,k as ListFilesContract,c as PresignedUrlModel,E as UpdateFileContract,T as UploadFileContract};
|
package/dist/entities/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{defineEntity as e,defineEntityEnum as t,field as n,index as r}from"@lssm/lib.schema";const i=t({name:`StorageProvider`,values:[`LOCAL`,`S3`,`GCS`,`AZURE`,`CLOUDFLARE`],schema:`lssm_files`,description:`Storage backend provider.`}),a=t({name:`FileStatus`,values:[`PENDING`,`UPLOADED`,`PROCESSING`,`READY`,`ERROR`,`DELETED`],schema:`lssm_files`,description:`File processing status.`}),o=e({name:`File`,description:`An uploaded file.`,schema:`lssm_files`,map:`file`,fields:{id:n.id({description:`Unique file identifier`}),name:n.string({description:`Original file name`}),mimeType:n.string({description:`MIME type`}),size:n.int({description:`File size in bytes`}),storageProvider:n.enum(`StorageProvider`,{default:`LOCAL`,description:`Storage backend`}),storagePath:n.string({description:`Path in storage backend`}),storageKey:n.string({isOptional:!0,description:`Storage key/bucket`}),checksum:n.string({isOptional:!0,description:`SHA-256 checksum`}),etag:n.string({isOptional:!0,description:`Storage ETag`}),status:n.enum(`FileStatus`,{default:`PENDING`,description:`File status`}),isPublic:n.boolean({default:!1,description:`Whether file is publicly accessible`}),expiresAt:n.dateTime({isOptional:!0,description:`Auto-delete timestamp`}),ownerId:n.string({description:`User who uploaded`}),orgId:n.string({isOptional:!0,description:`Organization scope`}),metadata:n.json({isOptional:!0,description:`Additional metadata`}),tags:n.json({isOptional:!0,description:`Tags for categorization`}),width:n.int({isOptional:!0,description:`Image width in pixels`}),height:n.int({isOptional:!0,description:`Image height in pixels`}),createdAt:n.createdAt(),updatedAt:n.updatedAt(),versions:n.hasMany(`FileVersion`),attachments:n.hasMany(`Attachment`)},indexes:[r.on([`ownerId`]),r.on([`orgId`]),r.on([`status`]),r.on([`mimeType`]),r.on([`storageProvider`,`storagePath`])],enums:[i,a]}),s=e({name:`FileVersion`,description:`A version of a file.`,schema:`lssm_files`,map:`file_version`,fields:{id:n.id({description:`Unique version identifier`}),fileId:n.foreignKey({description:`Parent file`}),version:n.int({description:`Version number`}),size:n.int({description:`Version size in bytes`}),storagePath:n.string({description:`Path in storage backend`}),checksum:n.string({isOptional:!0,description:`SHA-256 checksum`}),comment:n.string({isOptional:!0,description:`Version comment`}),changes:n.json({isOptional:!0,description:`Change description`}),createdBy:n.string({description:`User who created version`}),createdAt:n.createdAt(),file:n.belongsTo(`File`,[`fileId`],[`id`],{onDelete:`Cascade`})},indexes:[r.on([`fileId`,`version`]),r.unique([`fileId`,`version`],{name:`file_version_unique`})]}),c=e({name:`Attachment`,description:`Links a file to an entity.`,schema:`lssm_files`,map:`attachment`,fields:{id:n.id({description:`Unique attachment identifier`}),fileId:n.foreignKey({description:`Attached file`}),entityType:n.string({description:`Target entity type (deal, listing, etc.)`}),entityId:n.string({description:`Target entity ID`}),attachmentType:n.string({isOptional:!0,description:`Type of attachment (document, image, avatar, etc.)`}),name:n.string({isOptional:!0,description:`Display name (overrides file name)`}),description:n.string({isOptional:!0,description:`Attachment description`}),order:n.int({default:0,description:`Display order`}),metadata:n.json({isOptional:!0,description:`Attachment-specific metadata`}),createdBy:n.string({description:`User who created attachment`}),createdAt:n.createdAt(),updatedAt:n.updatedAt(),file:n.belongsTo(`File`,[`fileId`],[`id`],{onDelete:`Cascade`})},indexes:[r.on([`entityType`,`entityId`]),r.on([`fileId`]),r.on([`entityType`,`entityId`,`attachmentType`]),r.unique([`fileId`,`entityType`,`entityId`],{name:`attachment_unique`})]}),l=e({name:`UploadSession`,description:`Tracks a multipart upload session.`,schema:`lssm_files`,map:`upload_session`,fields:{id:n.id({description:`Unique session identifier`}),fileName:n.string({description:`Target file name`}),mimeType:n.string({description:`Expected MIME type`}),totalSize:n.int({description:`Total file size`}),uploadId:n.string({isOptional:!0,description:`Storage upload ID`}),uploadedBytes:n.int({default:0,description:`Bytes uploaded so far`}),uploadedParts:n.json({isOptional:!0,description:`Completed part info`}),status:n.string({default:`"pending"`,description:`Session status`}),error:n.string({isOptional:!0,description:`Error message if failed`}),fileId:n.string({isOptional:!0,description:`Resulting file ID`}),ownerId:n.string({description:`User who initiated upload`}),orgId:n.string({isOptional:!0,description:`Organization scope`}),expiresAt:n.dateTime({description:`Session expiry time`}),createdAt:n.createdAt(),updatedAt:n.updatedAt()},indexes:[r.on([`status`,`expiresAt`]),r.on([`ownerId`])]}),u=[o,s,c,l],d={moduleId:`@lssm/lib.files`,entities:u,enums:[i,a]};export{c as AttachmentEntity,o as FileEntity,a as FileStatusEnum,s as FileVersionEntity,i as StorageProviderEnum,l as UploadSessionEntity,u as fileEntities,d as filesSchemaContribution};
|
package/dist/events.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{ScalarTypeEnum as e,defineSchemaModel as t}from"@lssm/lib.schema";import{defineEvent as n}from"@lssm/lib.contracts";const r=t({name:`FileUploadedEventPayload`,description:`Payload when a file is uploaded`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},storageProvider:{type:e.String_unsecure(),isOptional:!1},ownerId:{type:e.String_unsecure(),isOptional:!1},orgId:{type:e.String_unsecure(),isOptional:!0},uploadedAt:{type:e.DateTime(),isOptional:!1}}}),i=t({name:`FileUpdatedEventPayload`,description:`Payload when a file is updated`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},changes:{type:e.JSON(),isOptional:!1},updatedBy:{type:e.String_unsecure(),isOptional:!0},updatedAt:{type:e.DateTime(),isOptional:!1}}}),a=t({name:`FileDeletedEventPayload`,description:`Payload when a file is deleted`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},name:{type:e.String_unsecure(),isOptional:!1},storageProvider:{type:e.String_unsecure(),isOptional:!1},storagePath:{type:e.String_unsecure(),isOptional:!1},deletedBy:{type:e.String_unsecure(),isOptional:!0},deletedAt:{type:e.DateTime(),isOptional:!1}}}),o=t({name:`FileVersionCreatedEventPayload`,description:`Payload when a file version is created`,fields:{fileId:{type:e.String_unsecure(),isOptional:!1},versionId:{type:e.String_unsecure(),isOptional:!1},version:{type:e.Int_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},createdBy:{type:e.String_unsecure(),isOptional:!1},comment:{type:e.String_unsecure(),isOptional:!0},createdAt:{type:e.DateTime(),isOptional:!1}}}),s=t({name:`AttachmentAttachedEventPayload`,description:`Payload when a file is attached to an entity`,fields:{attachmentId:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},attachmentType:{type:e.String_unsecure(),isOptional:!0},attachedBy:{type:e.String_unsecure(),isOptional:!1},attachedAt:{type:e.DateTime(),isOptional:!1}}}),c=t({name:`AttachmentDetachedEventPayload`,description:`Payload when a file is detached from an entity`,fields:{attachmentId:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},entityType:{type:e.String_unsecure(),isOptional:!1},entityId:{type:e.String_unsecure(),isOptional:!1},detachedBy:{type:e.String_unsecure(),isOptional:!0},detachedAt:{type:e.DateTime(),isOptional:!1}}}),l=t({name:`UploadSessionStartedEventPayload`,description:`Payload when an upload session starts`,fields:{sessionId:{type:e.String_unsecure(),isOptional:!1},fileName:{type:e.String_unsecure(),isOptional:!1},mimeType:{type:e.String_unsecure(),isOptional:!1},totalSize:{type:e.Int_unsecure(),isOptional:!1},ownerId:{type:e.String_unsecure(),isOptional:!1},startedAt:{type:e.DateTime(),isOptional:!1}}}),u=t({name:`UploadSessionCompletedEventPayload`,description:`Payload when an upload session completes`,fields:{sessionId:{type:e.String_unsecure(),isOptional:!1},fileId:{type:e.String_unsecure(),isOptional:!1},fileName:{type:e.String_unsecure(),isOptional:!1},size:{type:e.Int_unsecure(),isOptional:!1},completedAt:{type:e.DateTime(),isOptional:!1}}}),d=n({name:`file.uploaded`,version:1,description:`A file has been uploaded.`,payload:r}),f=n({name:`file.updated`,version:1,description:`A file has been updated.`,payload:i}),p=n({name:`file.deleted`,version:1,description:`A file has been deleted.`,payload:a}),m=n({name:`file.version_created`,version:1,description:`A new file version has been created.`,payload:o}),h=n({name:`attachment.attached`,version:1,description:`A file has been attached to an entity.`,payload:s}),g=n({name:`attachment.detached`,version:1,description:`A file has been detached from an entity.`,payload:c}),_=n({name:`upload.session_started`,version:1,description:`An upload session has started.`,payload:l}),v=n({name:`upload.session_completed`,version:1,description:`An upload session has completed.`,payload:u}),y={FileUploadedEvent:d,FileUpdatedEvent:f,FileDeletedEvent:p,FileVersionCreatedEvent:m,AttachmentAttachedEvent:h,AttachmentDetachedEvent:g,UploadSessionStartedEvent:_,UploadSessionCompletedEvent:v};export{h as AttachmentAttachedEvent,g as AttachmentDetachedEvent,p as FileDeletedEvent,y as FileEvents,f as FileUpdatedEvent,d as FileUploadedEvent,m as FileVersionCreatedEvent,v as UploadSessionCompletedEvent,_ as UploadSessionStartedEvent};
|
package/dist/storage/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import*as e from"node:
|
|
1
|
+
import*as e from"node:fs/promises";import*as t from"node:path";import*as n from"node:crypto";var r=class{provider=`LOCAL`;basePath;baseUrl;constructor(e){this.basePath=e.basePath,this.baseUrl=e.baseUrl}async upload(r){let i=t.join(this.basePath,r.path),a=t.dirname(i);await e.mkdir(a,{recursive:!0});let o=typeof r.content==`string`?Buffer.from(r.content,`base64`):r.content;await e.writeFile(i,o);let s=n.createHash(`sha256`).update(o).digest(`hex`);return{path:r.path,size:o.length,mimeType:r.mimeType,checksum:s,metadata:r.metadata}}async download(n){let r=t.join(this.basePath,n);return e.readFile(r)}async delete(n){let r=t.join(this.basePath,n);await e.unlink(r)}async exists(n){let r=t.join(this.basePath,n);try{return await e.access(r),!0}catch{return!1}}async getMetadata(n){let r=t.join(this.basePath,n);try{return{path:n,size:(await e.stat(r)).size,mimeType:`application/octet-stream`}}catch{return null}}async list(n){let r=n?.prefix?t.join(this.basePath,n.prefix):this.basePath;try{let i=await e.readdir(r,{withFileTypes:!0}),a=[];for(let o of i)if(o.isFile()){let i=n?.prefix?t.join(n.prefix,o.name):o.name,s=await e.stat(t.join(r,o.name));a.push({path:i,size:s.size,mimeType:`application/octet-stream`})}let o=n?.limit||a.length;return{files:a.slice(0,o),hasMore:a.length>o}}catch{return{files:[],hasMore:!1}}}async createPresignedUpload(e){let t=e.expiresIn||3600,n=new Date(Date.now()+t*1e3);return{url:this.baseUrl?`${this.baseUrl}/upload?path=${encodeURIComponent(e.path)}`:`/upload?path=${encodeURIComponent(e.path)}`,fields:{path:e.path,mimeType:e.mimeType},expiresAt:n}}async createPresignedDownload(e){let t=e.expiresIn||3600,n=new Date(Date.now()+t*1e3);return{url:this.baseUrl?`${this.baseUrl}/download/${e.path}`:`/download/${e.path}`,expiresAt:n}}getPublicUrl(e){return this.baseUrl?`${this.baseUrl}/${e}`:null}async copy(n,r){let i=t.join(this.basePath,n),a=t.join(this.basePath,r),o=t.dirname(a);return await e.mkdir(o,{recursive:!0}),await e.copyFile(i,a),{path:r,size:(await e.stat(a)).size,mimeType:`application/octet-stream`}}},i=class{provider=`S3`;config;constructor(e){this.config=e}async upload(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the upload method.`)}async download(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the download method.`)}async delete(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the delete method.`)}async exists(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the exists method.`)}async getMetadata(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the getMetadata method.`)}async list(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the list method.`)}async createPresignedUpload(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the createPresignedUpload method.`)}async createPresignedDownload(e){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the createPresignedDownload method.`)}getPublicUrl(e){let{bucket:t,region:n,endpoint:r}=this.config;return r?`${r}/${t}/${e}`:`https://${t}.s3.${n}.amazonaws.com/${e}`}async copy(e,t){throw Error(`S3 adapter requires @aws-sdk/client-s3. Install it and implement the copy method.`)}},a=class{provider=`LOCAL`;files=new Map;async upload(e){let t=typeof e.content==`string`?Buffer.from(e.content,`base64`):e.content,r=n.createHash(`sha256`).update(t).digest(`hex`),i={path:e.path,size:t.length,mimeType:e.mimeType,checksum:r,metadata:e.metadata};return this.files.set(e.path,{content:t,metadata:i}),i}async download(e){let t=this.files.get(e);if(!t)throw Error(`File not found: ${e}`);return t.content}async delete(e){this.files.delete(e)}async exists(e){return this.files.has(e)}async getMetadata(e){return this.files.get(e)?.metadata||null}async list(e){let t=e?.prefix||``,n=[];for(let[e,r]of this.files)e.startsWith(t)&&n.push(r.metadata);let r=e?.limit||n.length;return{files:n.slice(0,r),hasMore:n.length>r}}async createPresignedUpload(e){let t=new Date(Date.now()+(e.expiresIn||3600)*1e3);return{url:`/upload?path=${encodeURIComponent(e.path)}`,fields:{path:e.path},expiresAt:t}}async createPresignedDownload(e){let t=new Date(Date.now()+(e.expiresIn||3600)*1e3);return{url:`/download/${e.path}`,expiresAt:t}}getPublicUrl(e){return`/files/${e}`}async copy(e,t){let n=this.files.get(e);if(!n)throw Error(`Source file not found: ${e}`);let r={...n.metadata,path:t};return this.files.set(t,{content:n.content,metadata:r}),r}clear(){this.files.clear()}};function o(e){switch(e.provider){case`LOCAL`:if(!e.local)throw Error(`Local storage configuration required`);return new r(e.local);case`S3`:if(!e.s3)throw Error(`S3 storage configuration required`);return new i(e.s3);default:throw Error(`Unsupported storage provider: ${e.provider}`)}}export{a as InMemoryStorageAdapter,r as LocalStorageAdapter,i as S3StorageAdapter,o as createStorageAdapter};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lssm/lib.files",
|
|
3
|
-
"version": "0.0.0-canary-
|
|
3
|
+
"version": "0.0.0-canary-20251207043720",
|
|
4
4
|
"description": "Files, documents and attachments module for ContractSpec applications",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -27,11 +27,11 @@
|
|
|
27
27
|
"typescript": "^5.9.3"
|
|
28
28
|
},
|
|
29
29
|
"exports": {
|
|
30
|
-
".": "./
|
|
31
|
-
"./contracts": "./
|
|
32
|
-
"./entities": "./
|
|
33
|
-
"./events": "./
|
|
34
|
-
"./storage": "./
|
|
30
|
+
".": "./src/index.ts",
|
|
31
|
+
"./contracts": "./src/contracts/index.ts",
|
|
32
|
+
"./entities": "./src/entities/index.ts",
|
|
33
|
+
"./events": "./src/events.ts",
|
|
34
|
+
"./storage": "./src/storage/index.ts",
|
|
35
35
|
"./*": "./*"
|
|
36
36
|
},
|
|
37
37
|
"module": "./dist/index.js",
|
|
@@ -40,6 +40,14 @@
|
|
|
40
40
|
"README.md"
|
|
41
41
|
],
|
|
42
42
|
"publishConfig": {
|
|
43
|
-
"access": "public"
|
|
43
|
+
"access": "public",
|
|
44
|
+
"exports": {
|
|
45
|
+
".": "./dist/index.js",
|
|
46
|
+
"./contracts": "./dist/contracts/index.js",
|
|
47
|
+
"./entities": "./dist/entities/index.js",
|
|
48
|
+
"./events": "./dist/events.js",
|
|
49
|
+
"./storage": "./dist/storage/index.js",
|
|
50
|
+
"./*": "./*"
|
|
51
|
+
}
|
|
44
52
|
}
|
|
45
53
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../ownership.js";const t=[`platform.finance`],n=[`open-banking`,`finance`];[...t],[...n],e.Experimental,[...t],[...n],e.Experimental,[...t],[...n],e.Experimental;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use client";import"./react/feature-render.js";import"./react/form-render.js";import"./react/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"../../presentations.v2.js";import"react";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"react";import"react-hook-form";import"@hookform/resolvers/zod";import"react/jsx-runtime";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use client";import"./feature-render.js";import"./form-render.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./schema/dist/index.js";function e(e){return e}export{e};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"node:crypto";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@pothos/plugin-federation";import"@apollo/subgraph";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./schema/dist/SchemaModel.js";import"./schema/dist/index.js";import{e}from"./events.js";import"./presentations.v2.js";import"./client/react/feature-render.js";import"./client/react/form-render.js";import"./client/index.js";import"./jsonschema.js";import"./server/graphql-pothos.js";import"./server/graphql-schema-export.js";import"./presentations.js";import"./server/provider-mcp.js";import"./server/rest-generic.js";import"./server/rest-elysia.js";import"./server/rest-express.js";import"./server/rest-next-app.js";import"./server/rest-next-pages.js";import"./server/index.js";import{n as t,t as n}from"./spec.js";import"./registry.js";import"./install.js";import"./prompt.js";import"./promptRegistry.js";import"./resources.js";import{e as r,r as i,t as a}from"./ownership.js";import{d as o,l as s,m as c,o as l,p as u,s as d}from"./onboarding-base.js";import"./capabilities/openbanking.js";import"./telemetry/tracker.js";import"./telemetry/index.js";import"./tests/runner.js";import"./tests/index.js";import"./experiments/evaluator.js";import"./integrations/providers/stripe.js";import"./integrations/providers/postmark.js";import"./integrations/providers/qdrant.js";import"./integrations/providers/mistral.js";import"./integrations/providers/elevenlabs.js";import"./integrations/providers/gmail.js";import"./integrations/providers/google-calendar.js";import"./integrations/providers/twilio-sms.js";import"./integrations/providers/gcs-storage.js";import"./integrations/providers/powens.js";import"./integrations/providers/impls/mistral-llm.js";import"./integrations/providers/impls/mistral-embedding.js";import"./integrations/providers/impls/qdrant-vector.js";import"./integrations/providers/impls/gmail-inbound.js";import"./integrations/providers/impls/gmail-outbound.js";import"./integrations/providers/impls/google-calendar.js";import"./integrations/providers/impls/elevenlabs-voice.js";import"./integrations/providers/impls/gcs-storage.js";import"./integrations/providers/impls/stripe-payments.js";import"./integrations/providers/impls/postmark-email.js";import"./integrations/providers/impls/twilio-sms.js";import"./integrations/providers/impls/powens-client.js";import"./integrations/providers/impls/powens-openbanking.js";import"./integrations/providers/impls/provider-factory.js";import"./integrations/secrets/provider.js";import"./integrations/secrets/gcp-secret-manager.js";import"./integrations/secrets/env-secret-provider.js";import"./integrations/secrets/manager.js";import"./integrations/runtime.js";import{i as f,n as p,r as m}from"./integrations/openbanking/models.js";import{t as h}from"./integrations/openbanking/telemetry.js";import{d as g,f as _,p as v}from"./integrations/openbanking/contracts/accounts.js";import{d as y,u as b}from"./integrations/openbanking/contracts/transactions.js";import{d as x,u as S}from"./integrations/openbanking/contracts/balances.js";import"./integrations/openbanking/contracts/index.js";import"./integrations/index.js";import"./knowledge/spaces/product-canon.js";import"./knowledge/spaces/support-faq.js";import"./knowledge/spaces/email-threads.js";import"./knowledge/spaces/uploaded-docs.js";import"./knowledge/spaces/financial-docs.js";import"./knowledge/spaces/financial-overview.js";import"./knowledge/index.js";import{_ as C,g as w,h as T,m as E,p as D}from"./integrations/contracts.js";import{_ as O,g as k,h as A,m as j,v as M}from"./knowledge/contracts.js";import"./regenerator/service.js";import"./regenerator/index.js";import"./workflow/runner.js";import"./workflow/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./registry.js";import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../schema/dist/SchemaModel.js";import{l as t}from"../schema/dist/ScalarTypeEnum.js";import"../schema/dist/index.js";import{n,t as r}from"../spec.js";const i=new e({name:`IntegrationConnectionRecord`,fields:{id:{type:t.ID(),isOptional:!1},tenantId:{type:t.ID(),isOptional:!1},integrationKey:{type:t.NonEmptyString(),isOptional:!1},integrationVersion:{type:t.Int_unsecure(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!1},ownershipMode:{type:t.String_unsecure(),isOptional:!1},externalAccountId:{type:t.String_unsecure(),isOptional:!0},secretProvider:{type:t.String_unsecure(),isOptional:!1},secretRef:{type:t.String_unsecure(),isOptional:!1},status:{type:t.String_unsecure(),isOptional:!1},environment:{type:t.String_unsecure(),isOptional:!0},healthStatus:{type:t.String_unsecure(),isOptional:!0},healthCheckedAt:{type:t.DateTime(),isOptional:!0},healthLatencyMs:{type:t.Float_unsecure(),isOptional:!0},healthErrorCode:{type:t.String_unsecure(),isOptional:!0},healthErrorMessage:{type:t.String_unsecure(),isOptional:!0},usageRequestCount:{type:t.Int_unsecure(),isOptional:!0},usageSuccessCount:{type:t.Int_unsecure(),isOptional:!0},usageErrorCount:{type:t.Int_unsecure(),isOptional:!0},usageLastUsedAt:{type:t.DateTime(),isOptional:!0},usageLastErrorAt:{type:t.DateTime(),isOptional:!0},usageLastErrorCode:{type:t.String_unsecure(),isOptional:!0},createdAt:{type:t.DateTime(),isOptional:!0},updatedAt:{type:t.DateTime(),isOptional:!0}}}),a=new e({name:`CreateIntegrationConnectionInput`,fields:{tenantId:{type:t.ID(),isOptional:!1},integrationKey:{type:t.NonEmptyString(),isOptional:!1},integrationVersion:{type:t.Int_unsecure(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!1},ownershipMode:{type:t.String_unsecure(),isOptional:!1},externalAccountId:{type:t.String_unsecure(),isOptional:!0},secretProvider:{type:t.String_unsecure(),isOptional:!1},secretRef:{type:t.String_unsecure(),isOptional:!1},environment:{type:t.String_unsecure(),isOptional:!0},config:{type:t.JSONObject(),isOptional:!1}}}),o=new e({name:`UpdateIntegrationConnectionInput`,fields:{connectionId:{type:t.ID(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!0},status:{type:t.String_unsecure(),isOptional:!0},ownershipMode:{type:t.String_unsecure(),isOptional:!0},externalAccountId:{type:t.String_unsecure(),isOptional:!0},secretProvider:{type:t.String_unsecure(),isOptional:!0},secretRef:{type:t.String_unsecure(),isOptional:!0},config:{type:t.JSONObject(),isOptional:!0}}}),s=new e({name:`DeleteIntegrationConnectionInput`,fields:{connectionId:{type:t.ID(),isOptional:!1}}}),c=new e({name:`ListIntegrationConnectionsInput`,fields:{tenantId:{type:t.ID(),isOptional:!1},category:{type:t.String_unsecure(),isOptional:!0},status:{type:t.String_unsecure(),isOptional:!0}}}),l=new e({name:`ListIntegrationConnectionsOutput`,fields:{connections:{type:i,isOptional:!1,isArray:!0}}}),u=new e({name:`TestIntegrationConnectionInput`,fields:{connectionId:{type:t.ID(),isOptional:!1}}}),d=new e({name:`TestIntegrationConnectionOutput`,fields:{success:{type:t.Boolean(),isOptional:!1},status:{type:t.String_unsecure(),isOptional:!0},latencyMs:{type:t.Float_unsecure(),isOptional:!0},error:{type:t.String_unsecure(),isOptional:!0},errorCode:{type:t.String_unsecure(),isOptional:!0}}}),f=new e({name:`DeleteIntegrationConnectionOutput`,fields:{success:{type:t.Boolean(),isOptional:!1}}}),p=r({meta:{name:`integrations.connection.create`,version:1,description:`Create a new integration connection for a tenant.`,goal:`Provision a tenant-scoped connection to an external provider.`,context:`Used by Ops or the App Studio to configure external integrations such as Stripe or Qdrant.`,owners:[`platform.integrations`],tags:[`integration`,`connections`],stability:`experimental`},io:{input:a,output:i},policy:{auth:`admin`,policies:[{name:`platform.integration.manage`,version:1}]}}),m=r({meta:{name:`integrations.connection.update`,version:1,description:`Update metadata or credentials for an integration connection.`,goal:`Allow secure rotation of credentials and metadata adjustments.`,context:`Supports rotating API keys, toggling status, or updating labels for tenant integrations.`,owners:[`platform.integrations`],tags:[`integration`,`connections`],stability:`experimental`},io:{input:o,output:i},policy:{auth:`admin`,policies:[{name:`platform.integration.manage`,version:1}]}}),h=r({meta:{name:`integrations.connection.delete`,version:1,description:`Delete an integration connection for a tenant.`,goal:`Safely remove credentials and disable connector usage.`,context:`Ensures connections are de-provisioned when no longer needed or breached.`,owners:[`platform.integrations`],tags:[`integration`,`connections`],stability:`experimental`},io:{input:s,output:f},policy:{auth:`admin`,policies:[{name:`platform.integration.manage`,version:1}]}}),g=n({meta:{name:`integrations.connection.list`,version:1,description:`List integration connections for a tenant.`,goal:`Provide visibility into configured integrations and their status.`,context:`Used by the App Studio and Ops flows to show bindings and health.`,owners:[`platform.integrations`],tags:[`integration`,`connections`],stability:`experimental`},io:{input:c,output:l},policy:{auth:`admin`,policies:[{name:`platform.integration.read`,version:1}]}}),_=r({meta:{name:`integrations.connection.test`,version:1,description:`Run a health check against a configured integration connection.`,goal:`Validate credentials and connectivity for external providers.`,context:`Triggered manually or by background monitors to confirm provider availability.`,owners:[`platform.integrations`],tags:[`integration`,`connections`],stability:`experimental`},io:{input:u,output:d},policy:{auth:`admin`,policies:[{name:`platform.integration.manage`,version:1}]}});export{_,g,h,m,p};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./providers/stripe.js";import"./providers/postmark.js";import"./providers/qdrant.js";import"./providers/mistral.js";import"./providers/elevenlabs.js";import"./providers/gmail.js";import"./providers/google-calendar.js";import"./providers/twilio-sms.js";import"./providers/gcs-storage.js";import"./providers/powens.js";import"./providers/impls/mistral-llm.js";import"./providers/impls/mistral-embedding.js";import"./providers/impls/qdrant-vector.js";import"./providers/impls/gmail-inbound.js";import"./providers/impls/gmail-outbound.js";import"./providers/impls/google-calendar.js";import"./providers/impls/elevenlabs-voice.js";import"./providers/impls/gcs-storage.js";import"./providers/impls/stripe-payments.js";import"./providers/impls/postmark-email.js";import"./providers/impls/twilio-sms.js";import"./providers/impls/powens-client.js";import"./providers/impls/powens-openbanking.js";import"./providers/impls/provider-factory.js";import"./secrets/provider.js";import"./secrets/gcp-secret-manager.js";import"./secrets/env-secret-provider.js";import"./secrets/manager.js";import"./runtime.js";import{i as e,n as t,r as n}from"./openbanking/models.js";import{t as r}from"./openbanking/telemetry.js";import{d as i,f as a,p as o}from"./openbanking/contracts/accounts.js";import{d as s,u as c}from"./openbanking/contracts/transactions.js";import{d as l,u}from"./openbanking/contracts/balances.js";import"./openbanking/contracts/index.js";import"./providers/index.js";import"./secrets/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../../../schema/dist/SchemaModel.js";import{l as t}from"../../../schema/dist/ScalarTypeEnum.js";import"../../../schema/dist/index.js";import{n,t as r}from"../../../spec.js";import{n as i}from"../models.js";import{t as a}from"../telemetry.js";const o=new e({name:`OpenBankingListAccountsInput`,description:`Parameters for listing bank accounts through the open banking provider.`,fields:{tenantId:{type:t.ID(),isOptional:!1},userId:{type:t.ID(),isOptional:!1},connectionId:{type:t.ID(),isOptional:!0},includeBalances:{type:t.Boolean(),isOptional:!0},institutionId:{type:t.String_unsecure(),isOptional:!0},cursor:{type:t.String_unsecure(),isOptional:!0},pageSize:{type:t.Int_unsecure(),isOptional:!0}}}),s=new e({name:`OpenBankingListAccountsOutput`,description:`Paginated list of bank accounts available to the tenant and user.`,fields:{accounts:{type:i,isOptional:!1,isArray:!0},nextCursor:{type:t.String_unsecure(),isOptional:!0},hasMore:{type:t.Boolean(),isOptional:!0}}}),c=new e({name:`OpenBankingGetAccountInput`,description:`Parameters for retrieving a specific bank account.`,fields:{tenantId:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},includeBalances:{type:t.Boolean(),isOptional:!0},includeLatestTransactions:{type:t.Boolean(),isOptional:!0}}}),l=new e({name:`OpenBankingSyncAccountsInput`,description:`Command payload to trigger an account synchronisation against the open banking provider.`,fields:{tenantId:{type:t.ID(),isOptional:!1},userId:{type:t.ID(),isOptional:!0},connectionId:{type:t.ID(),isOptional:!1},accountIds:{type:t.ID(),isArray:!0,isOptional:!0},forceFullRefresh:{type:t.Boolean(),isOptional:!0},triggerWorkflows:{type:t.Boolean(),isOptional:!0}}}),u=new e({name:`OpenBankingSyncAccountsOutput`,description:`Result of a bank account synchronisation run.`,fields:{synced:{type:t.Int_unsecure(),isOptional:!1},failed:{type:t.Int_unsecure(),isOptional:!1},errors:{type:t.String_unsecure(),isArray:!0,isOptional:!0},nextSyncSuggestedAt:{type:t.DateTime(),isOptional:!0}}}),d=n({meta:{name:`openbanking.accounts.list`,version:1,description:`List bank accounts available to a tenant/user via Powens Open Banking.`,goal:`Provide downstream workflows with the set of accounts accessible via the configured open banking connection.`,context:`Used by Pocket Family Office dashboards and sync workflows to enumerate bank accounts prior to syncing balances or transactions.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`accounts`],stability:`experimental`},io:{input:o,output:s},policy:{auth:`user`}}),f=n({meta:{name:`openbanking.accounts.get`,version:1,description:`Retrieve the canonical bank account record for the given account identifier.`,goal:`Allow user-facing experiences and automations to display up-to-date account metadata.`,context:`Invoked by UI surfaces and workflow automation steps that require detailed metadata for a specific bank account.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`accounts`],stability:`experimental`},io:{input:c,output:i},policy:{auth:`user`}}),p=r({meta:{name:`openbanking.accounts.sync`,version:1,description:`Initiate a synchronisation run to refresh bank account metadata from Powens.`,goal:`Keep canonical bank account records aligned with the external open banking provider.`,context:`Triggered by scheduled workflows or manual operator actions to reconcile account metadata prior to transaction/balance syncs.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`accounts`],stability:`experimental`},io:{input:l,output:u},policy:{auth:`admin`},telemetry:{success:{event:{name:a.accountsSynced},properties:({input:e,output:t})=>{let n=e,r=t;return{tenantId:n?.tenantId,connectionId:n?.connectionId,synced:r?.synced,failed:r?.failed}}},failure:{event:{name:a.accountsSyncFailed},properties:({input:e,error:t})=>{let n=e;return{tenantId:n?.tenantId,connectionId:n?.connectionId,error:t instanceof Error?t.message:String(t??`unknown`)}}}}});export{d,f,p};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../../../schema/dist/SchemaModel.js";import{l as t}from"../../../schema/dist/ScalarTypeEnum.js";import"../../../schema/dist/index.js";import{n,t as r}from"../../../spec.js";import{i}from"../models.js";import{t as a}from"../telemetry.js";const o=new e({name:`OpenBankingGetBalancesInput`,description:`Parameters for retrieving bank account balances from the canonical ledger.`,fields:{tenantId:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},balanceTypes:{type:t.String_unsecure(),isArray:!0,isOptional:!0}}}),s=new e({name:`OpenBankingGetBalancesOutput`,description:`Canonical balances for a bank account.`,fields:{balances:{type:i,isOptional:!1,isArray:!0},asOf:{type:t.DateTime(),isOptional:!0}}}),c=new e({name:`OpenBankingRefreshBalancesInput`,description:`Command payload to refresh balances for a bank account via the open banking provider.`,fields:{tenantId:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},connectionId:{type:t.ID(),isOptional:!0},balanceTypes:{type:t.String_unsecure(),isArray:!0,isOptional:!0},forceRefresh:{type:t.Boolean(),isOptional:!0}}}),l=new e({name:`OpenBankingRefreshBalancesOutput`,description:`Result of a balance refresh against the open banking provider.`,fields:{balances:{type:i,isOptional:!1,isArray:!0},refreshedAt:{type:t.DateTime(),isOptional:!1},errors:{type:t.String_unsecure(),isArray:!0,isOptional:!0}}}),u=n({meta:{name:`openbanking.balances.get`,version:1,description:`Retrieve the latest cached balances for a bank account.`,goal:`Expose current and available balances required by dashboards and analytics.`,context:`Used by Pocket Family Office UI surfaces and automation steps that require balance totals prior to generating summaries.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`balances`],stability:`experimental`},io:{input:o,output:s},policy:{auth:`user`}}),d=r({meta:{name:`openbanking.balances.refresh`,version:1,description:`Refresh balances for a bank account via the configured open banking provider.`,goal:`Ensure canonical balance records reflect the latest values from Powens.`,context:`Triggered by scheduled workflows before generating summaries or forecasting cashflow.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`balances`],stability:`experimental`},io:{input:c,output:l},policy:{auth:`admin`},telemetry:{success:{event:{name:a.balancesRefreshed},properties:({input:e,output:t})=>{let n=e,r=t;return{tenantId:n?.tenantId,accountId:n?.accountId,refreshedAt:r?.refreshedAt,balanceCount:Array.isArray(r?.balances)?r?.balances.length:void 0}}},failure:{event:{name:a.balancesRefreshFailed},properties:({input:e,error:t})=>{let n=e;return{tenantId:n?.tenantId,accountId:n?.accountId,error:t instanceof Error?t.message:String(t??`unknown`)}}}}});export{d,u};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{d as e,f as t,p as n}from"./accounts.js";import{d as r,u as i}from"./transactions.js";import{d as a,u as o}from"./balances.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../../../schema/dist/SchemaModel.js";import{l as t}from"../../../schema/dist/ScalarTypeEnum.js";import"../../../schema/dist/index.js";import{n,t as r}from"../../../spec.js";import{r as i}from"../models.js";import{t as a}from"../telemetry.js";const o=new e({name:`OpenBankingListTransactionsInput`,description:`Parameters for listing bank transactions from the canonical ledger.`,fields:{tenantId:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},from:{type:t.DateTime(),isOptional:!0},to:{type:t.DateTime(),isOptional:!0},cursor:{type:t.String_unsecure(),isOptional:!0},pageSize:{type:t.Int_unsecure(),isOptional:!0},direction:{type:t.String_unsecure(),isOptional:!0},minimumAmount:{type:t.Float_unsecure(),isOptional:!0},maximumAmount:{type:t.Float_unsecure(),isOptional:!0},category:{type:t.String_unsecure(),isOptional:!0}}}),s=new e({name:`OpenBankingListTransactionsOutput`,description:`Paginated list of transactions for a bank account.`,fields:{transactions:{type:i,isOptional:!1,isArray:!0},nextCursor:{type:t.String_unsecure(),isOptional:!0},hasMore:{type:t.Boolean(),isOptional:!0}}}),c=new e({name:`OpenBankingSyncTransactionsInput`,description:`Command payload to synchronise transactions from the open banking provider into the canonical ledger.`,fields:{tenantId:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},from:{type:t.DateTime(),isOptional:!0},to:{type:t.DateTime(),isOptional:!0},connectionId:{type:t.ID(),isOptional:!0},includePending:{type:t.Boolean(),isOptional:!0},backfillDays:{type:t.Int_unsecure(),isOptional:!0}}}),l=new e({name:`OpenBankingSyncTransactionsOutput`,description:`Result of a transaction synchronisation run.`,fields:{synced:{type:t.Int_unsecure(),isOptional:!1},failed:{type:t.Int_unsecure(),isOptional:!1},earliestSyncedAt:{type:t.DateTime(),isOptional:!0},latestSyncedAt:{type:t.DateTime(),isOptional:!0},nextSinceToken:{type:t.String_unsecure(),isOptional:!0},errors:{type:t.String_unsecure(),isArray:!0,isOptional:!0}}}),u=n({meta:{name:`openbanking.transactions.list`,version:1,description:`List bank transactions that have been normalised into the canonical ledger.`,goal:`Allow downstream analytics and UI surfaces to page through canonical bank transactions.`,context:`Used by Pocket Family Office dashboards, reconciliation workflows, and analytics data views.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`transactions`],stability:`experimental`},io:{input:o,output:s},policy:{auth:`user`}}),d=r({meta:{name:`openbanking.transactions.sync`,version:1,description:`Synchronise transactions for a bank account by calling the configured open banking provider.`,goal:`Ensure the canonical transaction ledger stays aligned with the external provider.`,context:`Triggered by scheduled workflows or on-demand actions when activity is expected on an account.`,owners:[`platform.finance`],tags:[`open-banking`,`powens`,`transactions`],stability:`experimental`},io:{input:c,output:l},policy:{auth:`admin`},telemetry:{success:{event:{name:a.transactionsSynced},properties:({input:e,output:t})=>{let n=e,r=t;return{tenantId:n?.tenantId,accountId:n?.accountId,synced:r?.synced,failed:r?.failed,earliestSyncedAt:r?.earliestSyncedAt,latestSyncedAt:r?.latestSyncedAt}}},failure:{event:{name:a.transactionsSyncFailed},properties:({input:e,error:t})=>{let n=e;return{tenantId:n?.tenantId,accountId:n?.accountId,error:t instanceof Error?t.message:String(t??`unknown`)}}}}});export{d,u};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../../schema/dist/SchemaModel.js";import{l as t}from"../../schema/dist/ScalarTypeEnum.js";import"../../schema/dist/index.js";const n=new e({name:`BankAccountRecord`,description:`Canonical representation of a bank account synced from an open banking provider.`,fields:{id:{type:t.ID(),isOptional:!1},tenantId:{type:t.ID(),isOptional:!1},userId:{type:t.ID(),isOptional:!1},connectionId:{type:t.ID(),isOptional:!1},externalId:{type:t.NonEmptyString(),isOptional:!1},institutionId:{type:t.NonEmptyString(),isOptional:!1},institutionName:{type:t.NonEmptyString(),isOptional:!1},institutionLogoUrl:{type:t.URL(),isOptional:!0},iban:{type:t.String_unsecure(),isOptional:!0},bic:{type:t.String_unsecure(),isOptional:!0},accountType:{type:t.NonEmptyString(),isOptional:!1},currency:{type:t.Currency(),isOptional:!1},displayName:{type:t.NonEmptyString(),isOptional:!1},accountNumberMasked:{type:t.String_unsecure(),isOptional:!0},productCode:{type:t.String_unsecure(),isOptional:!0},balance:{type:t.Float_unsecure(),isOptional:!0},availableBalance:{type:t.Float_unsecure(),isOptional:!0},lastSyncedAt:{type:t.DateTime(),isOptional:!1},createdAt:{type:t.DateTime(),isOptional:!1},updatedAt:{type:t.DateTime(),isOptional:!1},metadata:{type:t.JSONObject(),isOptional:!0}}}),r=new e({name:`BankTransactionRecord`,description:`Canonical transaction entry mapped from Powens into the open banking ledger.`,fields:{id:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},tenantId:{type:t.ID(),isOptional:!1},connectionId:{type:t.ID(),isOptional:!1},externalId:{type:t.NonEmptyString(),isOptional:!1},amount:{type:t.Float_unsecure(),isOptional:!1},currency:{type:t.Currency(),isOptional:!1},date:{type:t.DateTime(),isOptional:!1},bookingDate:{type:t.DateTime(),isOptional:!0},valueDate:{type:t.DateTime(),isOptional:!0},description:{type:t.String_unsecure(),isOptional:!0},counterpartyName:{type:t.String_unsecure(),isOptional:!0},counterpartyAccount:{type:t.String_unsecure(),isOptional:!0},merchantCategoryCode:{type:t.String_unsecure(),isOptional:!0},rawCategory:{type:t.String_unsecure(),isOptional:!0},standardizedCategory:{type:t.String_unsecure(),isOptional:!0},transactionType:{type:t.NonEmptyString(),isOptional:!1},status:{type:t.NonEmptyString(),isOptional:!1},runningBalance:{type:t.Float_unsecure(),isOptional:!0},metadata:{type:t.JSONObject(),isOptional:!0},createdAt:{type:t.DateTime(),isOptional:!1},updatedAt:{type:t.DateTime(),isOptional:!1}}}),i=new e({name:`AccountBalanceRecord`,description:`Canonical balance snapshot computed from Powens balance payloads.`,fields:{id:{type:t.ID(),isOptional:!1},accountId:{type:t.ID(),isOptional:!1},tenantId:{type:t.ID(),isOptional:!1},connectionId:{type:t.ID(),isOptional:!1},balanceType:{type:t.NonEmptyString(),isOptional:!1},currentBalance:{type:t.Float_unsecure(),isOptional:!1},availableBalance:{type:t.Float_unsecure(),isOptional:!0},currency:{type:t.Currency(),isOptional:!1},lastUpdatedAt:{type:t.DateTime(),isOptional:!1},createdAt:{type:t.DateTime(),isOptional:!1},metadata:{type:t.JSONObject(),isOptional:!0}}});export{i,n,r};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
const e={accountsSynced:`openbanking.accounts.synced`,accountsSyncFailed:`openbanking.accounts.sync_failed`,transactionsSynced:`openbanking.transactions.synced`,transactionsSyncFailed:`openbanking.transactions.sync_failed`,balancesRefreshed:`openbanking.balances.refreshed`,balancesRefreshFailed:`openbanking.balances.refresh_failed`,overviewGenerated:`openbanking.overview.generated`};export{e as t};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@elevenlabs/elevenlabs-js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@google-cloud/storage";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"googleapis";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"googleapis";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"googleapis";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./mistral-llm.js";import"./mistral-embedding.js";import"./qdrant-vector.js";import"./gmail-inbound.js";import"./gmail-outbound.js";import"./google-calendar.js";import"./elevenlabs-voice.js";import"./gcs-storage.js";import"./stripe-payments.js";import"./postmark-email.js";import"./twilio-sms.js";import"./powens-client.js";import"./powens-openbanking.js";import"./provider-factory.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@mistralai/mistralai";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@mistralai/mistralai";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"postmark";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"node:url";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./powens-client.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./mistral-llm.js";import"./mistral-embedding.js";import"./qdrant-vector.js";import"./elevenlabs-voice.js";import"./gcs-storage.js";import"./stripe-payments.js";import"./postmark-email.js";import"./twilio-sms.js";import"./powens-openbanking.js";import"node:buffer";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"@qdrant/js-client-rest";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"stripe";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"twilio";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./stripe.js";import"./postmark.js";import"./qdrant.js";import"./mistral.js";import"./elevenlabs.js";import"./gmail.js";import"./google-calendar.js";import"./twilio-sms.js";import"./gcs-storage.js";import"./powens.js";import"./impls/mistral-llm.js";import"./impls/mistral-embedding.js";import"./impls/qdrant-vector.js";import"./impls/gmail-inbound.js";import"./impls/gmail-outbound.js";import"./impls/google-calendar.js";import"./impls/elevenlabs-voice.js";import"./impls/gcs-storage.js";import"./impls/stripe-payments.js";import"./impls/postmark-email.js";import"./impls/twilio-sms.js";import"./impls/powens-client.js";import"./impls/powens-openbanking.js";import"./impls/provider-factory.js";import"./impls/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Experimental;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Stable;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Experimental;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Experimental;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Stable;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Stable;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"node:perf_hooks";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./provider.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./provider.js";import"@google-cloud/secret-manager";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./provider.js";import"./gcp-secret-manager.js";import"./env-secret-provider.js";import"./manager.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./provider.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"node:buffer";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"../schema/dist/SchemaModel.js";import{l as t}from"../schema/dist/ScalarTypeEnum.js";import"../schema/dist/index.js";import{n,t as r}from"../spec.js";const i=new e({name:`KnowledgeSyncSchedule`,fields:{enabled:{type:t.Boolean(),isOptional:!1},cron:{type:t.String_unsecure(),isOptional:!0},intervalMs:{type:t.Int_unsecure(),isOptional:!0}}}),a=new e({name:`KnowledgeSourceRecord`,fields:{id:{type:t.ID(),isOptional:!1},tenantId:{type:t.ID(),isOptional:!1},spaceKey:{type:t.NonEmptyString(),isOptional:!1},spaceVersion:{type:t.Int_unsecure(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!1},sourceType:{type:t.String_unsecure(),isOptional:!1},syncSchedule:{type:i,isOptional:!0},lastSyncStatus:{type:t.String_unsecure(),isOptional:!0},lastSyncAt:{type:t.DateTime(),isOptional:!0},itemsProcessed:{type:t.Int_unsecure(),isOptional:!0},createdAt:{type:t.DateTime(),isOptional:!0},updatedAt:{type:t.DateTime(),isOptional:!0}}}),o=new e({name:`CreateKnowledgeSourceInput`,fields:{tenantId:{type:t.ID(),isOptional:!1},spaceKey:{type:t.NonEmptyString(),isOptional:!1},spaceVersion:{type:t.Int_unsecure(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!1},sourceType:{type:t.NonEmptyString(),isOptional:!1},config:{type:t.JSONObject(),isOptional:!1},syncSchedule:{type:i,isOptional:!0}}}),s=new e({name:`UpdateKnowledgeSourceInput`,fields:{sourceId:{type:t.ID(),isOptional:!1},label:{type:t.String_unsecure(),isOptional:!0},config:{type:t.JSONObject(),isOptional:!0},syncSchedule:{type:i,isOptional:!0}}}),c=new e({name:`DeleteKnowledgeSourceInput`,fields:{sourceId:{type:t.ID(),isOptional:!1}}}),l=new e({name:`DeleteKnowledgeSourceOutput`,fields:{success:{type:t.Boolean(),isOptional:!1}}}),u=new e({name:`ListKnowledgeSourcesInput`,fields:{tenantId:{type:t.ID(),isOptional:!1},spaceKey:{type:t.NonEmptyString(),isOptional:!0}}}),d=new e({name:`ListKnowledgeSourcesOutput`,fields:{sources:{type:a,isOptional:!1,isArray:!0}}}),f=new e({name:`TriggerKnowledgeSyncInput`,fields:{sourceId:{type:t.ID(),isOptional:!1}}}),p=new e({name:`TriggerKnowledgeSyncOutput`,fields:{success:{type:t.Boolean(),isOptional:!1},itemsProcessed:{type:t.Int_unsecure(),isOptional:!0},error:{type:t.String_unsecure(),isOptional:!0}}}),m=r({meta:{name:`knowledge.source.create`,version:1,description:`Create a knowledge source binding for a tenant.`,goal:`Onboard a new knowledge ingestion source such as Notion or uploads.`,context:`Used by Ops and App Studio to configure knowledge ingestion per tenant and space.`,owners:[`platform.knowledge`],tags:[`knowledge`,`sources`],stability:`experimental`},io:{input:o,output:a},policy:{auth:`admin`,policies:[{name:`platform.knowledge.manage`,version:1}]}}),h=r({meta:{name:`knowledge.source.update`,version:1,description:`Update metadata or configuration for a knowledge source.`,goal:`Allow rotation of credentials, sync schedules, and labels.`,context:`Supports editing how a tenant ingests knowledge (e.g., toggling sync cadence).`,owners:[`platform.knowledge`],tags:[`knowledge`,`sources`],stability:`experimental`},io:{input:s,output:a},policy:{auth:`admin`,policies:[{name:`platform.knowledge.manage`,version:1}]}}),g=r({meta:{name:`knowledge.source.delete`,version:1,description:`Delete a knowledge source binding for a tenant.`,goal:`Remove obsolete or compromised knowledge ingestion paths.`,context:`Ensures ephemeral or external sources can be removed cleanly without leaving residual bindings.`,owners:[`platform.knowledge`],tags:[`knowledge`,`sources`],stability:`experimental`},io:{input:c,output:l},policy:{auth:`admin`,policies:[{name:`platform.knowledge.manage`,version:1}]}}),_=n({meta:{name:`knowledge.source.list`,version:1,description:`List knowledge sources configured for a tenant.`,goal:`Provide visibility into knowledge ingest configuration and schedules.`,context:`Used by App Studio and Ops flows to surface knowledge sources and their health.`,owners:[`platform.knowledge`],tags:[`knowledge`,`sources`],stability:`experimental`},io:{input:u,output:d},policy:{auth:`admin`,policies:[{name:`platform.knowledge.read`,version:1}]}}),v=r({meta:{name:`knowledge.source.triggerSync`,version:1,description:`Trigger an immediate sync for a knowledge source.`,goal:`Support manual or automated sync retries for knowledge ingestion.`,context:`Invoked by Ops tooling or monitors when knowledge content must be refreshed or reprocessed.`,owners:[`platform.knowledge`],tags:[`knowledge`,`sources`],stability:`experimental`},io:{input:f,output:p},policy:{auth:`admin`,policies:[{name:`platform.knowledge.manage`,version:1}]}});export{_,g,h,m,v};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./spaces/product-canon.js";import"./spaces/support-faq.js";import"./spaces/email-threads.js";import"./spaces/uploaded-docs.js";import"./spaces/financial-docs.js";import"./spaces/financial-overview.js";import"./spaces/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Experimental;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./product-canon.js";import"./support-faq.js";import"./email-threads.js";import"./uploaded-docs.js";import"./financial-docs.js";import"./financial-overview.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Stable;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{e}from"../../ownership.js";e.Beta;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"./schema/dist/SchemaModel.js";import{l as t}from"./schema/dist/ScalarTypeEnum.js";import"./schema/dist/index.js";import{n,t as r}from"./spec.js";import{e as i,t as a}from"./ownership.js";const o=new e({name:`SaveOnboardingDraftInput`,description:`Input for saving onboarding draft`,fields:{data:{type:t.JSON(),isOptional:!1}}}),s=new e({name:`SaveOnboardingDraftOutput`,description:`Output for saving onboarding draft`,fields:{id:{type:t.ID(),isOptional:!1},organizationId:{type:t.ID(),isOptional:!1}}});r({meta:{name:`base.onboarding.saveDraft`,version:1,stability:i.Beta,owners:[a.PlatformSigil],tags:[`onboarding`,`draft`],description:`Save or update onboarding draft for active organization`,goal:`Persist onboarding progress incrementally for resumption and safety`,context:`Auto-saves every few seconds during onboarding; enables users to leave and resume`},io:{input:o,output:s},policy:{auth:`user`,escalate:null},transport:{gql:{field:`saveOnboardingDraft`},rest:{method:`POST`}}});const c=new e({name:`GetOnboardingDraftOutput`,description:`Onboarding draft payload`,fields:{id:{type:t.ID(),isOptional:!0},organizationId:{type:t.ID(),isOptional:!0},data:{type:t.JSON(),isOptional:!0},createdAt:{type:t.DateTime(),isOptional:!0},updatedAt:{type:t.DateTime(),isOptional:!0}}});n({meta:{name:`base.onboarding.getDraft`,version:1,stability:i.Beta,owners:[a.PlatformSigil],tags:[`onboarding`,`draft`],description:`Get onboarding draft for active organization`,goal:`Retrieve saved onboarding progress`,context:`Called on mount to restore in-progress onboarding`},io:{input:null,output:c},policy:{auth:`user`,escalate:null},transport:{gql:{field:`getOnboardingDraft`},rest:{method:`GET`}}});const l=new e({name:`DeleteOnboardingDraftOutput`,description:`Result of delete operation`,fields:{ok:{type:t.Boolean(),isOptional:!1}}});r({meta:{name:`base.onboarding.deleteDraft`,version:1,stability:i.Beta,owners:[a.PlatformSigil],tags:[`onboarding`,`draft`],description:`Delete onboarding draft for active organization`,goal:`Clear draft after completion or if user wants to restart`,context:`Called after successful onboarding or explicit user reset`},io:{input:null,output:l},policy:{auth:`user`,escalate:null},transport:{gql:{field:`deleteOnboardingDraft`},rest:{method:`POST`}}});const u=new e({name:`CompleteOnboardingBaseInput`,description:`Input for completing onboarding`,fields:{data:{type:t.JSON(),isOptional:!1}}}),d=new e({name:`CompleteOnboardingBaseOutput`,description:`Result of onboarding completion`,fields:{success:{type:t.Boolean(),isOptional:!1},userId:{type:t.ID(),isOptional:!0},organizationId:{type:t.ID(),isOptional:!0}}});r({meta:{name:`base.onboarding.complete`,version:1,stability:i.Beta,owners:[a.PlatformSigil],tags:[`onboarding`],description:`Complete onboarding and finalize user/organization setup`,goal:`Transition from draft to active profile`,context:`Validates all required fields, creates/updates entities, marks onboarding complete`},io:{input:u,output:d},policy:{auth:`user`,escalate:null},transport:{gql:{field:`completeOnboarding`},rest:{method:`POST`}}});export{l as d,c as l,d as m,o,u as p,s};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
const e={Idea:`idea`,InCreation:`in_creation`,Experimental:`experimental`,Beta:`beta`,Stable:`stable`,Deprecated:`deprecated`},t={ProductColiving:`product.coliving`,ProductStrit:`product.strit`,ProductArtisanos:`product.artisanos`,PlatformSigil:`platform.sigil`,PlatformMarketplace:`platform.marketplace`,PlatformContent:`platform.content`,PlatformFeatureFlags:`platform.featureflags`},n={Spots:`spots`,Collectivity:`collectivity`,Marketplace:`marketplace`,Sellers:`sellers`,Auth:`auth`,Login:`login`,Signup:`signup`,Guide:`guide`,Docs:`docs`,I18n:`i18n`,AtomicPages:`atomic:pages`,Incident:`incident`,Hygiene:`hygiene`,WeeklyPulse:`weekly_pulse`,WebAuth:`webauth`};export{e,n as r,t};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"react";import"turndown";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./service.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"node:timers/promises";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./events.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";import"graphql";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";import{GraphQLScalarType as t}from"graphql";var n=class extends t{zodSchema;jsonSchemaDef;constructor(e){super(e),this.zodSchema=e.zod,this.jsonSchemaDef=e.jsonSchema}getZod(){return this.zodSchema}getPothos(){return this}getJson(){return typeof this.jsonSchemaDef==`function`?this.jsonSchemaDef():this.jsonSchemaDef}getJsonSchemaDef(){return this.jsonSchemaDef}getJsonSchema(){let e=t=>{let n=typeof t==`function`?t():t;if(Array.isArray(n))return n.map(t=>e(t));if(n&&typeof n==`object`){let t={};for(let[r,i]of Object.entries(n))t[r]=e(i);return t}return n};return e(this.getJson())}};export{n};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{n as e}from"./FieldType.js";import{z as t}from"zod";import{Kind as n}from"graphql";const r=/^[A-Za-z]{2}(?:-[A-Za-z0-9]{2,8})*$/,i=/^(?:UTC|[A-Za-z_]+\/[A-Za-z_]+)$/,a=/^[+]?\d[\d\s().-]{3,}$/,o=/^[A-Z]{3}$/,s=/^[A-Z]{2}$/,c=-180,l={String_unsecure:()=>new e({name:`String_unsecure`,description:`Unvalidated string scalar`,zod:t.string(),parseValue:e=>t.string().parse(e),serialize:e=>String(e),parseLiteral:e=>{if(e.kind!==n.STRING)throw TypeError(`Invalid literal`);return e.value},jsonSchema:{type:`string`}}),Int_unsecure:()=>new e({name:`Int_unsecure`,description:`Unvalidated integer scalar`,zod:t.number().int(),parseValue:e=>{let n=typeof e==`number`?e:Number(e);return t.number().int().parse(n)},serialize:e=>Math.trunc(typeof e==`number`?e:Number(e)),parseLiteral:e=>{if(e.kind!==n.INT)throw TypeError(`Invalid literal`);return Number(e.value)},jsonSchema:{type:`integer`}}),Float_unsecure:()=>new e({name:`Float_unsecure`,description:`Unvalidated float scalar`,zod:t.number(),parseValue:e=>{let n=typeof e==`number`?e:Number(e);return t.number().parse(n)},serialize:e=>Number(e),parseLiteral:e=>{if(e.kind!==n.FLOAT&&e.kind!==n.INT)throw TypeError(`Invalid literal`);return Number(e.value)},jsonSchema:{type:`number`}}),Boolean:()=>new e({name:`Boolean`,description:`Unvalidated boolean scalar`,zod:t.boolean(),parseValue:e=>t.coerce.boolean().parse(e),serialize:e=>!!e,parseLiteral:e=>{if(e.kind!==n.BOOLEAN)throw TypeError(`Invalid literal`);return e.value},jsonSchema:{type:`boolean`}}),ID:()=>new e({name:`ID`,description:`Unvalidated id scalar`,zod:t.string(),parseValue:e=>t.string().parse(e),serialize:e=>String(e),parseLiteral:e=>{if(e.kind!==n.STRING)throw TypeError(`Invalid literal`);return e.value},jsonSchema:{type:`string`}}),JSON:()=>new e({name:`JSON`,zod:t.any(),parseValue:e=>e,serialize:e=>e,jsonSchema:{}}),JSONObject:()=>new e({name:`JSONObject`,zod:t.record(t.string(),t.any()),parseValue:e=>t.record(t.string(),t.any()).parse(e),serialize:e=>e??{},jsonSchema:{type:`object`}}),Date:()=>new e({name:`Date`,zod:t.date(),parseValue:e=>e instanceof Date?e:new Date(String(e)),serialize:e=>e instanceof Date?e.toISOString().split(`T`)[0]:String(e),jsonSchema:{type:`string`,format:`date`}}),DateTime:()=>new e({name:`DateTime`,zod:t.date(),parseValue:e=>e instanceof Date?e:new Date(String(e)),serialize:e=>e instanceof Date?e.toISOString():String(e),jsonSchema:{type:`string`,format:`date-time`}}),Time:()=>new e({name:`Time`,zod:t.string().regex(/^\d{2}:\d{2}(:\d{2})?$/),parseValue:e=>t.string().regex(/^\d{2}:\d{2}(:\d{2})?$/).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:`^\\d{2}:\\d{2}(:\\d{2})?$`}}),EmailAddress:()=>new e({name:`EmailAddress`,zod:t.string().email(),parseValue:e=>t.string().email().parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,format:`email`}}),URL:()=>new e({name:`URL`,zod:t.string().url(),parseValue:e=>t.string().url().parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,format:`uri`}}),PhoneNumber:()=>new e({name:`PhoneNumber`,zod:t.string().regex(a),parseValue:e=>t.string().regex(a).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:a.source}}),NonEmptyString:()=>new e({name:`NonEmptyString`,zod:t.string().min(1),parseValue:e=>t.string().min(1).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,minLength:1}}),Locale:()=>new e({name:`Locale`,zod:t.string().regex(r),parseValue:e=>t.string().regex(r).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:r.source}}),TimeZone:()=>new e({name:`TimeZone`,zod:t.string().regex(i),parseValue:e=>t.string().regex(i).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:i.source}}),Latitude:()=>new e({name:`Latitude`,zod:t.number().min(-90).max(90),parseValue:e=>t.coerce.number().min(-90).max(90).parse(e),serialize:e=>Number(e),jsonSchema:{type:`number`,minimum:-90,maximum:90}}),Longitude:()=>new e({name:`Longitude`,zod:t.number().min(c).max(180),parseValue:e=>t.coerce.number().min(c).max(180).parse(e),serialize:e=>Number(e),jsonSchema:{type:`number`,minimum:c,maximum:180}}),Currency:()=>new e({name:`Currency`,zod:t.string().regex(o),parseValue:e=>t.string().regex(o).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:o.source}}),CountryCode:()=>new e({name:`CountryCode`,zod:t.string().regex(s),parseValue:e=>t.string().regex(s).parse(e),serialize:e=>String(e),jsonSchema:{type:`string`,pattern:s.source}})};export{l};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./EnumType.js";import"./FieldType.js";import{z as e}from"zod";var t=class{constructor(e){this.config=e}getZod(){let t=Object.entries(this.config.fields).reduce((t,[n,r])=>{let i=r.type.getZod(),a=r.isArray?e.array(i):i;return t[n]=r.isOptional?a.optional():a,t},{});return e.object(t)}getPothosInput(){return this.config.name}};export{t};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./defineEntity.js";import"./types.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{z as e}from"zod";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./EnumType.js";import"./FieldType.js";import"./SchemaModel.js";import"./ScalarTypeEnum.js";import"./entity/defineEntity.js";import"./entity/index.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"../jsonschema.js";import"@pothos/plugin-prisma";import"@pothos/plugin-complexity";import"@pothos/plugin-relay";import"@pothos/plugin-dataloader";import"@pothos/plugin-tracing";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use server";import"../graphql-federation/dist/index.js";import"graphql";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./graphql-pothos.js";import"./graphql-schema-export.js";import"./provider-mcp.js";import"./rest-generic.js";import"./rest-elysia.js";import"./rest-express.js";import"./rest-next-app.js";import"./rest-next-pages.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"../presentations.v2.js";import"../jsonschema.js";import"../presentations.js";import"zod";import"@modelcontextprotocol/sdk/server/mcp.js";import"zod-to-json-schema";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rest-generic.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rest-generic.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"../jsonschema.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rest-generic.js";
|