mirror of
https://github.com/LukeHagar/plexjs.git
synced 2025-12-06 04:20:46 +00:00
237 lines
6.8 KiB
TypeScript
237 lines
6.8 KiB
TypeScript
/*
|
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
*/
|
|
|
|
import { PlexAPICore } from "../core.js";
|
|
import { encodeFormQuery, encodeSimple } from "../lib/encodings.js";
|
|
import * as M from "../lib/matchers.js";
|
|
import { compactMap } from "../lib/primitives.js";
|
|
import { safeParse } from "../lib/schemas.js";
|
|
import { RequestOptions } from "../lib/sdks.js";
|
|
import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
|
|
import { pathToFunc } from "../lib/url.js";
|
|
import {
|
|
ConnectionError,
|
|
InvalidRequestError,
|
|
RequestAbortedError,
|
|
RequestTimeoutError,
|
|
UnexpectedClientError,
|
|
} from "../models/errors/httpclienterrors.js";
|
|
import { PlexAPIError } from "../models/errors/plexapierror.js";
|
|
import { ResponseValidationError } from "../models/errors/responsevalidationerror.js";
|
|
import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
|
|
import * as operations from "../models/operations/index.js";
|
|
import { APICall, APIPromise } from "../types/async.js";
|
|
import { Result } from "../types/fp.js";
|
|
|
|
export enum GetFileAcceptEnum {
|
|
audioMpeg3 = "audio/mpeg3",
|
|
imageJpeg = "image/jpeg",
|
|
}
|
|
|
|
/**
|
|
* Get a file from a metadata or media bundle
|
|
*
|
|
* @remarks
|
|
* Get a bundle file for a metadata or media item. This is either an image or a mp3 (for a show's theme)
|
|
*/
|
|
export function libraryGetFile(
|
|
client: PlexAPICore,
|
|
request: operations.GetFileRequest,
|
|
options?: RequestOptions & { acceptHeaderOverride?: GetFileAcceptEnum },
|
|
): APIPromise<
|
|
Result<
|
|
operations.GetFileResponse,
|
|
| PlexAPIError
|
|
| ResponseValidationError
|
|
| ConnectionError
|
|
| RequestAbortedError
|
|
| RequestTimeoutError
|
|
| InvalidRequestError
|
|
| UnexpectedClientError
|
|
| SDKValidationError
|
|
>
|
|
> {
|
|
return new APIPromise($do(
|
|
client,
|
|
request,
|
|
options,
|
|
));
|
|
}
|
|
|
|
async function $do(
|
|
client: PlexAPICore,
|
|
request: operations.GetFileRequest,
|
|
options?: RequestOptions & { acceptHeaderOverride?: GetFileAcceptEnum },
|
|
): Promise<
|
|
[
|
|
Result<
|
|
operations.GetFileResponse,
|
|
| PlexAPIError
|
|
| ResponseValidationError
|
|
| ConnectionError
|
|
| RequestAbortedError
|
|
| RequestTimeoutError
|
|
| InvalidRequestError
|
|
| UnexpectedClientError
|
|
| SDKValidationError
|
|
>,
|
|
APICall,
|
|
]
|
|
> {
|
|
const parsed = safeParse(
|
|
request,
|
|
(value) => operations.GetFileRequest$outboundSchema.parse(value),
|
|
"Input validation failed",
|
|
);
|
|
if (!parsed.ok) {
|
|
return [parsed, { status: "invalid" }];
|
|
}
|
|
const payload = parsed.value;
|
|
const body = null;
|
|
|
|
const pathParams = {
|
|
ids: encodeSimple("ids", payload.ids, {
|
|
explode: false,
|
|
charEncoding: "percent",
|
|
}),
|
|
};
|
|
|
|
const path = pathToFunc("/library/metadata/{ids}/file")(pathParams);
|
|
|
|
const query = encodeFormQuery({
|
|
"url": payload.url,
|
|
});
|
|
|
|
const headers = new Headers(compactMap({
|
|
Accept: options?.acceptHeaderOverride || "audio/mpeg3;q=1, image/jpeg;q=0",
|
|
"X-Plex-Client-Identifier": encodeSimple(
|
|
"X-Plex-Client-Identifier",
|
|
payload["Client-Identifier"] ?? client._options.clientIdentifier,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Device": encodeSimple(
|
|
"X-Plex-Device",
|
|
payload.Device ?? client._options.device,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Device-Name": encodeSimple(
|
|
"X-Plex-Device-Name",
|
|
payload["Device-Name"] ?? client._options.deviceName,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Device-Vendor": encodeSimple(
|
|
"X-Plex-Device-Vendor",
|
|
payload["Device-Vendor"] ?? client._options.deviceVendor,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Marketplace": encodeSimple(
|
|
"X-Plex-Marketplace",
|
|
payload.Marketplace ?? client._options.marketplace,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Model": encodeSimple(
|
|
"X-Plex-Model",
|
|
payload.Model ?? client._options.model,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Platform": encodeSimple(
|
|
"X-Plex-Platform",
|
|
payload.Platform ?? client._options.platform,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Platform-Version": encodeSimple(
|
|
"X-Plex-Platform-Version",
|
|
payload["Platform-Version"] ?? client._options.platformVersion,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Product": encodeSimple(
|
|
"X-Plex-Product",
|
|
payload.Product ?? client._options.product,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"X-Plex-Version": encodeSimple(
|
|
"X-Plex-Version",
|
|
payload.Version ?? client._options.version,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
"accepts": encodeSimple(
|
|
"accepts",
|
|
payload.accepts ?? client._options.accepts,
|
|
{ explode: false, charEncoding: "none" },
|
|
),
|
|
}));
|
|
|
|
const secConfig = await extractSecurity(client._options.token);
|
|
const securityInput = secConfig == null ? {} : { token: secConfig };
|
|
const requestSecurity = resolveGlobalSecurity(securityInput);
|
|
|
|
const context = {
|
|
options: client._options,
|
|
baseURL: options?.serverURL ?? client._baseURL ?? "",
|
|
operationID: "getFile",
|
|
oAuth2Scopes: null,
|
|
|
|
resolvedSecurity: requestSecurity,
|
|
|
|
securitySource: client._options.token,
|
|
retryConfig: options?.retries
|
|
|| client._options.retryConfig
|
|
|| { strategy: "none" },
|
|
retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
|
|
};
|
|
|
|
const requestRes = client._createRequest(context, {
|
|
security: requestSecurity,
|
|
method: "GET",
|
|
baseURL: options?.serverURL,
|
|
path: path,
|
|
headers: headers,
|
|
query: query,
|
|
body: body,
|
|
userAgent: client._options.userAgent,
|
|
timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
|
|
}, options);
|
|
if (!requestRes.ok) {
|
|
return [requestRes, { status: "invalid" }];
|
|
}
|
|
const req = requestRes.value;
|
|
|
|
const doResult = await client._do(req, {
|
|
context,
|
|
errorCodes: ["4XX", "5XX"],
|
|
retryConfig: context.retryConfig,
|
|
retryCodes: context.retryCodes,
|
|
});
|
|
if (!doResult.ok) {
|
|
return [doResult, { status: "request-error", request: req }];
|
|
}
|
|
const response = doResult.value;
|
|
|
|
const [result] = await M.match<
|
|
operations.GetFileResponse,
|
|
| PlexAPIError
|
|
| ResponseValidationError
|
|
| ConnectionError
|
|
| RequestAbortedError
|
|
| RequestTimeoutError
|
|
| InvalidRequestError
|
|
| UnexpectedClientError
|
|
| SDKValidationError
|
|
>(
|
|
M.stream(200, operations.GetFileResponse$inboundSchema, {
|
|
ctype: "audio/mpeg3",
|
|
}),
|
|
M.stream(200, operations.GetFileResponse$inboundSchema, {
|
|
ctype: "image/jpeg",
|
|
}),
|
|
M.fail("4XX"),
|
|
M.fail("5XX"),
|
|
)(response, req);
|
|
if (!result.ok) {
|
|
return [result, { status: "complete", request: req, response }];
|
|
}
|
|
|
|
return [result, { status: "complete", request: req, response }];
|
|
}
|