{"version":3,"file":"revisions.cjs","names":[],"sources":["../../../../src/rest/commands/read/revisions.ts"],"sourcesContent":["import type { DirectusRevision } from '../../../schema/revision.js';\nimport type { ApplyQueryFields, Query } from '../../../types/index.js';\nimport type { RestCommand } from '../../types.js';\nimport { throwIfEmpty } from '../../utils/index.js';\n\nexport type ReadRevisionOutput<\n\tSchema,\n\tTQuery extends Query<Schema, Item>,\n\tItem extends object = DirectusRevision<Schema>,\n> = ApplyQueryFields<Schema, Item, TQuery['fields']>;\n\n/**\n * List all Revisions that exist in Directus.\n * @param query The query parameters\n * @returns An array of up to limit Revision objects. If no items are available, data will be an empty array.\n */\nexport const readRevisions =\n\t<Schema, const TQuery extends Query<Schema, DirectusRevision<Schema>>>(\n\t\tquery?: TQuery,\n\t): RestCommand<ReadRevisionOutput<Schema, TQuery>[], Schema> =>\n\t() => ({\n\t\tpath: `/revisions`,\n\t\tparams: query ?? {},\n\t\tmethod: 'GET',\n\t});\n\n/**\n * List an existing Revision by primary key.\n * @param key The primary key of the dashboard\n * @param query The query parameters\n * @returns Returns a Revision object if a valid primary key was provided.\n * @throws Will throw if key is empty\n */\nexport const readRevision =\n\t<Schema, const TQuery extends Query<Schema, DirectusRevision<Schema>>>(\n\t\tkey: DirectusRevision<Schema>['id'],\n\t\tquery?: TQuery,\n\t): RestCommand<ReadRevisionOutput<Schema, TQuery>, Schema> =>\n\t() => {\n\t\tthrowIfEmpty(String(key), 'Key cannot be empty');\n\n\t\treturn {\n\t\t\tpath: `/revisions/${key}`,\n\t\t\tparams: query ?? {},\n\t\t\tmethod: 'GET',\n\t\t};\n\t};\n"],"mappings":"kDAgBa,EAEX,QAEM,CACN,KAAM,aACN,OAAQ,GAAS,EAAE,CACnB,OAAQ,MACR,EASW,GAEX,EACA,SAGA,EAAA,aAAa,OAAO,EAAI,CAAE,sBAAsB,CAEzC,CACN,KAAM,cAAc,IACpB,OAAQ,GAAS,EAAE,CACnB,OAAQ,MACR"}