files.mjs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
  2. import { APIResource } from "../../../resource.mjs";
  3. import { isRequestOptions } from "../../../core.mjs";
  4. import * as Core from "../../../core.mjs";
  5. import * as ContentAPI from "./content.mjs";
  6. import { Content } from "./content.mjs";
  7. import { CursorPage } from "../../../pagination.mjs";
  8. export class Files extends APIResource {
  9. constructor() {
  10. super(...arguments);
  11. this.content = new ContentAPI.Content(this._client);
  12. }
  13. /**
  14. * Create a Container File
  15. *
  16. * You can send either a multipart/form-data request with the raw file content, or
  17. * a JSON request with a file ID.
  18. */
  19. create(containerId, body, options) {
  20. return this._client.post(`/containers/${containerId}/files`, Core.multipartFormRequestOptions({ body, ...options }));
  21. }
  22. /**
  23. * Retrieve Container File
  24. */
  25. retrieve(containerId, fileId, options) {
  26. return this._client.get(`/containers/${containerId}/files/${fileId}`, options);
  27. }
  28. list(containerId, query = {}, options) {
  29. if (isRequestOptions(query)) {
  30. return this.list(containerId, {}, query);
  31. }
  32. return this._client.getAPIList(`/containers/${containerId}/files`, FileListResponsesPage, {
  33. query,
  34. ...options,
  35. });
  36. }
  37. /**
  38. * Delete Container File
  39. */
  40. del(containerId, fileId, options) {
  41. return this._client.delete(`/containers/${containerId}/files/${fileId}`, {
  42. ...options,
  43. headers: { Accept: '*/*', ...options?.headers },
  44. });
  45. }
  46. }
  47. export class FileListResponsesPage extends CursorPage {
  48. }
  49. Files.FileListResponsesPage = FileListResponsesPage;
  50. Files.Content = Content;
  51. //# sourceMappingURL=files.mjs.map