@wistia/wistia-api-client
v2026.3.3
Published
<div align="center"> <img width="500" height="300" alt="image" src="https://github.com/user-attachments/assets/e4169a55-3c50-41a7-a44e-3a2114b530b1" /> <h1>Wistia TypeScript SDK</h1> <p>Developer-friendly TypeScript SDK specifically catered to
Downloads
1,979
Keywords
Readme
Summary
The Wistia TypeScript SDK provides comprehensive programmatic access to the Wistia Data, stats, and upload API, enabling developers to integrate with Wistia's video hosting and marketing platform. The SDK supports core video management operations including media upload, organization within projects and subfolders, caption and localization management, analytics and stats retrieval, live streaming events, and domain security controls.
Server-side only
Important: Please do not use this library in a client context, as exposing bearer tokens in client-side applications is inherently insecure.
Official docs
For complete API documentation and platform guides, please visit docs.wistia.com.
Version note
This SDK wrapper is currently in beta; functionality is subject to change. When released, the API will use a date-based versioning system instead of (but compliant with) SemVer.
Table of Contents
- Server-side only
- Official docs
- Version note
- SDK Installation
- Requirements
- SDK Example Usage
- Authentication
- Available Resources and Operations
- Standalone functions
- File uploads
- Retries
- Error Handling
- Server Selection
- Custom HTTP Client
- Debugging
- Development
SDK Installation
The SDK can be installed with either npm, pnpm, bun or yarn package managers.
NPM
npm add @wistia/wistia-api-clientPNPM
pnpm add @wistia/wistia-api-clientBun
bun add @wistia/wistia-api-clientYarn
yarn add @wistia/wistia-api-client[!NOTE] This package is published with CommonJS and ES Modules (ESM) support.
Requirements
For supported JavaScript runtimes, please consult RUNTIMES.md.
SDK Example Usage
Example
import { Wistia } from "@wistia/wistia-api-client";
const wistia = new Wistia({
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
const result = await wistia.media.uploadForm({
url:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
lowPriority: true,
});
console.log(result);
}
run();
Authentication
Per-Client Security Schemes
This SDK supports the following security scheme globally:
| Name | Type | Scheme | Environment Variable |
| ------------ | ---- | ----------- | -------------------- |
| bearerAuth | http | HTTP Bearer | WISTIA_BEARER_AUTH |
To authenticate with the API the bearerAuth parameter must be set when initializing the SDK client instance. For example:
import { Wistia } from "@wistia/wistia-api-client";
const wistia = new Wistia({
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
const result = await wistia.media.uploadForm({
url:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
lowPriority: true,
});
console.log(result);
}
run();
Available Resources and Operations
Account
- get - Get Current Account
- getTokenDetails - Get Current Token
AllowedDomains
- list - List Allowed Domains
- create - Create Allowed Domain
- get - Show Allowed Domain
- delete - Delete Allowed Domain
AnalyticsMedia
- getAnalyticsMediasMediaId - Show Media Analytics
- getAnalyticsMediasMediaIdTimeseries - Show Media Analytics Timeseries
- getAnalyticsMediasMediaIdEmbedLocations - Show Media Embed Locations
- getAnalyticsMediasMediaIdTraffic - Show Media Traffic Breakdown
- getAnalyticsMediasMediaIdConversions - Show Media Form Conversions
- getAnalyticsMediasMediaIdLanguages - Show Media Languages
AnalyticsWebinar
- getAnalyticsWebinarsWebinarId - Show Webinar Analytics
- getAnalyticsWebinarsWebinarIdRegistration - Show Webinar Registration Timeseries
- getAnalyticsWebinarsWebinarIdTraffic - Show Webinar Traffic Breakdown
- getAnalyticsWebinarsWebinarIdAudience - Show Webinar Audience
- getAnalyticsWebinarsWebinarIdHistograms - Show Webinar Histograms
BackgroundJobStatus
- get - Show Background Job Status
Captions
- list - List Captions by Media
- create - Create Captions
- createMultipart - Create Captions
- getCaptions - List Captions
- purchase - Purchase Captions
- get - Show Captions
- update - Update Captions
- updateMultipart - Update Captions
- delete - Delete Captions
ChannelEpisodes
- get - Show Channel Episode
- create - Create Channel Episode
- list - List Channel Episodes
- putChannelEpisodesChannelEpisodeHashedId - Update Channel Episode
- deleteChannelEpisodesChannelEpisodeHashedId - Delete Channel Episode
- putChannelEpisodesChannelEpisodeHashedIdPublish - Publish Channel Episode
- putChannelEpisodesChannelEpisodeHashedIdUnpublish - Un-publish Channel Episode
Channels
- list - List Channels
- postChannels - Create Channel
- get - Show Channel
- putChannelsChannelHashedId - Update Channel
- deleteChannelsChannelHashedId - Delete Channel
Channels.ChannelEpisodes
- list - List Channel Episodes by Channel
Customizations
- get - Show Customizations
- create - Create Customizations
- update - Update Customizations
- delete - Delete Customizations
ExpiringAccessTokens
- create - Create Expiring Access Token
FolderSharings
- getFoldersFolderIdSharings - List Folder Sharings
- postFoldersFolderIdSharings - Create Folder Sharing
- getFoldersFolderIdSharingsSharingId - Show Folder Sharing
- putFoldersFolderIdSharingsSharingId - Update Folder Sharing
- deleteFoldersFolderIdSharingsSharingId - Delete Folder Sharing
Folders
- getFolders - List Folders
- postFolders - Create Folder
- getFoldersId - Show Folder
- putFoldersId - Update Folder
- deleteFoldersId - Delete Folder
- postFoldersIdCopy - Copy Folder
Localizations
- list - List Localizations
- create - Create Localization
- get - Show Localization
- delete - Delete Localization
Media
- uploadForm - Upload or Import Media
- uploadMultipart - Upload or Import Media
- list - List Media
- get - Show Media
- update - Update Media
- delete - Delete Media
- copy - Copy Media
- swap - Swap Media
- getStats - Show Media Aggregated Stats
- translate - Translate Media
- postMediasImportUrl - Import Media from URL
- archive - Archive Media
- move - Move Media
- restore - Restore Media
- putMediasCopy - Bulk Copy Media
MediaExtendedAudioDescriptions
- getMediaExtendedAudioDescriptions - List Media Extended Audio Descriptions
- getMediaExtendedAudioDescriptionsId - Show Media Extended Audio Description
- deleteMediaExtendedAudioDescriptionsId - Delete Media Extended Audio Description
- postMediaExtendedAudioDescriptionsOrder - Order Extended Audio Description
- getMediaExtendedAudioDescriptionsOrderStatusId - Get Order Status
Search
- search - Search
StatsAccount
- get - Show Current Account Stats
- getStatsAccountByDate - Show Account Stats by Date
StatsEvents
StatsMedia
- get - Show Media Stats
- getByDate - Show Media Stats by Date
- getEngagement - Show Media Engagement
StatsProjects
- get - Show Project Stats
StatsVisitors
Subfolders
- getFoldersFolderIdSubfolders - List Subfolders
- postFoldersFolderIdSubfolders - Create Subfolder
- getFoldersFolderIdSubfoldersSubfolderId - Show Subfolder
- putFoldersFolderIdSubfoldersSubfolderId - Update Subfolder
- deleteFoldersFolderIdSubfoldersSubfolderId - Delete Subfolder
- deleteFoldersFolderIdSubfoldersBulkDelete - Bulk Delete Subfolders
Taggings
- postTaggingsBulkCreate - Bulk Tag Media
Tags
Trims
- create - Create Media from Trims
WebinarRegistrations
- postWebinarsWebinarIdRegistrations - Create Webinar Registration
Webinars
- getWebinars - List Webinars
- postWebinars - Create Webinar
- getWebinarsId - Show Webinar
- putWebinarsId - Update Webinar
- deleteWebinarsId - Delete Webinar
Standalone functions
All the methods listed above are available as standalone functions. These functions are ideal for use in applications running in the browser, serverless runtimes or other environments where application bundle size is a primary concern. When using a bundler to build your application, all unused functionality will be either excluded from the final bundle or tree-shaken away.
To read more about standalone functions, check FUNCTIONS.md.
accountGet- Get Current AccountaccountGetTokenDetails- Get Current TokenallowedDomainsCreate- Create Allowed DomainallowedDomainsDelete- Delete Allowed DomainallowedDomainsGet- Show Allowed DomainallowedDomainsList- List Allowed DomainsanalyticsMediaGetAnalyticsMediasMediaId- Show Media AnalyticsanalyticsMediaGetAnalyticsMediasMediaIdConversions- Show Media Form ConversionsanalyticsMediaGetAnalyticsMediasMediaIdEmbedLocations- Show Media Embed LocationsanalyticsMediaGetAnalyticsMediasMediaIdLanguages- Show Media LanguagesanalyticsMediaGetAnalyticsMediasMediaIdTimeseries- Show Media Analytics TimeseriesanalyticsMediaGetAnalyticsMediasMediaIdTraffic- Show Media Traffic BreakdownanalyticsWebinarGetAnalyticsWebinarsWebinarId- Show Webinar AnalyticsanalyticsWebinarGetAnalyticsWebinarsWebinarIdAudience- Show Webinar AudienceanalyticsWebinarGetAnalyticsWebinarsWebinarIdHistograms- Show Webinar HistogramsanalyticsWebinarGetAnalyticsWebinarsWebinarIdRegistration- Show Webinar Registration TimeseriesanalyticsWebinarGetAnalyticsWebinarsWebinarIdTraffic- Show Webinar Traffic BreakdownbackgroundJobStatusGet- Show Background Job StatuscaptionsCreate- Create CaptionscaptionsCreateMultipart- Create CaptionscaptionsDelete- Delete CaptionscaptionsGet- Show CaptionscaptionsGetCaptions- List CaptionscaptionsList- List Captions by MediacaptionsPurchase- Purchase CaptionscaptionsUpdate- Update CaptionscaptionsUpdateMultipart- Update CaptionschannelEpisodesCreate- Create Channel EpisodechannelEpisodesDeleteChannelEpisodesChannelEpisodeHashedId- Delete Channel EpisodechannelEpisodesGet- Show Channel EpisodechannelEpisodesList- List Channel EpisodeschannelEpisodesPutChannelEpisodesChannelEpisodeHashedId- Update Channel EpisodechannelEpisodesPutChannelEpisodesChannelEpisodeHashedIdPublish- Publish Channel EpisodechannelEpisodesPutChannelEpisodesChannelEpisodeHashedIdUnpublish- Un-publish Channel EpisodechannelsChannelEpisodesList- List Channel Episodes by ChannelchannelsDeleteChannelsChannelHashedId- Delete ChannelchannelsGet- Show ChannelchannelsList- List ChannelschannelsPostChannels- Create ChannelchannelsPutChannelsChannelHashedId- Update ChannelcustomizationsCreate- Create CustomizationscustomizationsDelete- Delete CustomizationscustomizationsGet- Show CustomizationscustomizationsUpdate- Update CustomizationsexpiringAccessTokensCreate- Create Expiring Access TokenfoldersDeleteFoldersId- Delete FolderfoldersGetFolders- List FoldersfoldersGetFoldersId- Show FolderfolderSharingsDeleteFoldersFolderIdSharingsSharingId- Delete Folder SharingfolderSharingsGetFoldersFolderIdSharings- List Folder SharingsfolderSharingsGetFoldersFolderIdSharingsSharingId- Show Folder SharingfolderSharingsPostFoldersFolderIdSharings- Create Folder SharingfolderSharingsPutFoldersFolderIdSharingsSharingId- Update Folder SharingfoldersPostFolders- Create FolderfoldersPostFoldersIdCopy- Copy FolderfoldersPutFoldersId- Update FolderlocalizationsCreate- Create LocalizationlocalizationsDelete- Delete LocalizationlocalizationsGet- Show LocalizationlocalizationsList- List LocalizationsmediaArchive- Archive MediamediaCopy- Copy MediamediaDelete- Delete MediamediaExtendedAudioDescriptionsDeleteMediaExtendedAudioDescriptionsId- Delete Media Extended Audio DescriptionmediaExtendedAudioDescriptionsGetMediaExtendedAudioDescriptions- List Media Extended Audio DescriptionsmediaExtendedAudioDescriptionsGetMediaExtendedAudioDescriptionsId- Show Media Extended Audio DescriptionmediaExtendedAudioDescriptionsGetMediaExtendedAudioDescriptionsOrderStatusId- Get Order StatusmediaExtendedAudioDescriptionsPostMediaExtendedAudioDescriptionsOrder- Order Extended Audio DescriptionmediaGet- Show MediamediaGetStats- Show Media Aggregated StatsmediaList- List MediamediaMove- Move MediamediaPostMediasImportUrl- Import Media from URLmediaPutMediasCopy- Bulk Copy MediamediaRestore- Restore MediamediaSwap- Swap MediamediaTranslate- Translate MediamediaUpdate- Update MediamediaUploadForm- Upload or Import MediamediaUploadMultipart- Upload or Import MediasearchSearch- SearchstatsAccountGet- Show Current Account StatsstatsAccountGetStatsAccountByDate- Show Account Stats by DatestatsEventsGet- Show EventstatsEventsList- List EventsstatsMediaGet- Show Media StatsstatsMediaGetByDate- Show Media Stats by DatestatsMediaGetEngagement- Show Media EngagementstatsProjectsGet- Show Project StatsstatsVisitorsGet- Show VisitorstatsVisitorsList- List VisitorssubfoldersDeleteFoldersFolderIdSubfoldersBulkDelete- Bulk Delete SubfolderssubfoldersDeleteFoldersFolderIdSubfoldersSubfolderId- Delete SubfoldersubfoldersGetFoldersFolderIdSubfolders- List SubfolderssubfoldersGetFoldersFolderIdSubfoldersSubfolderId- Show SubfoldersubfoldersPostFoldersFolderIdSubfolders- Create SubfoldersubfoldersPutFoldersFolderIdSubfoldersSubfolderId- Update SubfoldertaggingsPostTaggingsBulkCreate- Bulk Tag MediatagsCreate- Create TagstagsDelete- Delete TagtagsList- List TagstrimsCreate- Create Media from TrimswebinarRegistrationsPostWebinarsWebinarIdRegistrations- Create Webinar RegistrationwebinarsDeleteWebinarsId- Delete WebinarwebinarsGetWebinars- List WebinarswebinarsGetWebinarsId- Show WebinarwebinarsPostWebinars- Create WebinarwebinarsPutWebinarsId- Update Webinar
File uploads
Certain SDK methods accept files as part of a multi-part request. It is possible and typically recommended to upload files as a stream rather than reading the entire contents into memory. This avoids excessive memory consumption and potentially crashing with out-of-memory errors when working with very large files. The following example demonstrates how to attach a file stream to a request.
[!TIP]
Depending on your JavaScript runtime, there are convenient utilities that return a handle to a file without reading the entire contents into memory:
- Node.js v20+: Since v20, Node.js comes with a native
openAsBlobfunction innode:fs.- Bun: The native
Bun.filefunction produces a file handle that can be used for streaming file uploads.- Browsers: All supported browsers return an instance to a
Filewhen reading the value from an<input type="file">element.- Node.js v18: A file stream can be created using the
fileFromhelper fromfetch-blob/from.js.
import { Wistia } from "@wistia/wistia-api-client";
import { openAsBlob } from "node:fs";
const wistia = new Wistia({
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
const result = await wistia.media.uploadMultipart({
file: await openAsBlob("example.file"),
});
console.log(result);
}
run();
Retries
Some of the endpoints in this SDK support retries. If you use the SDK without any configuration, it will fall back to the default retry strategy provided by the API. However, the default retry strategy can be overridden on a per-operation basis, or across the entire SDK.
To change the default retry strategy for a single API call, simply provide a retryConfig object to the call:
import { Wistia } from "@wistia/wistia-api-client";
const wistia = new Wistia({
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
const result = await wistia.media.uploadForm({
url:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
lowPriority: true,
}, {
retries: {
strategy: "backoff",
backoff: {
initialInterval: 1,
maxInterval: 50,
exponent: 1.1,
maxElapsedTime: 100,
},
retryConnectionErrors: false,
},
});
console.log(result);
}
run();
If you'd like to override the default retry strategy for all operations that support retries, you can provide a retryConfig at SDK initialization:
import { Wistia } from "@wistia/wistia-api-client";
const wistia = new Wistia({
retryConfig: {
strategy: "backoff",
backoff: {
initialInterval: 1,
maxInterval: 50,
exponent: 1.1,
maxElapsedTime: 100,
},
retryConnectionErrors: false,
},
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
const result = await wistia.media.uploadForm({
url:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
lowPriority: true,
});
console.log(result);
}
run();
Error Handling
WistiaError is the base class for all HTTP error responses. It has the following properties:
| Property | Type | Description |
| ------------------- | ---------- | --------------------------------------------------------------------------------------- |
| error.message | string | Error message |
| error.statusCode | number | HTTP response status code eg 404 |
| error.headers | Headers | HTTP response headers |
| error.body | string | HTTP body. Can be empty string if no body is returned. |
| error.rawResponse | Response | Raw HTTP response |
| error.data$ | | Optional. Some errors may contain structured data. See Error Classes. |
Example
import { Wistia } from "@wistia/wistia-api-client";
import * as errors from "@wistia/wistia-api-client/models/errors";
const wistia = new Wistia({
bearerAuth: process.env["WISTIA_BEARER_AUTH"] ?? "",
});
async function run() {
try {
const result = await wistia.media.uploadForm({
url:
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
lowPriority: true,
});
console.log(result);
} catch (error) {
// The base class for HTTP error responses
if (error instanceof errors.WistiaError) {
console.log(error.message);
console.log(error.statusCode);
console.log(error.body);
console.log(error.headers);
// Depending on the method different errors may be thrown
if (error instanceof errors.PostFormBadRequestError) {
console.log(error.data$.error); // operations.PostFormError
}
}
}
}
run();
Error Classes
Primary error:
WistiaError: The base class for HTTP error responses.
Network errors:
ConnectionError: HTTP client was unable to make a request to a server.RequestTimeoutError: HTTP request timed out due to an AbortSignal signal.RequestAbortedError: HTTP request was aborted by the client.InvalidRequestError: Any input used to create a request is invalid.UnexpectedClientError: Unrecognised or unexpected error.
Inherit from WistiaError:
PostFormBadRequestError: Error due to reaching the video limit of your account or other issues. Status code400. Applicable to 1 of 108 methods.*PostMultipartBadRequestError: Error due to reaching the video limit of your account or other issues. Status code400. Applicable to 1 of 108 methods.*GetMediasBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCopyBadRequestError: Bad request, e.g. copy failure. Status code400. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdSwapBadRequestError: Bad request, e.g. missing replacement_media_id or media type mismatch. Status code400. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdStatsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdTranslateBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostMediasImportUrlBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PutMediasMoveBadRequestError: Invalid request. Status code400. Applicable to 1 of 108 methods.*GetCaptionsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdLocalizationsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostMediaExtendedAudioDescriptionsOrderBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetTagsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostTagsBadRequestError: Bad request - missing or invalid parameters. Status code400. Applicable to 1 of 108 methods.*GetFoldersBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetFoldersFolderIdSubfoldersBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetChannelsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostChannelsChannelHashedIdChannelEpisodesBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetChannelEpisodesBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetSearchBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*PostAllowedDomainsBadRequestError: Bad request - missing or invalid domain. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdTimeseriesBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdEmbedLocationsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdTrafficBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdConversionsBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdLanguagesBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdRegistrationBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdTrafficBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetChannelsChannelHashedIdChannelEpisodesBadRequestError: Bad request. Status code400. Applicable to 1 of 108 methods.*GetMediasUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteMediasMediaHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCopyUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdSwapUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdStatsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdTranslateUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasImportUrlUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasArchiveUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMoveUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasRestoreUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasCopyUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaIdCustomizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaIdCustomizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaIdCustomizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteMediasMediaIdCustomizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdCaptionsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCaptionsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCaptionsMultipartUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetCaptionsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCaptionsPurchaseUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdCaptionsLanguageCodeUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdCaptionsLanguageCodeUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdCaptionsLanguageCodeMultipartUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteMediasMediaHashedIdCaptionsLanguageCodeUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdLocalizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdLocalizationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdLocalizationsLocalizationHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteMediasMediaHashedIdLocalizationsLocalizationHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdTrimsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediaExtendedAudioDescriptionsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediaExtendedAudioDescriptionsIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteMediaExtendedAudioDescriptionsIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostMediaExtendedAudioDescriptionsOrderUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetMediaExtendedAudioDescriptionsOrderStatusIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetTagsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostTagsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteTagsNameUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostTaggingsBulkCreateUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostFoldersUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutFoldersIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteFoldersIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostFoldersIdCopyUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersFolderIdSharingsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostFoldersFolderIdSharingsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersFolderIdSharingsSharingIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutFoldersFolderIdSharingsSharingIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteFoldersFolderIdSharingsSharingIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersFolderIdSubfoldersUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostFoldersFolderIdSubfoldersUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetFoldersFolderIdSubfoldersSubfolderIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutFoldersFolderIdSubfoldersSubfolderIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteFoldersFolderIdSubfoldersSubfolderIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteFoldersFolderIdSubfoldersBulkDeleteUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetChannelsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostChannelsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetChannelsChannelHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutChannelsChannelHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteChannelsChannelHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetChannelsChannelHashedIdChannelEpisodesChannelEpisodeIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostChannelsChannelHashedIdChannelEpisodesUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetChannelEpisodesUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutChannelEpisodesChannelEpisodeHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteChannelEpisodesChannelEpisodeHashedIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutChannelEpisodesChannelEpisodeHashedIdPublishUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutChannelEpisodesChannelEpisodeHashedIdUnpublishUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetWebinarsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostWebinarsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetWebinarsIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutWebinarsIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteWebinarsIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostWebinarsWebinarIdRegistrationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAccountDetailsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetTokenDetailsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetSearchUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostExpiringTokenUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetBackgroundJobStatusBackgroundJobStatusIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAllowedDomainsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PostAllowedDomainsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAllowedDomainsDomainUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*DeleteAllowedDomainsDomainUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsAccountUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsAccountByDateUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsProjectsProjectIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsMediasMediaIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsMediasMediaIdByDateUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsMediasMediaIdEngagementUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsVisitorsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsVisitorsVisitorKeyUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsEventsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetStatsEventsEventKeyUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdTimeseriesUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdEmbedLocationsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdTrafficUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdConversionsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsMediasMediaIdLanguagesUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdRegistrationUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdTrafficUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdAudienceUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetAnalyticsWebinarsWebinarIdHistogramsUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*GetChannelsChannelHashedIdChannelEpisodesUnauthorizedError: Unauthorized, invalid or missing token. Status code401. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*DeleteMediasMediaHashedIdForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdCopyForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*PutMediasMediaHashedIdSwapForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*GetMediasMediaHashedIdStatsForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*PostMediasMediaHashedIdTranslateForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*PostMediasImportUrlForbiddenError: Forbidden, token is valid but account does not have access to feature. Status code403. Applicable to 1 of 108 methods.*PutMediasArchiveForbiddenError: Forbidden, e.g. account does not have access to archiving. Status code403. Appli
