box-node-sdk 3.8.0 → 3.8.2
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 +89 -69
- package/config/package.schema.json +42 -42
- package/lib/api-request-manager.d.ts +0 -2
- package/lib/api-request-manager.js.map +1 -1
- package/lib/api-request.d.ts +0 -3
- package/lib/api-request.js.map +1 -1
- package/lib/box-client.d.ts +7 -7
- package/lib/box-client.js +6 -3
- package/lib/box-client.js.map +1 -1
- package/lib/box-node-sdk.d.ts +1 -3
- package/lib/box-node-sdk.js +26 -10
- package/lib/box-node-sdk.js.map +1 -1
- package/lib/chunked-uploader.d.ts +0 -5
- package/lib/chunked-uploader.js.map +1 -1
- package/lib/enterprise-event-stream.d.ts +0 -1
- package/lib/enterprise-event-stream.js +3 -3
- package/lib/enterprise-event-stream.js.map +1 -1
- package/lib/event-stream.d.ts +0 -2
- package/lib/event-stream.js.map +1 -1
- package/lib/managers/ai.generated.js.map +1 -1
- package/lib/managers/collaboration-allowlist.js.map +1 -1
- package/lib/managers/collaborations.d.ts +3 -3
- package/lib/managers/collaborations.js +23 -23
- package/lib/managers/collaborations.js.map +1 -1
- package/lib/managers/collections.js.map +1 -1
- package/lib/managers/comments.js.map +1 -1
- package/lib/managers/device-pins.js.map +1 -1
- package/lib/managers/enterprise.js.map +1 -1
- package/lib/managers/events.d.ts +0 -1
- package/lib/managers/events.js +3 -1
- package/lib/managers/events.js.map +1 -1
- package/lib/managers/file-requests-manager.d.ts +2 -2
- package/lib/managers/file-requests-manager.js +1 -1
- package/lib/managers/file-requests-manager.js.map +1 -1
- package/lib/managers/files.d.ts +1 -4
- package/lib/managers/files.js +6 -2
- package/lib/managers/files.js.map +1 -1
- package/lib/managers/folders.d.ts +1 -1
- package/lib/managers/folders.js +3 -1
- package/lib/managers/folders.js.map +1 -1
- package/lib/managers/groups.js +2 -2
- package/lib/managers/groups.js.map +1 -1
- package/lib/managers/integration-mappings.js.map +1 -1
- package/lib/managers/legal-hold-policies.js.map +1 -1
- package/lib/managers/metadata.js.map +1 -1
- package/lib/managers/recent-items.js.map +1 -1
- package/lib/managers/retention-policies.d.ts +1 -1
- package/lib/managers/retention-policies.js.map +1 -1
- package/lib/managers/search.d.ts +1 -1
- package/lib/managers/search.js.map +1 -1
- package/lib/managers/shared-items.js.map +1 -1
- package/lib/managers/shield-information-barrier-reports.generated.js.map +1 -1
- package/lib/managers/shield-information-barrier-segment-members.generated.js.map +1 -1
- package/lib/managers/shield-information-barrier-segment-restrictions.generated.js.map +1 -1
- package/lib/managers/shield-information-barrier-segments.generated.js.map +1 -1
- package/lib/managers/shield-information-barriers.generated.js.map +1 -1
- package/lib/managers/sign-requests.generated.js.map +1 -1
- package/lib/managers/sign-templates.generated.js.map +1 -1
- package/lib/managers/storage-policies.js.map +1 -1
- package/lib/managers/tasks.js.map +1 -1
- package/lib/managers/terms-of-service.js.map +1 -1
- package/lib/managers/trash.js.map +1 -1
- package/lib/managers/users.d.ts +0 -3
- package/lib/managers/users.js +1 -1
- package/lib/managers/users.js.map +1 -1
- package/lib/managers/web-links.js +3 -1
- package/lib/managers/web-links.js.map +1 -1
- package/lib/managers/webhooks.d.ts +11 -11
- package/lib/managers/webhooks.js +24 -14
- package/lib/managers/webhooks.js.map +1 -1
- package/lib/schemas/collaboration-update.d.ts +1 -1
- package/lib/schemas/collaboration.d.ts +3 -3
- package/lib/schemas/collaborations.d.ts +1 -1
- package/lib/schemas/file-request.d.ts +2 -2
- package/lib/sessions/app-auth-session.js.map +1 -1
- package/lib/sessions/basic-session.d.ts +0 -1
- package/lib/sessions/basic-session.js.map +1 -1
- package/lib/sessions/ccg-session.js.map +1 -1
- package/lib/sessions/persistent-session.js.map +1 -1
- package/lib/token-manager.js +4 -2
- package/lib/token-manager.js.map +1 -1
- package/lib/util/config.d.ts +0 -2
- package/lib/util/config.js +18 -8
- package/lib/util/config.js.map +1 -1
- package/lib/util/errors.js +17 -7
- package/lib/util/errors.js.map +1 -1
- package/lib/util/exponential-backoff.js.map +1 -1
- package/lib/util/paging-iterator.js +17 -7
- package/lib/util/paging-iterator.js.map +1 -1
- package/lib/util/serializable.js.map +1 -1
- package/lib/util/url-path.js.map +1 -1
- package/lib-esm/api-request-manager.d.ts +36 -0
- package/lib-esm/api-request-manager.js +78 -0
- package/lib-esm/api-request-manager.js.map +1 -0
- package/lib-esm/api-request.d.ts +135 -0
- package/lib-esm/api-request.js +282 -0
- package/lib-esm/api-request.js.map +1 -0
- package/lib-esm/box-client.d.ts +274 -0
- package/lib-esm/box-client.js +594 -0
- package/lib-esm/box-client.js.map +1 -0
- package/lib-esm/box-node-sdk.d.ts +227 -0
- package/lib-esm/box-node-sdk.js +373 -0
- package/lib-esm/box-node-sdk.js.map +1 -0
- package/lib-esm/chunked-uploader.d.ts +128 -0
- package/lib-esm/chunked-uploader.js +276 -0
- package/lib-esm/chunked-uploader.js.map +1 -0
- package/lib-esm/enterprise-event-stream.d.ts +82 -0
- package/lib-esm/enterprise-event-stream.js +205 -0
- package/lib-esm/enterprise-event-stream.js.map +1 -0
- package/lib-esm/event-stream.d.ts +91 -0
- package/lib-esm/event-stream.js +277 -0
- package/lib-esm/event-stream.js.map +1 -0
- package/lib-esm/managers/ai.generated.d.ts +58 -0
- package/lib-esm/managers/ai.generated.js +66 -0
- package/lib-esm/managers/ai.generated.js.map +1 -0
- package/lib-esm/managers/collaboration-allowlist.d.ts +133 -0
- package/lib-esm/managers/collaboration-allowlist.js +194 -0
- package/lib-esm/managers/collaboration-allowlist.js.map +1 -0
- package/lib-esm/managers/collaborations.d.ts +173 -0
- package/lib-esm/managers/collaborations.js +252 -0
- package/lib-esm/managers/collaborations.js.map +1 -0
- package/lib-esm/managers/collections.d.ts +42 -0
- package/lib-esm/managers/collections.js +62 -0
- package/lib-esm/managers/collections.js.map +1 -0
- package/lib-esm/managers/comments.d.ts +103 -0
- package/lib-esm/managers/comments.js +175 -0
- package/lib-esm/managers/comments.js.map +1 -0
- package/lib-esm/managers/device-pins.d.ts +52 -0
- package/lib-esm/managers/device-pins.js +91 -0
- package/lib-esm/managers/device-pins.js.map +1 -0
- package/lib-esm/managers/enterprise.d.ts +164 -0
- package/lib-esm/managers/enterprise.js +193 -0
- package/lib-esm/managers/enterprise.js.map +1 -0
- package/lib-esm/managers/events.d.ts +222 -0
- package/lib-esm/managers/events.js +295 -0
- package/lib-esm/managers/events.js.map +1 -0
- package/lib-esm/managers/file-requests-manager.d.ts +56 -0
- package/lib-esm/managers/file-requests-manager.js +81 -0
- package/lib-esm/managers/file-requests-manager.js.map +1 -0
- package/lib-esm/managers/files.d.ts +817 -0
- package/lib-esm/managers/files.js +1408 -0
- package/lib-esm/managers/files.js.map +1 -0
- package/lib-esm/managers/folders.d.ts +396 -0
- package/lib-esm/managers/folders.js +570 -0
- package/lib-esm/managers/folders.js.map +1 -0
- package/lib-esm/managers/groups.d.ts +213 -0
- package/lib-esm/managers/groups.js +289 -0
- package/lib-esm/managers/groups.js.map +1 -0
- package/lib-esm/managers/integration-mappings.d.ts +116 -0
- package/lib-esm/managers/integration-mappings.js +101 -0
- package/lib-esm/managers/integration-mappings.js.map +1 -0
- package/lib-esm/managers/legal-hold-policies.d.ts +190 -0
- package/lib-esm/managers/legal-hold-policies.js +254 -0
- package/lib-esm/managers/legal-hold-policies.js.map +1 -0
- package/lib-esm/managers/metadata.d.ts +232 -0
- package/lib-esm/managers/metadata.js +288 -0
- package/lib-esm/managers/metadata.js.map +1 -0
- package/lib-esm/managers/recent-items.d.ts +38 -0
- package/lib-esm/managers/recent-items.js +49 -0
- package/lib-esm/managers/recent-items.js.map +1 -0
- package/lib-esm/managers/retention-policies.d.ts +308 -0
- package/lib-esm/managers/retention-policies.js +374 -0
- package/lib-esm/managers/retention-policies.js.map +1 -0
- package/lib-esm/managers/search.d.ts +82 -0
- package/lib-esm/managers/search.js +90 -0
- package/lib-esm/managers/search.js.map +1 -0
- package/lib-esm/managers/shared-items.d.ts +33 -0
- package/lib-esm/managers/shared-items.js +74 -0
- package/lib-esm/managers/shared-items.js.map +1 -0
- package/lib-esm/managers/shield-information-barrier-reports.generated.d.ts +65 -0
- package/lib-esm/managers/shield-information-barrier-reports.generated.js +65 -0
- package/lib-esm/managers/shield-information-barrier-reports.generated.js.map +1 -0
- package/lib-esm/managers/shield-information-barrier-segment-members.generated.d.ts +83 -0
- package/lib-esm/managers/shield-information-barrier-segment-members.generated.js +83 -0
- package/lib-esm/managers/shield-information-barrier-segment-members.generated.js.map +1 -0
- package/lib-esm/managers/shield-information-barrier-segment-restrictions.generated.d.ts +84 -0
- package/lib-esm/managers/shield-information-barrier-segment-restrictions.generated.js +84 -0
- package/lib-esm/managers/shield-information-barrier-segment-restrictions.generated.js.map +1 -0
- package/lib-esm/managers/shield-information-barrier-segments.generated.d.ts +98 -0
- package/lib-esm/managers/shield-information-barrier-segments.generated.js +99 -0
- package/lib-esm/managers/shield-information-barrier-segments.generated.js.map +1 -0
- package/lib-esm/managers/shield-information-barriers.generated.d.ts +79 -0
- package/lib-esm/managers/shield-information-barriers.generated.js +83 -0
- package/lib-esm/managers/shield-information-barriers.generated.js.map +1 -0
- package/lib-esm/managers/sign-requests.generated.d.ts +93 -0
- package/lib-esm/managers/sign-requests.generated.js +97 -0
- package/lib-esm/managers/sign-requests.generated.js.map +1 -0
- package/lib-esm/managers/sign-templates.generated.d.ts +51 -0
- package/lib-esm/managers/sign-templates.generated.js +49 -0
- package/lib-esm/managers/sign-templates.generated.js.map +1 -0
- package/lib-esm/managers/storage-policies.d.ts +86 -0
- package/lib-esm/managers/storage-policies.js +174 -0
- package/lib-esm/managers/storage-policies.js.map +1 -0
- package/lib-esm/managers/tasks.d.ts +161 -0
- package/lib-esm/managers/tasks.js +243 -0
- package/lib-esm/managers/tasks.js.map +1 -0
- package/lib-esm/managers/terms-of-service.d.ts +161 -0
- package/lib-esm/managers/terms-of-service.js +283 -0
- package/lib-esm/managers/terms-of-service.js.map +1 -0
- package/lib-esm/managers/trash.d.ts +30 -0
- package/lib-esm/managers/trash.js +47 -0
- package/lib-esm/managers/trash.js.map +1 -0
- package/lib-esm/managers/users.d.ts +171 -0
- package/lib-esm/managers/users.js +230 -0
- package/lib-esm/managers/users.js.map +1 -0
- package/lib-esm/managers/web-links.d.ts +127 -0
- package/lib-esm/managers/web-links.js +200 -0
- package/lib-esm/managers/web-links.js.map +1 -0
- package/lib-esm/managers/webhooks.d.ts +169 -0
- package/lib-esm/managers/webhooks.js +398 -0
- package/lib-esm/managers/webhooks.js.map +1 -0
- package/lib-esm/schemas/ai-agent-ask.generated.d.ts +17 -0
- package/lib-esm/schemas/ai-agent-ask.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-ask.generated.js.map +1 -0
- package/lib-esm/schemas/ai-agent-basic-gen-tool.generated.d.ts +14 -0
- package/lib-esm/schemas/ai-agent-basic-gen-tool.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-basic-gen-tool.generated.js.map +1 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-ask.generated.d.ts +34 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-ask.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-ask.generated.js.map +1 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-text-gen.generated.d.ts +36 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-text-gen.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-basic-text-tool-text-gen.generated.js.map +1 -0
- package/lib-esm/schemas/ai-agent-long-text-tool.generated.d.ts +9 -0
- package/lib-esm/schemas/ai-agent-long-text-tool.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-long-text-tool.generated.js.map +1 -0
- package/lib-esm/schemas/ai-agent-text-gen.generated.d.ts +14 -0
- package/lib-esm/schemas/ai-agent-text-gen.generated.js +3 -0
- package/lib-esm/schemas/ai-agent-text-gen.generated.js.map +1 -0
- package/lib-esm/schemas/ai-ask.generated.d.ts +40 -0
- package/lib-esm/schemas/ai-ask.generated.js +3 -0
- package/lib-esm/schemas/ai-ask.generated.js.map +1 -0
- package/lib-esm/schemas/ai-citation.generated.d.ts +27 -0
- package/lib-esm/schemas/ai-citation.generated.js +3 -0
- package/lib-esm/schemas/ai-citation.generated.js.map +1 -0
- package/lib-esm/schemas/ai-dialogue-history.generated.d.ts +22 -0
- package/lib-esm/schemas/ai-dialogue-history.generated.js +3 -0
- package/lib-esm/schemas/ai-dialogue-history.generated.js.map +1 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-google.generated.d.ts +31 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-google.generated.js +3 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-google.generated.js.map +1 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-open-ai.generated.d.ts +43 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-open-ai.generated.js +3 -0
- package/lib-esm/schemas/ai-llm-endpoint-params-open-ai.generated.js.map +1 -0
- package/lib-esm/schemas/ai-response-full.generated.d.ts +12 -0
- package/lib-esm/schemas/ai-response-full.generated.js +3 -0
- package/lib-esm/schemas/ai-response-full.generated.js.map +1 -0
- package/lib-esm/schemas/ai-response.generated.d.ts +22 -0
- package/lib-esm/schemas/ai-response.generated.js +3 -0
- package/lib-esm/schemas/ai-response.generated.js.map +1 -0
- package/lib-esm/schemas/ai-text-gen.generated.d.ts +30 -0
- package/lib-esm/schemas/ai-text-gen.generated.js +3 -0
- package/lib-esm/schemas/ai-text-gen.generated.js.map +1 -0
- package/lib-esm/schemas/collaboration-create.d.ts +5 -0
- package/lib-esm/schemas/collaboration-create.js +3 -0
- package/lib-esm/schemas/collaboration-create.js.map +1 -0
- package/lib-esm/schemas/collaboration-update.d.ts +7 -0
- package/lib-esm/schemas/collaboration-update.js +3 -0
- package/lib-esm/schemas/collaboration-update.js.map +1 -0
- package/lib-esm/schemas/collaboration.d.ts +108 -0
- package/lib-esm/schemas/collaboration.js +3 -0
- package/lib-esm/schemas/collaboration.js.map +1 -0
- package/lib-esm/schemas/collaborations.d.ts +13 -0
- package/lib-esm/schemas/collaborations.js +3 -0
- package/lib-esm/schemas/collaborations.js.map +1 -0
- package/lib-esm/schemas/enterprise-base.generated.d.ts +18 -0
- package/lib-esm/schemas/enterprise-base.generated.js +3 -0
- package/lib-esm/schemas/enterprise-base.generated.js.map +1 -0
- package/lib-esm/schemas/file-base.generated.d.ts +32 -0
- package/lib-esm/schemas/file-base.generated.js +3 -0
- package/lib-esm/schemas/file-base.generated.js.map +1 -0
- package/lib-esm/schemas/file-mini.generated.d.ts +41 -0
- package/lib-esm/schemas/file-mini.generated.js +3 -0
- package/lib-esm/schemas/file-mini.generated.js.map +1 -0
- package/lib-esm/schemas/file-request.d.ts +41 -0
- package/lib-esm/schemas/file-request.js +3 -0
- package/lib-esm/schemas/file-request.js.map +1 -0
- package/lib-esm/schemas/file-version-base.generated.d.ts +19 -0
- package/lib-esm/schemas/file-version-base.generated.js +3 -0
- package/lib-esm/schemas/file-version-base.generated.js.map +1 -0
- package/lib-esm/schemas/file-version-mini.generated.d.ts +14 -0
- package/lib-esm/schemas/file-version-mini.generated.js +3 -0
- package/lib-esm/schemas/file-version-mini.generated.js.map +1 -0
- package/lib-esm/schemas/folder-base.generated.d.ts +32 -0
- package/lib-esm/schemas/folder-base.generated.js +3 -0
- package/lib-esm/schemas/folder-base.generated.js.map +1 -0
- package/lib-esm/schemas/folder-mini.generated.d.ts +31 -0
- package/lib-esm/schemas/folder-mini.generated.js +3 -0
- package/lib-esm/schemas/folder-mini.generated.js.map +1 -0
- package/lib-esm/schemas/index.d.ts +15 -0
- package/lib-esm/schemas/index.generated.d.ts +52 -0
- package/lib-esm/schemas/index.generated.js +69 -0
- package/lib-esm/schemas/index.generated.js.map +1 -0
- package/lib-esm/schemas/index.js +32 -0
- package/lib-esm/schemas/index.js.map +1 -0
- package/lib-esm/schemas/integration-mapping-base.d.ts +23 -0
- package/lib-esm/schemas/integration-mapping-base.js +3 -0
- package/lib-esm/schemas/integration-mapping-base.js.map +1 -0
- package/lib-esm/schemas/integration-mapping-box-item-slack.d.ts +17 -0
- package/lib-esm/schemas/integration-mapping-box-item-slack.js +3 -0
- package/lib-esm/schemas/integration-mapping-box-item-slack.js.map +1 -0
- package/lib-esm/schemas/integration-mapping-partner-item-slack.d.ts +27 -0
- package/lib-esm/schemas/integration-mapping-partner-item-slack.js +3 -0
- package/lib-esm/schemas/integration-mapping-partner-item-slack.js.map +1 -0
- package/lib-esm/schemas/integration-mapping-slack-create-request.d.ts +12 -0
- package/lib-esm/schemas/integration-mapping-slack-create-request.js +3 -0
- package/lib-esm/schemas/integration-mapping-slack-create-request.js.map +1 -0
- package/lib-esm/schemas/integration-mapping-slack-options.d.ts +16 -0
- package/lib-esm/schemas/integration-mapping-slack-options.js +3 -0
- package/lib-esm/schemas/integration-mapping-slack-options.js.map +1 -0
- package/lib-esm/schemas/integration-mapping.d.ts +55 -0
- package/lib-esm/schemas/integration-mapping.js +3 -0
- package/lib-esm/schemas/integration-mapping.js.map +1 -0
- package/lib-esm/schemas/integration-mappings.d.ts +27 -0
- package/lib-esm/schemas/integration-mappings.js +3 -0
- package/lib-esm/schemas/integration-mappings.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-base.generated.d.ts +18 -0
- package/lib-esm/schemas/shield-information-barrier-base.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-base.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-reference.generated.d.ts +9 -0
- package/lib-esm/schemas/shield-information-barrier-reference.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-reference.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-report-base.generated.d.ts +18 -0
- package/lib-esm/schemas/shield-information-barrier-report-base.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-report-base.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-report-details.generated.d.ts +9 -0
- package/lib-esm/schemas/shield-information-barrier-report-details.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-report-details.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-report.generated.d.ts +32 -0
- package/lib-esm/schemas/shield-information-barrier-report.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-report.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-reports.generated.d.ts +26 -0
- package/lib-esm/schemas/shield-information-barrier-reports.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-reports.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-base.generated.d.ts +19 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-base.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-base.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-mini.generated.d.ts +13 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-mini.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member-mini.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member.generated.d.ts +39 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-member.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-members.generated.d.ts +26 -0
- package/lib-esm/schemas/shield-information-barrier-segment-members.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-members.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-base.generated.d.ts +20 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-base.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-base.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-mini.generated.d.ts +20 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-mini.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction-mini.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction.generated.d.ts +33 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restriction.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restrictions.generated.d.ts +26 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restrictions.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment-restrictions.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segment.generated.d.ts +50 -0
- package/lib-esm/schemas/shield-information-barrier-segment.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segment.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier-segments.generated.d.ts +26 -0
- package/lib-esm/schemas/shield-information-barrier-segments.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier-segments.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barrier.generated.d.ts +56 -0
- package/lib-esm/schemas/shield-information-barrier.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barrier.generated.js.map +1 -0
- package/lib-esm/schemas/shield-information-barriers.generated.d.ts +25 -0
- package/lib-esm/schemas/shield-information-barriers.generated.js +3 -0
- package/lib-esm/schemas/shield-information-barriers.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-base.generated.d.ts +78 -0
- package/lib-esm/schemas/sign-request-base.generated.js +3 -0
- package/lib-esm/schemas/sign-request-base.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-create-request.generated.d.ts +39 -0
- package/lib-esm/schemas/sign-request-create-request.generated.js +3 -0
- package/lib-esm/schemas/sign-request-create-request.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-create-signer.generated.d.ts +95 -0
- package/lib-esm/schemas/sign-request-create-signer.generated.js +3 -0
- package/lib-esm/schemas/sign-request-create-signer.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-prefill-tag.generated.d.ts +28 -0
- package/lib-esm/schemas/sign-request-prefill-tag.generated.js +3 -0
- package/lib-esm/schemas/sign-request-prefill-tag.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-signer-input.generated.d.ts +28 -0
- package/lib-esm/schemas/sign-request-signer-input.generated.js +3 -0
- package/lib-esm/schemas/sign-request-signer-input.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request-signer.generated.d.ts +34 -0
- package/lib-esm/schemas/sign-request-signer.generated.js +3 -0
- package/lib-esm/schemas/sign-request-signer.generated.js.map +1 -0
- package/lib-esm/schemas/sign-request.generated.d.ts +72 -0
- package/lib-esm/schemas/sign-request.generated.js +3 -0
- package/lib-esm/schemas/sign-request.generated.js.map +1 -0
- package/lib-esm/schemas/sign-requests.generated.d.ts +25 -0
- package/lib-esm/schemas/sign-requests.generated.js +3 -0
- package/lib-esm/schemas/sign-requests.generated.js.map +1 -0
- package/lib-esm/schemas/sign-template.generated.d.ts +94 -0
- package/lib-esm/schemas/sign-template.generated.js +3 -0
- package/lib-esm/schemas/sign-template.generated.js.map +1 -0
- package/lib-esm/schemas/sign-templates.generated.d.ts +30 -0
- package/lib-esm/schemas/sign-templates.generated.js +3 -0
- package/lib-esm/schemas/sign-templates.generated.js.map +1 -0
- package/lib-esm/schemas/template-signer-input.generated.d.ts +61 -0
- package/lib-esm/schemas/template-signer-input.generated.js +3 -0
- package/lib-esm/schemas/template-signer-input.generated.js.map +1 -0
- package/lib-esm/schemas/template-signer.generated.d.ts +43 -0
- package/lib-esm/schemas/template-signer.generated.js +3 -0
- package/lib-esm/schemas/template-signer.generated.js.map +1 -0
- package/lib-esm/schemas/user-base.generated.d.ts +18 -0
- package/lib-esm/schemas/user-base.generated.js +3 -0
- package/lib-esm/schemas/user-base.generated.js.map +1 -0
- package/lib-esm/schemas/user-integration-mappings.d.ts +19 -0
- package/lib-esm/schemas/user-integration-mappings.js +3 -0
- package/lib-esm/schemas/user-integration-mappings.js.map +1 -0
- package/lib-esm/schemas/user-mini.d.ts +6 -0
- package/lib-esm/schemas/user-mini.js +3 -0
- package/lib-esm/schemas/user-mini.js.map +1 -0
- package/lib-esm/sessions/app-auth-session.d.ts +92 -0
- package/lib-esm/sessions/app-auth-session.js +176 -0
- package/lib-esm/sessions/app-auth-session.js.map +1 -0
- package/lib-esm/sessions/basic-session.d.ts +55 -0
- package/lib-esm/sessions/basic-session.js +62 -0
- package/lib-esm/sessions/basic-session.js.map +1 -0
- package/lib-esm/sessions/ccg-session.d.ts +72 -0
- package/lib-esm/sessions/ccg-session.js +111 -0
- package/lib-esm/sessions/ccg-session.js.map +1 -0
- package/lib-esm/sessions/persistent-session.d.ts +96 -0
- package/lib-esm/sessions/persistent-session.js +234 -0
- package/lib-esm/sessions/persistent-session.js.map +1 -0
- package/lib-esm/token-manager.d.ts +191 -0
- package/lib-esm/token-manager.js +453 -0
- package/lib-esm/token-manager.js.map +1 -0
- package/lib-esm/util/config.d.ts +85 -0
- package/lib-esm/util/config.js +212 -0
- package/lib-esm/util/config.js.map +1 -0
- package/lib-esm/util/errors.d.ts +50 -0
- package/lib-esm/util/errors.js +176 -0
- package/lib-esm/util/errors.js.map +1 -0
- package/lib-esm/util/exponential-backoff.d.ts +11 -0
- package/lib-esm/util/exponential-backoff.js +17 -0
- package/lib-esm/util/exponential-backoff.js.map +1 -0
- package/lib-esm/util/paging-iterator.d.ts +53 -0
- package/lib-esm/util/paging-iterator.js +247 -0
- package/lib-esm/util/paging-iterator.js.map +1 -0
- package/lib-esm/util/serializable.d.ts +10 -0
- package/lib-esm/util/serializable.js +17 -0
- package/lib-esm/util/serializable.js.map +1 -0
- package/lib-esm/util/url-path.d.ts +16 -0
- package/lib-esm/util/url-path.js +36 -0
- package/lib-esm/util/url-path.js.map +1 -0
- package/package.json +33 -28
|
@@ -0,0 +1,374 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @fileoverview Manager for the Retention Policies Resource
|
|
4
|
+
*/
|
|
5
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
6
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
7
|
+
};
|
|
8
|
+
const url_path_1 = __importDefault(require("../util/url-path"));
|
|
9
|
+
// -----------------------------------------------------------------------------
|
|
10
|
+
// Typedefs
|
|
11
|
+
// -----------------------------------------------------------------------------
|
|
12
|
+
/**
|
|
13
|
+
* Enum of valid retention policy types, which specify how long the policy should
|
|
14
|
+
* remain in effect.
|
|
15
|
+
* @readonly
|
|
16
|
+
* @enum {RetentionPolicyType}
|
|
17
|
+
*/
|
|
18
|
+
var RetentionPolicyType;
|
|
19
|
+
(function (RetentionPolicyType) {
|
|
20
|
+
RetentionPolicyType["FINITE"] = "finite";
|
|
21
|
+
RetentionPolicyType["INDEFINITE"] = "indefinite";
|
|
22
|
+
})(RetentionPolicyType || (RetentionPolicyType = {}));
|
|
23
|
+
/**
|
|
24
|
+
* Enum of valid retention types.
|
|
25
|
+
* @readonly
|
|
26
|
+
* @enum {RetentionType}
|
|
27
|
+
*/
|
|
28
|
+
var RetentionType;
|
|
29
|
+
(function (RetentionType) {
|
|
30
|
+
/**
|
|
31
|
+
* You can modify the retention policy. For example, you can add or remove folders,
|
|
32
|
+
* shorten or lengthen the policy duration, or delete the assignment.
|
|
33
|
+
* Use this type if your retention policy is not related to any regulatory purposes.
|
|
34
|
+
*/
|
|
35
|
+
RetentionType["MODIFIABLE"] = "modifiable";
|
|
36
|
+
/**
|
|
37
|
+
* You can modify the retention policy only in a limited way: add a folder, lengthen the duration,
|
|
38
|
+
* retire the policy, change the disposition action or notification settings.
|
|
39
|
+
* You cannot perform other actions, such as deleting the assignment or shortening the policy duration.
|
|
40
|
+
* Use this type to ensure compliance with regulatory retention policies.
|
|
41
|
+
*/
|
|
42
|
+
RetentionType["NON_MODIFIABLE"] = "non_modifiable";
|
|
43
|
+
})(RetentionType || (RetentionType = {}));
|
|
44
|
+
/**
|
|
45
|
+
* Enum of valid retention policy disposition actions, which specify what should
|
|
46
|
+
* be done when the retention period is over
|
|
47
|
+
* @readonly
|
|
48
|
+
* @enum {RetentionPolicyDispositionAction}
|
|
49
|
+
*/
|
|
50
|
+
var RetentionPolicyDispositionAction;
|
|
51
|
+
(function (RetentionPolicyDispositionAction) {
|
|
52
|
+
RetentionPolicyDispositionAction["PERMANENTLY_DELETE"] = "permanently_delete";
|
|
53
|
+
RetentionPolicyDispositionAction["REMOVE_RETENTION"] = "remove_retention";
|
|
54
|
+
})(RetentionPolicyDispositionAction || (RetentionPolicyDispositionAction = {}));
|
|
55
|
+
/**
|
|
56
|
+
* Enum of valid policy assignment types, which specify what object the policy applies to
|
|
57
|
+
* @readonly
|
|
58
|
+
* @enum {RetentionPolicyAssignmentType}
|
|
59
|
+
*/
|
|
60
|
+
var RetentionPolicyAssignmentType;
|
|
61
|
+
(function (RetentionPolicyAssignmentType) {
|
|
62
|
+
RetentionPolicyAssignmentType["FOLDER"] = "folder";
|
|
63
|
+
RetentionPolicyAssignmentType["ENTERPRISE"] = "enterprise";
|
|
64
|
+
RetentionPolicyAssignmentType["METADATA"] = "metadata_template";
|
|
65
|
+
})(RetentionPolicyAssignmentType || (RetentionPolicyAssignmentType = {}));
|
|
66
|
+
// -----------------------------------------------------------------------------
|
|
67
|
+
// Private
|
|
68
|
+
// -----------------------------------------------------------------------------
|
|
69
|
+
const BASE_PATH = '/retention_policies', ASSIGNMENTS_PATH = '/retention_policy_assignments', FILE_VERSION_RETENTIONS_PATH = '/file_version_retentions', ASSIGNMENTS_SUBRESOURCE = 'assignments', FILES_UNDER_RETENTION_SUBRESOURCE = 'files_under_retention', FILES_VERSIONS_UNDER_RETENTION_SUBRESOURCE = 'file_versions_under_retention';
|
|
70
|
+
// -----------------------------------------------------------------------------
|
|
71
|
+
// Public
|
|
72
|
+
// -----------------------------------------------------------------------------
|
|
73
|
+
/**
|
|
74
|
+
* Simple manager for interacting with all Retention Policies endpoints and actions.
|
|
75
|
+
*
|
|
76
|
+
* @constructor
|
|
77
|
+
* @param {BoxClient} client - The Box API Client that is responsible for making calls to the API
|
|
78
|
+
* @returns {void}
|
|
79
|
+
*/
|
|
80
|
+
class RetentionPolicies {
|
|
81
|
+
constructor(client) {
|
|
82
|
+
this.client = client;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Used to create a single retention policy for an enterprise
|
|
86
|
+
*
|
|
87
|
+
* API Endpoint: '/retention_policies'
|
|
88
|
+
* Method: POST
|
|
89
|
+
*
|
|
90
|
+
* @param {string} name - The name of the retention policy to be created
|
|
91
|
+
* @param {RetentionPolicyType} type - The type of policy to create
|
|
92
|
+
* @param {RetentionPolicyDispositionAction} action - The disposition action for the new policy
|
|
93
|
+
* @param {Object} [options] - Additional parameters
|
|
94
|
+
* @param {boolean} [options.are_owners_notified] - Whether or not owner and co-owners of a file are notified when the policy nears expiration
|
|
95
|
+
* @param {boolean} [options.can_owner_extend_retention] - Whether or not the owner of a file will be allowed to extend the retention
|
|
96
|
+
* @param {UserMini[]} [options.custom_notification_recipients] - A list of users notified when the retention policy duration is about to end
|
|
97
|
+
* @param {string} [options.description] - The additional text description of the retention policy
|
|
98
|
+
* @param {int} [options.retention_length] - For finite policies, the number of days to retain the content
|
|
99
|
+
* @param {RetentionType} [options.retention_type] - The type of retention for the new policy
|
|
100
|
+
* @param {Function} [callback] - Passed the new policy information if it was acquired successfully, error otherwise
|
|
101
|
+
* @returns {Promise<Object>} A promise resolving to the new policy object
|
|
102
|
+
*/
|
|
103
|
+
create(name, type, action, options, callback) {
|
|
104
|
+
var apiPath = (0, url_path_1.default)(BASE_PATH), params = {
|
|
105
|
+
body: {
|
|
106
|
+
policy_name: name,
|
|
107
|
+
policy_type: type,
|
|
108
|
+
disposition_action: action,
|
|
109
|
+
},
|
|
110
|
+
};
|
|
111
|
+
Object.assign(params.body, options);
|
|
112
|
+
return this.client.wrapWithDefaultHandler(this.client.post)(apiPath, params, callback);
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Fetches details about a specific retention policy
|
|
116
|
+
*
|
|
117
|
+
* API Endpoint: '/retention_policies/:policyID'
|
|
118
|
+
* Method: GET
|
|
119
|
+
*
|
|
120
|
+
* @param {string} policyID - The Box ID of the retention policy being requested
|
|
121
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
122
|
+
* @param {Function} [callback] - Passed the policy information if it was acquired successfully, error otherwise
|
|
123
|
+
* @returns {Promise<Object>} A promise resolving to the policy object
|
|
124
|
+
*/
|
|
125
|
+
get(policyID, options, callback) {
|
|
126
|
+
var apiPath = (0, url_path_1.default)(BASE_PATH, policyID), params = {
|
|
127
|
+
qs: options,
|
|
128
|
+
};
|
|
129
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Update or modify a retention policy.
|
|
133
|
+
*
|
|
134
|
+
* API Endpoint: '/retention_policies/:policyID'
|
|
135
|
+
* Method: PUT
|
|
136
|
+
*
|
|
137
|
+
* @param {string} policyID - The Box ID of the retention policy to update
|
|
138
|
+
* @param {Object} updates - The information to be updated
|
|
139
|
+
* @param {string} [updates.policy_name] - The name of the retention policy
|
|
140
|
+
* @param {RetentionPolicyDispositionAction} [updates.disposition_action] - The disposition action for the updated policy
|
|
141
|
+
* @param {boolean} [updates.are_owners_notified] - Whether or not owner and co-owners of a file are notified when the policy nears expiration
|
|
142
|
+
* @param {boolean} [updates.can_owner_extend_retention] - Whether or not the owner of a file will be allowed to extend the retention
|
|
143
|
+
* @param {UserMini[]} [updates.custom_notification_recipients] - A list of users notified when the retention policy duration is about to end
|
|
144
|
+
* @param {string} [updates.description] - The additional text description of the retention policy
|
|
145
|
+
* @param {int} [updates.retention_length] - For finite policies, the number of days to retain the content
|
|
146
|
+
* @param {RetentionType} [updates.retention_type] - The type of retention. The only possible value here is non_modifiable. You can convert a modifiable policy to non_modifiable, but not the other way around.
|
|
147
|
+
* @param {string} [updates.status] - Used to retire a retention policy if status is set to retired
|
|
148
|
+
* @param {Function} [callback] - Passed the updated policy information if it was acquired successfully, error otherwise
|
|
149
|
+
* @returns {Promise<Object>} A promise resolving to the updated policy object
|
|
150
|
+
*/
|
|
151
|
+
update(policyID, updates, callback) {
|
|
152
|
+
var apiPath = (0, url_path_1.default)(BASE_PATH, policyID), params = {
|
|
153
|
+
body: updates,
|
|
154
|
+
};
|
|
155
|
+
return this.client.wrapWithDefaultHandler(this.client.put)(apiPath, params, callback);
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Fetches a list of retention policies for the enterprise
|
|
159
|
+
*
|
|
160
|
+
* API Endpoint: '/retention_policies
|
|
161
|
+
* Method: GET
|
|
162
|
+
*
|
|
163
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
164
|
+
* @param {string} [options.policy_name] - A full or partial name to filter the retention policies by
|
|
165
|
+
* @param {RetentionPolicyType} [options.policy_type] - A policy type to filter the retention policies by
|
|
166
|
+
* @param {string} [options.created_by_user_id] - A user id to filter the retention policies by
|
|
167
|
+
* @param {Function} [callback] - Passed the policy objects if they were acquired successfully, error otherwise
|
|
168
|
+
* @returns {Promise<Object>} A promise resolving to the collection of policies
|
|
169
|
+
*/
|
|
170
|
+
getAll(options, callback) {
|
|
171
|
+
var apiPath = (0, url_path_1.default)(BASE_PATH), params = {
|
|
172
|
+
qs: options,
|
|
173
|
+
};
|
|
174
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Fetch a list of assignments for a given retention policy
|
|
178
|
+
*
|
|
179
|
+
* API Endpoint: '/retention_policies/:policyID/assignments'
|
|
180
|
+
* Method: GET
|
|
181
|
+
*
|
|
182
|
+
* @param {string} policyID - The Box ID of the retention policy to get assignments for
|
|
183
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
184
|
+
* @param {RetentionPolicyAssignmentType} [options.type] - The type of the retention policy assignment to retrieve
|
|
185
|
+
* @param {Function} [callback] - Passed the assignment objects if they were acquired successfully, error otherwise
|
|
186
|
+
* @returns {Promise<Object>} A promise resolving to the collection of policy assignments
|
|
187
|
+
*/
|
|
188
|
+
getAssignments(policyID, options, callback) {
|
|
189
|
+
var apiPath = (0, url_path_1.default)(BASE_PATH, policyID, ASSIGNMENTS_SUBRESOURCE), params = {
|
|
190
|
+
qs: options,
|
|
191
|
+
};
|
|
192
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Assign a retention policy to a folder or the entire enterprise.
|
|
196
|
+
*
|
|
197
|
+
* API Endpoint: '/retention_policy_assignments
|
|
198
|
+
* Method: POST
|
|
199
|
+
*
|
|
200
|
+
* @param {string} policyID - The ID of the policy to assign
|
|
201
|
+
* @param {RetentionPolicyAssignmentType} assignType - The type of object the policy will be assigned to
|
|
202
|
+
* @param {string} assignID - The Box ID of the object to assign the retention policy to
|
|
203
|
+
* @param {Object} [options] - Optional parameters for the request
|
|
204
|
+
* @param {MetadataFilterField[]} [options.filter_fields] - Metadata fields to filter against, if assigning to a metadata template
|
|
205
|
+
* @param {string} [options.start_date_field] - Id of Metadata field which will be used to specify the start date for the retention policy, or set this to "upload_date" as value to use the date when the file was uploaded to Box
|
|
206
|
+
* @param {Function} [callback] - Passed the new assignment object if successful, error otherwise
|
|
207
|
+
* @returns {Promise<Object>} A promise resolving to the created assignment object
|
|
208
|
+
*/
|
|
209
|
+
assign(policyID, assignType, assignID, options, callback) {
|
|
210
|
+
// Shuffle optional arguments
|
|
211
|
+
if (typeof options === 'function') {
|
|
212
|
+
callback = options;
|
|
213
|
+
options = null;
|
|
214
|
+
}
|
|
215
|
+
var apiPath = (0, url_path_1.default)(ASSIGNMENTS_PATH), params = {
|
|
216
|
+
body: {
|
|
217
|
+
policy_id: policyID,
|
|
218
|
+
assign_to: {
|
|
219
|
+
type: assignType,
|
|
220
|
+
id: assignID,
|
|
221
|
+
},
|
|
222
|
+
},
|
|
223
|
+
};
|
|
224
|
+
Object.assign(params.body, options);
|
|
225
|
+
return this.client.wrapWithDefaultHandler(this.client.post)(apiPath, params, callback);
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Fetch a specific policy assignment
|
|
229
|
+
*
|
|
230
|
+
* API Endpoint: '/retention_policy_assignments/:assignmentID'
|
|
231
|
+
* Method: GET
|
|
232
|
+
*
|
|
233
|
+
* @param {string} assignmentID - The Box ID of the policy assignment object to fetch
|
|
234
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
235
|
+
* @param {Function} [callback] - Passed the assignment object if it was acquired successfully, error otherwise
|
|
236
|
+
* @returns {Promise<Object>} A promise resolving to the assignment object
|
|
237
|
+
*/
|
|
238
|
+
getAssignment(assignmentID, options, callback) {
|
|
239
|
+
var apiPath = (0, url_path_1.default)(ASSIGNMENTS_PATH, assignmentID), params = {
|
|
240
|
+
qs: options,
|
|
241
|
+
};
|
|
242
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Delete a specific policy assignment.
|
|
246
|
+
*
|
|
247
|
+
* API Endpoint: '/retention_policy_assignments/:assignmentID'
|
|
248
|
+
* Method: DELETE
|
|
249
|
+
*
|
|
250
|
+
* @param {string} assignmentID - The Box ID of the policy assignment object to delete
|
|
251
|
+
* @param {Function} [callback] - Empty response body passed if successful.
|
|
252
|
+
* @returns {Promise<void>} A promise resolving to nothing
|
|
253
|
+
*/
|
|
254
|
+
deleteAssignment(assignmentID, callback) {
|
|
255
|
+
var apiPath = (0, url_path_1.default)(ASSIGNMENTS_PATH, assignmentID);
|
|
256
|
+
return this.client.wrapWithDefaultHandler(this.client.del)(apiPath, null, callback);
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Get the specific retention record for a retained file version. To use this feature,
|
|
260
|
+
* you must have the manage retention policies scope enabled for your API key
|
|
261
|
+
* via your application management console.
|
|
262
|
+
*
|
|
263
|
+
* API Endpoint: '/file_version_retentions/:retentionID'
|
|
264
|
+
* Method: GET
|
|
265
|
+
*
|
|
266
|
+
* @param {string} retentionID - The ID for the file retention record to retrieve
|
|
267
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
268
|
+
* @param {Function} [callback] - Pass the file version retention record if successful, error otherwise
|
|
269
|
+
* @returns {Promise<Object>} A promise resolving to the retention record
|
|
270
|
+
*/
|
|
271
|
+
getFileVersionRetention(retentionID, options, callback) {
|
|
272
|
+
var apiPath = (0, url_path_1.default)(FILE_VERSION_RETENTIONS_PATH, retentionID), params = {
|
|
273
|
+
qs: options,
|
|
274
|
+
};
|
|
275
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
276
|
+
}
|
|
277
|
+
/**
|
|
278
|
+
* Get a list of retention records for a retained file versions in an enterprise.
|
|
279
|
+
* To use this feature, you must have the manage retention policies scope enabled
|
|
280
|
+
* for your API key via your application management console.
|
|
281
|
+
*
|
|
282
|
+
* API Endpoint: '/file_version_retentions'
|
|
283
|
+
* Method: GET
|
|
284
|
+
*
|
|
285
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
286
|
+
* @param {string} [options.file_id] - A file id to filter the file version retentions by
|
|
287
|
+
* @param {string} [options.file_version_id] - A file version id to filter the file version retentions by
|
|
288
|
+
* @param {string} [options.policy_id] - A policy id to filter the file version retentions by
|
|
289
|
+
* @param {RetentionPolicyDispositionAction} [options.disposition_action] - The disposition action of the retention policy to filter by
|
|
290
|
+
* @param {string} [options.disposition_before] - Filter by retention policies which will complete before a certain time
|
|
291
|
+
* @param {string} [options.disposition_after] - Filter by retention policies which will complete after a certain time
|
|
292
|
+
* @param {int} [options.limit] - The maximum number of items to return in a page
|
|
293
|
+
* @param {string} [options.marker] - Paging marker, left blank to begin paging from the beginning
|
|
294
|
+
* @param {Function} [callback] - Pass the file version retention record if successful, error otherwise
|
|
295
|
+
* @returns {Promise<Object>} A promise resolving to the collection of retention records
|
|
296
|
+
*/
|
|
297
|
+
getAllFileVersionRetentions(options, callback) {
|
|
298
|
+
var apiPath = (0, url_path_1.default)(FILE_VERSION_RETENTIONS_PATH), params = {
|
|
299
|
+
qs: options,
|
|
300
|
+
};
|
|
301
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
302
|
+
}
|
|
303
|
+
/**
|
|
304
|
+
* Get files under retention by each assignment
|
|
305
|
+
* To use this feature, you must have the manage retention policies scope enabled
|
|
306
|
+
* for your API key via your application management console.
|
|
307
|
+
*
|
|
308
|
+
* API Endpoint: '/retention_policy_assignments/:assignmentID/files_under_retention'
|
|
309
|
+
* Method: GET
|
|
310
|
+
*
|
|
311
|
+
* @param {string} assignmentID - The Box ID of the policy assignment object to fetch
|
|
312
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
313
|
+
* @param {int} [options.limit] - The maximum number of items to return in a page
|
|
314
|
+
* @param {string} [options.marker] - Paging marker, left blank to begin paging from the beginning
|
|
315
|
+
* @param {Function} [callback] - Pass the file version retention record if successful, error otherwise
|
|
316
|
+
* @returns {Promise<Object>} A promise resolving to the collection of retention records
|
|
317
|
+
*/
|
|
318
|
+
getFilesUnderRetentionForAssignment(assignmentID, options, callback) {
|
|
319
|
+
var apiPath = (0, url_path_1.default)(ASSIGNMENTS_PATH, assignmentID, FILES_UNDER_RETENTION_SUBRESOURCE), params = {
|
|
320
|
+
qs: options,
|
|
321
|
+
};
|
|
322
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Get file versions under retention by each assignment
|
|
326
|
+
* To use this feature, you must have the manage retention policies scope enabled
|
|
327
|
+
* for your API key via your application management console.
|
|
328
|
+
*
|
|
329
|
+
* API Endpoint: '/retention_policy_assignments/:assignmentID/file_versions_under_retention'
|
|
330
|
+
* Method: GET
|
|
331
|
+
*
|
|
332
|
+
* @param {string} assignmentID - The Box ID of the policy assignment object to fetch
|
|
333
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
334
|
+
* @param {int} [options.limit] - The maximum number of items to return in a page
|
|
335
|
+
* @param {string} [options.marker] - Paging marker, left blank to begin paging from the beginning
|
|
336
|
+
* @param {Function} [callback] - Pass the file version retention record if successful, error otherwise
|
|
337
|
+
* @returns {Promise<Object>} A promise resolving to the collection of retention records
|
|
338
|
+
*/
|
|
339
|
+
getFileVersionsUnderRetentionForAssignment(assignmentID, options, callback) {
|
|
340
|
+
var apiPath = (0, url_path_1.default)(ASSIGNMENTS_PATH, assignmentID, FILES_VERSIONS_UNDER_RETENTION_SUBRESOURCE), params = {
|
|
341
|
+
qs: options,
|
|
342
|
+
};
|
|
343
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
/**
|
|
347
|
+
* Enum of valid retention policy types, which specify how long the policy should
|
|
348
|
+
* remain in effect.
|
|
349
|
+
* @readonly
|
|
350
|
+
* @enum {RetentionPolicyType}
|
|
351
|
+
*/
|
|
352
|
+
RetentionPolicies.prototype.policyTypes = RetentionPolicyType;
|
|
353
|
+
/**
|
|
354
|
+
* Enum of valid retention policy disposition actions, which specify what should
|
|
355
|
+
* be done when the retention period is over
|
|
356
|
+
* @readonly
|
|
357
|
+
* @enum {RetentionPolicyDispositionAction}
|
|
358
|
+
*/
|
|
359
|
+
RetentionPolicies.prototype.dispositionActions =
|
|
360
|
+
RetentionPolicyDispositionAction;
|
|
361
|
+
/**
|
|
362
|
+
* Enum of valid policy assignment types, which specify what object the policy applies to
|
|
363
|
+
* @readonly
|
|
364
|
+
* @enum {RetentionPolicyAssignmentType}
|
|
365
|
+
*/
|
|
366
|
+
RetentionPolicies.prototype.assignmentTypes = RetentionPolicyAssignmentType;
|
|
367
|
+
/**
|
|
368
|
+
* Enum of valid retention types. Could be either modifiable or non-modifiable.
|
|
369
|
+
* @readonly
|
|
370
|
+
* @enum {RetentionType}
|
|
371
|
+
*/
|
|
372
|
+
RetentionPolicies.prototype.retentionTypes = RetentionType;
|
|
373
|
+
module.exports = RetentionPolicies;
|
|
374
|
+
//# sourceMappingURL=retention-policies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retention-policies.js","sourceRoot":"","sources":["../../src/managers/retention-policies.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Manager for the Box Search Resource
|
|
3
|
+
*/
|
|
4
|
+
import BoxClient from '../box-client';
|
|
5
|
+
/**
|
|
6
|
+
* Search metadata filter
|
|
7
|
+
* @typedef {Object} SearchMetadataFilter
|
|
8
|
+
* @property {string} templateKey The template to filter against
|
|
9
|
+
* @property {string} scope The scope of the template, e.g. 'global' or 'enterprise'
|
|
10
|
+
* @property {Object} filters Key/value filters against individual metadata template properties
|
|
11
|
+
*/
|
|
12
|
+
type SearchMetadataFilter = {
|
|
13
|
+
templateKey: string;
|
|
14
|
+
scope: string;
|
|
15
|
+
filters: Record<string, any>;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Valid search scopes
|
|
19
|
+
* @readonly
|
|
20
|
+
* @enum {SearchScope}
|
|
21
|
+
*/
|
|
22
|
+
declare enum SearchScope {
|
|
23
|
+
USER = "user_content",
|
|
24
|
+
ENTERPRISE = "enterprise_content"
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Simple manager for interacting with the search endpoints and actions.
|
|
28
|
+
*
|
|
29
|
+
* @constructor
|
|
30
|
+
* @param {BoxClient} client - The Box API Client that is responsible for making calls to the API
|
|
31
|
+
* @returns {void}
|
|
32
|
+
*/
|
|
33
|
+
declare class Search {
|
|
34
|
+
client: BoxClient;
|
|
35
|
+
scopes: typeof SearchScope;
|
|
36
|
+
constructor(client: BoxClient);
|
|
37
|
+
/**
|
|
38
|
+
* Searches Box for the given query.
|
|
39
|
+
*
|
|
40
|
+
* @param {string} searchString - The query string to use for search
|
|
41
|
+
* @param {Object} [options] - Additional search filters. Can be left null in most cases.
|
|
42
|
+
* @param {SearchScope} [options.scope] - The scope on which you want search. Can be user_content for a search limited to the current user or enterprise_content to search an entire enterprise
|
|
43
|
+
* @param {string} [options.file_extensions] - Single or comma-delimited list of file extensions to filter against
|
|
44
|
+
* @param {string} [options.created_at_range] - Date range for filtering on item creation time, e.g. '2014-05-15T13:35:01-07:00,2014-05-17T13:35:01-07:00'
|
|
45
|
+
* @param {string} [options.updated_at_range] - Date range for filtering on item update time, e.g. '2014-05-15T13:35:01-07:00,2014-05-17T13:35:01-07:00'
|
|
46
|
+
* @param {string} [options.size_range] - Range of item sizes (in bytes) to filter on, as lower_bound,upper_bound. Either bound can be ommitted, e.g. ',100000' for <= 100KB
|
|
47
|
+
* @param {string} [options.owner_user_ids] - Comma-delimited list of user IDs to filter item owner against
|
|
48
|
+
* @param {string} [options.ancestor_folder_ids] - Comma-delimited list of folder IDs, search results will contain only items in these folders (and folders within them)
|
|
49
|
+
* @param {string} [options.content_types] - Query within specified comma-delimited fields. The types can be name, description, file_content, comments, or tags
|
|
50
|
+
* @param {string} [options.type] - The type of objects you want to include in the search results. The type can be file, folder, or web_link
|
|
51
|
+
* @param {string} [options.trash_content=non_trashed_only] - Controls whether to search in the trash. The value can be trashed_only or non_trashed_only
|
|
52
|
+
* @param {SearchMetadataFilter[]} [options.mdfilters] - Searches for objects with a specific metadata object association. Searches with this parameter do not require a query string
|
|
53
|
+
* @param {boolean} [options.include_recent_shared_links] - Determines whether to include items accessible only via shared link in the response.
|
|
54
|
+
* @param {string} [options.fields] - Comma-delimited list of fields to be included in the response
|
|
55
|
+
* @param {int} [options.limit=30] - The number of search results to return, max 200
|
|
56
|
+
* @param {int} [options.offset=0] - The search result at which to start the response, must be a multiple of limit
|
|
57
|
+
* @param {string} [options.sort] - The field on which the results should be sorted, e.g. "modified_at"
|
|
58
|
+
* @param {string} [options.direction] - The sort direction: "ASC" for ascending and "DESC" for descending
|
|
59
|
+
* @param {APIRequest~Callback} [callback] - passed the new comment data if it was posted successfully
|
|
60
|
+
* @returns {Promise<Object>} A promise resolving to the collection of search results
|
|
61
|
+
*/
|
|
62
|
+
query(searchString: string, options?: {
|
|
63
|
+
scope?: SearchScope;
|
|
64
|
+
file_extensions?: string;
|
|
65
|
+
created_at_range?: string;
|
|
66
|
+
updated_at_range?: string;
|
|
67
|
+
size_range?: string;
|
|
68
|
+
owner_user_ids?: string;
|
|
69
|
+
ancestor_folder_ids?: string;
|
|
70
|
+
content_types?: string;
|
|
71
|
+
type?: string;
|
|
72
|
+
trash_content?: string;
|
|
73
|
+
mdfilters?: SearchMetadataFilter[] | string;
|
|
74
|
+
include_recent_shared_links?: boolean;
|
|
75
|
+
fields?: string;
|
|
76
|
+
limit?: number;
|
|
77
|
+
offset?: number;
|
|
78
|
+
sort?: string;
|
|
79
|
+
direction?: string;
|
|
80
|
+
}, callback?: Function): any;
|
|
81
|
+
}
|
|
82
|
+
export = Search;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @fileoverview Manager for the Box Search Resource
|
|
4
|
+
*/
|
|
5
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
6
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
7
|
+
};
|
|
8
|
+
// -----------------------------------------------------------------------------
|
|
9
|
+
// Requirements
|
|
10
|
+
// -----------------------------------------------------------------------------
|
|
11
|
+
const bluebird_1 = require("bluebird");
|
|
12
|
+
const url_path_1 = __importDefault(require("../util/url-path"));
|
|
13
|
+
/**
|
|
14
|
+
* Valid search scopes
|
|
15
|
+
* @readonly
|
|
16
|
+
* @enum {SearchScope}
|
|
17
|
+
*/
|
|
18
|
+
var SearchScope;
|
|
19
|
+
(function (SearchScope) {
|
|
20
|
+
SearchScope["USER"] = "user_content";
|
|
21
|
+
SearchScope["ENTERPRISE"] = "enterprise_content";
|
|
22
|
+
})(SearchScope || (SearchScope = {}));
|
|
23
|
+
// -----------------------------------------------------------------------------
|
|
24
|
+
// Private
|
|
25
|
+
// -----------------------------------------------------------------------------
|
|
26
|
+
var API_PATHS_SEARCH = '/search';
|
|
27
|
+
// -----------------------------------------------------------------------------
|
|
28
|
+
// Public
|
|
29
|
+
// -----------------------------------------------------------------------------
|
|
30
|
+
/**
|
|
31
|
+
* Simple manager for interacting with the search endpoints and actions.
|
|
32
|
+
*
|
|
33
|
+
* @constructor
|
|
34
|
+
* @param {BoxClient} client - The Box API Client that is responsible for making calls to the API
|
|
35
|
+
* @returns {void}
|
|
36
|
+
*/
|
|
37
|
+
class Search {
|
|
38
|
+
constructor(client) {
|
|
39
|
+
this.client = client;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Searches Box for the given query.
|
|
43
|
+
*
|
|
44
|
+
* @param {string} searchString - The query string to use for search
|
|
45
|
+
* @param {Object} [options] - Additional search filters. Can be left null in most cases.
|
|
46
|
+
* @param {SearchScope} [options.scope] - The scope on which you want search. Can be user_content for a search limited to the current user or enterprise_content to search an entire enterprise
|
|
47
|
+
* @param {string} [options.file_extensions] - Single or comma-delimited list of file extensions to filter against
|
|
48
|
+
* @param {string} [options.created_at_range] - Date range for filtering on item creation time, e.g. '2014-05-15T13:35:01-07:00,2014-05-17T13:35:01-07:00'
|
|
49
|
+
* @param {string} [options.updated_at_range] - Date range for filtering on item update time, e.g. '2014-05-15T13:35:01-07:00,2014-05-17T13:35:01-07:00'
|
|
50
|
+
* @param {string} [options.size_range] - Range of item sizes (in bytes) to filter on, as lower_bound,upper_bound. Either bound can be ommitted, e.g. ',100000' for <= 100KB
|
|
51
|
+
* @param {string} [options.owner_user_ids] - Comma-delimited list of user IDs to filter item owner against
|
|
52
|
+
* @param {string} [options.ancestor_folder_ids] - Comma-delimited list of folder IDs, search results will contain only items in these folders (and folders within them)
|
|
53
|
+
* @param {string} [options.content_types] - Query within specified comma-delimited fields. The types can be name, description, file_content, comments, or tags
|
|
54
|
+
* @param {string} [options.type] - The type of objects you want to include in the search results. The type can be file, folder, or web_link
|
|
55
|
+
* @param {string} [options.trash_content=non_trashed_only] - Controls whether to search in the trash. The value can be trashed_only or non_trashed_only
|
|
56
|
+
* @param {SearchMetadataFilter[]} [options.mdfilters] - Searches for objects with a specific metadata object association. Searches with this parameter do not require a query string
|
|
57
|
+
* @param {boolean} [options.include_recent_shared_links] - Determines whether to include items accessible only via shared link in the response.
|
|
58
|
+
* @param {string} [options.fields] - Comma-delimited list of fields to be included in the response
|
|
59
|
+
* @param {int} [options.limit=30] - The number of search results to return, max 200
|
|
60
|
+
* @param {int} [options.offset=0] - The search result at which to start the response, must be a multiple of limit
|
|
61
|
+
* @param {string} [options.sort] - The field on which the results should be sorted, e.g. "modified_at"
|
|
62
|
+
* @param {string} [options.direction] - The sort direction: "ASC" for ascending and "DESC" for descending
|
|
63
|
+
* @param {APIRequest~Callback} [callback] - passed the new comment data if it was posted successfully
|
|
64
|
+
* @returns {Promise<Object>} A promise resolving to the collection of search results
|
|
65
|
+
*/
|
|
66
|
+
query(searchString, options, callback) {
|
|
67
|
+
var apiPath = (0, url_path_1.default)(API_PATHS_SEARCH), qs = options || {};
|
|
68
|
+
qs.query = searchString;
|
|
69
|
+
if (qs.mdfilters) {
|
|
70
|
+
if (Array.isArray(qs.mdfilters)) {
|
|
71
|
+
qs.mdfilters = JSON.stringify(qs.mdfilters);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
return bluebird_1.Promise.reject(new Error('Invalid mdfilters parameter: must be a valid array')).asCallback(callback);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
var params = {
|
|
78
|
+
qs,
|
|
79
|
+
};
|
|
80
|
+
return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Valid search scopes
|
|
85
|
+
* @readonly
|
|
86
|
+
* @enum {SearchScope}
|
|
87
|
+
*/
|
|
88
|
+
Search.prototype.scopes = SearchScope;
|
|
89
|
+
module.exports = Search;
|
|
90
|
+
//# sourceMappingURL=search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../src/managers/search.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;AAEH,gFAAgF;AAChF,eAAe;AACf,gFAAgF;AAEhF,uCAAmC;AAEnC,gEAAuC;AAmBvC;;;;GAIG;AACH,IAAK,WAGJ;AAHD,WAAK,WAAW;IACd,oCAAqB,CAAA;IACrB,gDAAiC,CAAA;AACnC,CAAC,EAHI,WAAW,KAAX,WAAW,QAGf;AAKD,gFAAgF;AAChF,UAAU;AACV,gFAAgF;AAEhF,IAAI,gBAAgB,GAAG,SAAS,CAAC;AAEjC,gFAAgF;AAChF,SAAS;AACT,gFAAgF;AAEhF;;;;;;GAMG;AACH,MAAM,MAAM;IAIV,YAAY,MAAiB;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;OAwBG;IACH,KAAK,CACH,YAAoB,EACpB,OAkBC,EACD,QAAmB;QAEnB,IAAI,OAAO,GAAG,IAAA,kBAAO,EAAC,gBAAgB,CAAC,EACrC,EAAE,GAEE,OAAO,IAAK,EAA0B,CAAC;QAE7C,EAAE,CAAC,KAAK,GAAG,YAAY,CAAC;QAExB,IAAI,EAAE,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC;gBAChC,EAAE,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;YAC9C,CAAC;iBAAM,CAAC;gBACN,OAAO,kBAAO,CAAC,MAAM,CACnB,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAChE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QAED,IAAI,MAAM,GAAG;YACX,EAAE;SACH,CAAC;QACF,OAAO,IAAI,CAAC,MAAM,CAAC,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CACxD,OAAO,EACP,MAAM,EACN,QAAQ,CACT,CAAC;IACJ,CAAC;CACF;AAED;;;;GAIG;AACH,MAAM,CAAC,SAAS,CAAC,MAAM,GAAG,WAAW,CAAC;AAEtC,iBAAS,MAAM,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Manager for the Shared Items
|
|
3
|
+
*/
|
|
4
|
+
import BoxClient from '../box-client';
|
|
5
|
+
/**
|
|
6
|
+
* Simple manager for interacting with all 'Shared Item' endpoints and actions.
|
|
7
|
+
*
|
|
8
|
+
* @constructor
|
|
9
|
+
* @param {BoxClient} client - The Box API Client that is responsible for making calls to the API
|
|
10
|
+
* @returns {void}
|
|
11
|
+
*/
|
|
12
|
+
declare class SharedItems {
|
|
13
|
+
client: BoxClient;
|
|
14
|
+
constructor(client: BoxClient);
|
|
15
|
+
/**
|
|
16
|
+
* Requests a Box item associated with a shared link.
|
|
17
|
+
*
|
|
18
|
+
* API Endpoint: '/shared_items'
|
|
19
|
+
* Method: GET
|
|
20
|
+
*
|
|
21
|
+
* @param {string} url - Shared Link URL
|
|
22
|
+
* @param {string} [password] - Shared Link Password (null if no password)
|
|
23
|
+
* @param {Object} [options] - Additional options for the request. Can be left null in most cases.
|
|
24
|
+
* @param {Function} [callback] - passed the shared item if it was successfully acquired
|
|
25
|
+
* @returns {Promise<Object>} A promise resolving to the shared item object
|
|
26
|
+
*/
|
|
27
|
+
get(url: string, password: string, options?: Record<string, any>, callback?: Function): any;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* @module box-node-sdk/lib/managers/shared-items
|
|
31
|
+
* @see {@Link SharedItems}
|
|
32
|
+
*/
|
|
33
|
+
export = SharedItems;
|