mirror of
https://github.com/LukeHagar/plexjava.git
synced 2025-12-06 20:47:45 +00:00
Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c0e915da8b | ||
|
|
0077561a6a | ||
|
|
4b28ca3416 | ||
|
|
dd781d1e27 |
3
.gitattributes
vendored
3
.gitattributes
vendored
@@ -8,5 +8,4 @@
|
|||||||
*.bat text eol=crlf
|
*.bat text eol=crlf
|
||||||
|
|
||||||
# This allows generated code to be indexed correctly
|
# This allows generated code to be indexed correctly
|
||||||
*.java linguist-generated=false
|
*.java linguist-generated=false
|
||||||
|
|
||||||
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,3 +1,5 @@
|
|||||||
|
**/.speakeasy/temp/
|
||||||
|
**/.speakeasy/logs/
|
||||||
.speakeasy/reports
|
.speakeasy/reports
|
||||||
# Ignore Gradle project-specific cache directory
|
# Ignore Gradle project-specific cache directory
|
||||||
.gradle
|
.gradle
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
@@ -11,11 +11,12 @@ generation:
|
|||||||
parameterOrderingFeb2024: true
|
parameterOrderingFeb2024: true
|
||||||
requestResponseComponentNamesFeb2024: true
|
requestResponseComponentNamesFeb2024: true
|
||||||
securityFeb2025: false
|
securityFeb2025: false
|
||||||
|
sharedErrorComponentsApr2025: false
|
||||||
auth:
|
auth:
|
||||||
oAuth2ClientCredentialsEnabled: true
|
oAuth2ClientCredentialsEnabled: true
|
||||||
oAuth2PasswordEnabled: false
|
oAuth2PasswordEnabled: false
|
||||||
java:
|
java:
|
||||||
version: 0.14.1
|
version: 0.16.1
|
||||||
additionalDependencies: []
|
additionalDependencies: []
|
||||||
additionalPlugins: []
|
additionalPlugins: []
|
||||||
artifactID: plexapi
|
artifactID: plexapi
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
speakeasyVersion: 1.528.1
|
speakeasyVersion: 1.541.2
|
||||||
sources:
|
sources:
|
||||||
my-source:
|
my-source:
|
||||||
sourceNamespace: my-source
|
sourceNamespace: my-source
|
||||||
@@ -8,19 +8,19 @@ sources:
|
|||||||
- latest
|
- latest
|
||||||
plexapi:
|
plexapi:
|
||||||
sourceNamespace: plexapi
|
sourceNamespace: plexapi
|
||||||
sourceRevisionDigest: sha256:b5580df6ec4a386e12249ff13f35b916fe5559e101de4a816b53e47d6947f1a5
|
sourceRevisionDigest: sha256:31ab7b2e65ccf1e0349bcd8b35791d1ce80091313481874749163fc0c80fd8ed
|
||||||
sourceBlobDigest: sha256:6108b6c35fbe7e9163ffe0c804170f5e3a6edb63b8e745454ea8ee249bd790c3
|
sourceBlobDigest: sha256:d971fff9723c626fe70403a2a83d813c396a20b06ccd6b899263762038cfdbb0
|
||||||
tags:
|
tags:
|
||||||
- latest
|
- latest
|
||||||
- speakeasy-sdk-regen-1743640078
|
- speakeasy-sdk-regen-1746059587
|
||||||
targets:
|
targets:
|
||||||
plexjava:
|
plexjava:
|
||||||
source: plexapi
|
source: plexapi
|
||||||
sourceNamespace: plexapi
|
sourceNamespace: plexapi
|
||||||
sourceRevisionDigest: sha256:b5580df6ec4a386e12249ff13f35b916fe5559e101de4a816b53e47d6947f1a5
|
sourceRevisionDigest: sha256:31ab7b2e65ccf1e0349bcd8b35791d1ce80091313481874749163fc0c80fd8ed
|
||||||
sourceBlobDigest: sha256:6108b6c35fbe7e9163ffe0c804170f5e3a6edb63b8e745454ea8ee249bd790c3
|
sourceBlobDigest: sha256:d971fff9723c626fe70403a2a83d813c396a20b06ccd6b899263762038cfdbb0
|
||||||
codeSamplesNamespace: code-samples-java-plexjava
|
codeSamplesNamespace: code-samples-java-plexjava
|
||||||
codeSamplesRevisionDigest: sha256:5ac1b6e0506bbf85ab353ce21dbf6646b6590efa4ba68ab778ba9836b378e0f6
|
codeSamplesRevisionDigest: sha256:7014061698c081192d583b95c5cdcb4120fd314b9e0963b81fb16e74b320b426
|
||||||
workflow:
|
workflow:
|
||||||
workflowVersion: 1.0.0
|
workflowVersion: 1.0.0
|
||||||
speakeasyVersion: latest
|
speakeasyVersion: latest
|
||||||
|
|||||||
27
README.md
27
README.md
@@ -69,7 +69,7 @@ The samples below show how a published SDK artifact is used:
|
|||||||
|
|
||||||
Gradle:
|
Gradle:
|
||||||
```groovy
|
```groovy
|
||||||
implementation 'dev.plexapi:plexapi:0.14.1'
|
implementation 'dev.plexapi:plexapi:0.16.1'
|
||||||
```
|
```
|
||||||
|
|
||||||
Maven:
|
Maven:
|
||||||
@@ -77,7 +77,7 @@ Maven:
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>dev.plexapi</groupId>
|
<groupId>dev.plexapi</groupId>
|
||||||
<artifactId>plexapi</artifactId>
|
<artifactId>plexapi</artifactId>
|
||||||
<version>0.14.1</version>
|
<version>0.16.1</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -94,6 +94,29 @@ On Windows:
|
|||||||
```bash
|
```bash
|
||||||
gradlew.bat publishToMavenLocal -Pskip.signing
|
gradlew.bat publishToMavenLocal -Pskip.signing
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Logging
|
||||||
|
A logging framework/facade has not yet been adopted but is under consideration.
|
||||||
|
|
||||||
|
For request and response logging (especially json bodies) use:
|
||||||
|
```java
|
||||||
|
SpeakeasyHTTPClient.setDebugLogging(true); // experimental API only (may change without warning)
|
||||||
|
```
|
||||||
|
Example output:
|
||||||
|
```
|
||||||
|
Sending request: http://localhost:35123/bearer#global GET
|
||||||
|
Request headers: {Accept=[application/json], Authorization=[******], Client-Level-Header=[added by client], Idempotency-Key=[some-key], x-speakeasy-user-agent=[speakeasy-sdk/java 0.0.1 internal 0.1.0 org.openapis.openapi]}
|
||||||
|
Received response: (GET http://localhost:35123/bearer#global) 200
|
||||||
|
Response headers: {access-control-allow-credentials=[true], access-control-allow-origin=[*], connection=[keep-alive], content-length=[50], content-type=[application/json], date=[Wed, 09 Apr 2025 01:43:29 GMT], server=[gunicorn/19.9.0]}
|
||||||
|
Response body:
|
||||||
|
{
|
||||||
|
"authenticated": true,
|
||||||
|
"token": "global"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
WARNING: This should only used for temporary debugging purposes. Leaving this option on in a production system could expose credentials/secrets in logs. <i>Authorization</i> headers are redacted by default and there is the ability to specify redacted header names via `SpeakeasyHTTPClient.setRedactedHeaders`.
|
||||||
|
|
||||||
|
Another option is to set the System property `-Djdk.httpclient.HttpClient.log=all`. However, this second option does not log bodies.
|
||||||
<!-- End SDK Installation [installation] -->
|
<!-- End SDK Installation [installation] -->
|
||||||
|
|
||||||
<!-- Start SDK Example Usage [usage] -->
|
<!-- Start SDK Example Usage [usage] -->
|
||||||
|
|||||||
42
RELEASES.md
42
RELEASES.md
@@ -298,4 +298,44 @@ Based on:
|
|||||||
### Generated
|
### Generated
|
||||||
- [java v0.14.1] .
|
- [java v0.14.1] .
|
||||||
### Releases
|
### Releases
|
||||||
- [Maven Central v0.14.1] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.14.1 - .
|
- [Maven Central v0.14.1] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.14.1 - .
|
||||||
|
|
||||||
|
## 2025-04-06 00:30:19
|
||||||
|
### Changes
|
||||||
|
Based on:
|
||||||
|
- OpenAPI Doc
|
||||||
|
- Speakeasy CLI 1.529.1 (2.566.5) https://github.com/speakeasy-api/speakeasy
|
||||||
|
### Generated
|
||||||
|
- [java v0.14.2] .
|
||||||
|
### Releases
|
||||||
|
- [Maven Central v0.14.2] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.14.2 - .
|
||||||
|
|
||||||
|
## 2025-04-14 00:30:37
|
||||||
|
### Changes
|
||||||
|
Based on:
|
||||||
|
- OpenAPI Doc
|
||||||
|
- Speakeasy CLI 1.531.4 (2.570.4) https://github.com/speakeasy-api/speakeasy
|
||||||
|
### Generated
|
||||||
|
- [java v0.15.0] .
|
||||||
|
### Releases
|
||||||
|
- [Maven Central v0.15.0] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.15.0 - .
|
||||||
|
|
||||||
|
## 2025-04-19 00:27:27
|
||||||
|
### Changes
|
||||||
|
Based on:
|
||||||
|
- OpenAPI Doc
|
||||||
|
- Speakeasy CLI 1.535.1 (2.585.2) https://github.com/speakeasy-api/speakeasy
|
||||||
|
### Generated
|
||||||
|
- [java v0.16.0] .
|
||||||
|
### Releases
|
||||||
|
- [Maven Central v0.16.0] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.16.0 - .
|
||||||
|
|
||||||
|
## 2025-05-01 00:32:51
|
||||||
|
### Changes
|
||||||
|
Based on:
|
||||||
|
- OpenAPI Doc
|
||||||
|
- Speakeasy CLI 1.541.2 (2.595.4) https://github.com/speakeasy-api/speakeasy
|
||||||
|
### Generated
|
||||||
|
- [java v0.16.1] .
|
||||||
|
### Releases
|
||||||
|
- [Maven Central v0.16.1] https://central.sonatype.com/artifact/dev.plexapi/plexapi/0.16.1 - .
|
||||||
@@ -103,7 +103,7 @@ publishing {
|
|||||||
// https://github.com/gradle/gradle/issues/18619
|
// https://github.com/gradle/gradle/issues/18619
|
||||||
groupId = "dev.plexapi"
|
groupId = "dev.plexapi"
|
||||||
artifactId = "plexapi"
|
artifactId = "plexapi"
|
||||||
version = "0.14.1"
|
version = "0.16.1"
|
||||||
|
|
||||||
from components.java
|
from components.java
|
||||||
|
|
||||||
|
|||||||
712
codeSamples.yaml
712
codeSamples.yaml
File diff suppressed because it is too large
Load Diff
11
docs/models/operations/Attributes.md
Normal file
11
docs/models/operations/Attributes.md
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# Attributes
|
||||||
|
|
||||||
|
Attributes associated with the marker.
|
||||||
|
|
||||||
|
|
||||||
|
## Fields
|
||||||
|
|
||||||
|
| Field | Type | Required | Description | Example |
|
||||||
|
| -------------------------------------------- | -------------------------------------------- | -------------------------------------------- | -------------------------------------------- | -------------------------------------------- |
|
||||||
|
| `id` | *long* | :heavy_check_mark: | The identifier for the attributes. | 306970 |
|
||||||
|
| `version` | *Optional\<Long>* | :heavy_minus_sign: | The version number of the marker attributes. | 4 |
|
||||||
15
docs/models/operations/Chapter.md
Normal file
15
docs/models/operations/Chapter.md
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
# Chapter
|
||||||
|
|
||||||
|
The thumbnail for the chapter
|
||||||
|
|
||||||
|
|
||||||
|
## Fields
|
||||||
|
|
||||||
|
| Field | Type | Required | Description | Example |
|
||||||
|
| ------------------------------------ | ------------------------------------ | ------------------------------------ | ------------------------------------ | ------------------------------------ |
|
||||||
|
| `id` | *long* | :heavy_check_mark: | N/A | 4 |
|
||||||
|
| `filter` | *String* | :heavy_check_mark: | N/A | thumb=4 |
|
||||||
|
| `index` | *long* | :heavy_check_mark: | N/A | 1 |
|
||||||
|
| `startTimeOffset` | *long* | :heavy_check_mark: | N/A | 0 |
|
||||||
|
| `endTimeOffset` | *long* | :heavy_check_mark: | N/A | 100100 |
|
||||||
|
| `thumb` | *String* | :heavy_check_mark: | N/A | /library/media/46883/chapterImages/1 |
|
||||||
@@ -7,6 +7,6 @@ The filter query string for country media items.
|
|||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- |
|
| ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | N/A | 259 |
|
| `id` | *int* | :heavy_check_mark: | N/A | 259 |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The country of origin of this media item | United States of America |
|
| `tag` | *String* | :heavy_check_mark: | The country of origin of this media item | United States of America |
|
||||||
| `filter` | *Optional\<String>* | :heavy_minus_sign: | N/A | country=19 |
|
| `filter` | *Optional\<String>* | :heavy_minus_sign: | N/A | country=19 |
|
||||||
8
docs/models/operations/Extras.md
Normal file
8
docs/models/operations/Extras.md
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Extras
|
||||||
|
|
||||||
|
|
||||||
|
## Fields
|
||||||
|
|
||||||
|
| Field | Type | Required | Description | Example |
|
||||||
|
| ----------------------- | ----------------------- | ----------------------- | ----------------------- | ----------------------- |
|
||||||
|
| `size` | *Optional\<Long>* | :heavy_minus_sign: | The size of the extras. | 1 |
|
||||||
@@ -3,26 +3,26 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------ |
|
| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| `allowSync` | *boolean* | :heavy_check_mark: | N/A | true |
|
| `allowSync` | *boolean* | :heavy_check_mark: | Indicates whether syncing is allowed. | false |
|
||||||
| `art` | *String* | :heavy_check_mark: | N/A | /:/resources/movie-fanart.jpg |
|
| `art` | *String* | :heavy_check_mark: | URL for the background artwork of the media container. | /:/resources/show-fanart.jpg |
|
||||||
| `composite` | *String* | :heavy_check_mark: | N/A | /library/sections/1/composite/1705615584 |
|
| `composite` | *String* | :heavy_check_mark: | The relative path to the composite media item. | /library/sections/1/composite/1743824484 |
|
||||||
| `filters` | *boolean* | :heavy_check_mark: | N/A | true |
|
| `filters` | *boolean* | :heavy_check_mark: | UNKNOWN | true |
|
||||||
| `refreshing` | *boolean* | :heavy_check_mark: | N/A | false |
|
| `refreshing` | *boolean* | :heavy_check_mark: | Indicates whether the library is currently being refreshed or updated | true |
|
||||||
| `thumb` | *String* | :heavy_check_mark: | N/A | /:/resources/movie.png |
|
| `thumb` | *String* | :heavy_check_mark: | URL for the thumbnail image of the media container. | /:/resources/show.png |
|
||||||
| `key` | *String* | :heavy_check_mark: | N/A | 1 |
|
| `key` | *String* | :heavy_check_mark: | The library key representing the unique identifier | 1 |
|
||||||
| `type` | *String* | :heavy_check_mark: | N/A | movie |
|
| `type` | [GetAllLibrariesType](../../models/operations/GetAllLibrariesType.md) | :heavy_check_mark: | N/A | movie |
|
||||||
| `title` | *String* | :heavy_check_mark: | N/A | Movies |
|
| `title` | *String* | :heavy_check_mark: | The title of the library | Movies |
|
||||||
| `agent` | *String* | :heavy_check_mark: | N/A | tv.plex.agents.movie |
|
| `agent` | *String* | :heavy_check_mark: | The Plex agent used to match and retrieve media metadata. | tv.plex.agents.movie |
|
||||||
| `scanner` | *String* | :heavy_check_mark: | N/A | Plex Movie |
|
| `scanner` | *String* | :heavy_check_mark: | UNKNOWN | Plex Movie |
|
||||||
| `language` | *String* | :heavy_check_mark: | N/A | en-US |
|
| `language` | *String* | :heavy_check_mark: | The Plex library language that has been set | en-US |
|
||||||
| `uuid` | *String* | :heavy_check_mark: | N/A | 322a231a-b7f7-49f5-920f-14c61199cd30 |
|
| `uuid` | *String* | :heavy_check_mark: | The universally unique identifier for the library. | e69655a2-ef48-4aba-bb19-01e7d3cc34d6 |
|
||||||
| `updatedAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
| `updatedAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
||||||
| `createdAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
| `createdAt` | *Optional\<Long>* | :heavy_minus_sign: | N/A | 1556281940 |
|
||||||
| `scannedAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
| `scannedAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
||||||
| `content` | *boolean* | :heavy_check_mark: | N/A | true |
|
| `content` | *boolean* | :heavy_check_mark: | UNKNOWN | true |
|
||||||
| `directory` | *boolean* | :heavy_check_mark: | N/A | true |
|
| `directory` | *boolean* | :heavy_check_mark: | UNKNOWN | true |
|
||||||
| `contentChangedAt` | *long* | :heavy_check_mark: | Unix epoch datetime in seconds | 1556281940 |
|
| `contentChangedAt` | *long* | :heavy_check_mark: | Timestamp (in seconds) representing the last time the content was modified.<br/>NOTE: Some Plex server have some absurd values for this field, like 8457612157633039800 so it should be int64<br/> | 9173960 |
|
||||||
| `hidden` | *int* | :heavy_check_mark: | N/A | 0 |
|
| `hidden` | [Optional\<Hidden>](../../models/operations/Hidden.md) | :heavy_minus_sign: | N/A | 1 |
|
||||||
| `location` | List\<[GetAllLibrariesLocation](../../models/operations/GetAllLibrariesLocation.md)> | :heavy_check_mark: | N/A | |
|
| `location` | List\<[GetAllLibrariesLocation](../../models/operations/GetAllLibrariesLocation.md)> | :heavy_check_mark: | N/A | |
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------ | ------------------ | ------------------ | ------------------ | ------------------ |
|
| --------------------------- | --------------------------- | --------------------------- | --------------------------- | --------------------------- |
|
||||||
| `id` | *int* | :heavy_check_mark: | N/A | 1 |
|
| `id` | *int* | :heavy_check_mark: | The ID of the location. | 1 |
|
||||||
| `path` | *String* | :heavy_check_mark: | N/A | /movies |
|
| `path` | *String* | :heavy_check_mark: | The path to the media item. | /Movies |
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- |
|
| -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- |
|
||||||
| `size` | *int* | :heavy_check_mark: | N/A | 5 |
|
| `size` | *int* | :heavy_check_mark: | Number of media items returned in this response. | 50 |
|
||||||
| `allowSync` | *boolean* | :heavy_check_mark: | N/A | false |
|
| `allowSync` | *boolean* | :heavy_check_mark: | Indicates whether syncing is allowed. | false |
|
||||||
| `title1` | *String* | :heavy_check_mark: | N/A | Plex Library |
|
| `title1` | *String* | :heavy_check_mark: | The primary title of the media container. | TV Series |
|
||||||
| `directory` | List\<[GetAllLibrariesDirectory](../../models/operations/GetAllLibrariesDirectory.md)> | :heavy_check_mark: | N/A | |
|
| `directory` | List\<[GetAllLibrariesDirectory](../../models/operations/GetAllLibrariesDirectory.md)> | :heavy_minus_sign: | N/A | |
|
||||||
@@ -5,6 +5,6 @@ The libraries available on the Server
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description |
|
| Field | Type | Required | Description |
|
||||||
| ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------- |
|
| ---------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- |
|
||||||
| `mediaContainer` | [GetAllLibrariesMediaContainer](../../models/operations/GetAllLibrariesMediaContainer.md) | :heavy_check_mark: | N/A |
|
| `mediaContainer` | [Optional\<GetAllLibrariesMediaContainer>](../../models/operations/GetAllLibrariesMediaContainer.md) | :heavy_minus_sign: | N/A |
|
||||||
15
docs/models/operations/GetAllLibrariesType.md
Normal file
15
docs/models/operations/GetAllLibrariesType.md
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
# GetAllLibrariesType
|
||||||
|
|
||||||
|
The library type
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| --------- | --------- |
|
||||||
|
| `Movie` | movie |
|
||||||
|
| `TvShow` | show |
|
||||||
|
| `Season` | season |
|
||||||
|
| `Episode` | episode |
|
||||||
|
| `Artist` | artist |
|
||||||
|
| `Album` | album |
|
||||||
@@ -3,54 +3,56 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- |
|
| --------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
||||||
| `streamType` | *int* | :heavy_check_mark: | Stream type (1=video, 2=audio, 3=subtitle). | 1 |
|
| `streamType` | [GetAllMediaLibraryStreamType](../../models/operations/GetAllMediaLibraryStreamType.md) | :heavy_check_mark: | Stream type:<br/> - 1 = video<br/> - 2 = audio<br/> - 3 = subtitle<br/> | 1 |
|
||||||
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
| `format` | *Optional\<String>* | :heavy_minus_sign: | Format of the stream (e.g., srt). | srt |
|
||||||
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
||||||
| `index` | *int* | :heavy_check_mark: | Index of the stream. | 0 |
|
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
||||||
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
| `index` | *Optional\<Integer>* | :heavy_minus_sign: | Index of the stream. | 0 |
|
||||||
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
||||||
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
||||||
| `languageCode` | *Optional\<String>* | :heavy_minus_sign: | ISO language code. | eng |
|
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
||||||
| `headerCompression` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates whether header compression is enabled. | true |
|
| `languageCode` | *Optional\<String>* | :heavy_minus_sign: | ISO language code. | eng |
|
||||||
| `doviblCompatID` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision BL compatibility ID. | 1 |
|
| `headerCompression` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates whether header compression is enabled. | true |
|
||||||
| `doviblPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision BL is present. | true |
|
| `doviblCompatID` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision BL compatibility ID. | 1 |
|
||||||
| `dovielPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision EL is present. | false |
|
| `doviblPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision BL is present. | true |
|
||||||
| `doviLevel` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision level. | 6 |
|
| `dovielPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision EL is present. | false |
|
||||||
| `doviPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision is present. | true |
|
| `doviLevel` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision level. | 6 |
|
||||||
| `doviProfile` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision profile. | 8 |
|
| `doviPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision is present. | true |
|
||||||
| `dovirpuPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision RPU is present. | true |
|
| `doviProfile` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision profile. | 8 |
|
||||||
| `doviVersion` | *Optional\<String>* | :heavy_minus_sign: | Dolby Vision version. | 1.0 |
|
| `dovirpuPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision RPU is present. | true |
|
||||||
| `bitDepth` | *Optional\<Integer>* | :heavy_minus_sign: | Bit depth of the video stream. | 10 |
|
| `doviVersion` | *Optional\<String>* | :heavy_minus_sign: | Dolby Vision version. | 1.0 |
|
||||||
| `chromaLocation` | *Optional\<String>* | :heavy_minus_sign: | Chroma sample location. | topleft |
|
| `bitDepth` | *Optional\<Integer>* | :heavy_minus_sign: | Bit depth of the video stream. | 10 |
|
||||||
| `chromaSubsampling` | *Optional\<String>* | :heavy_minus_sign: | Chroma subsampling format. | 4:2:0 |
|
| `chromaLocation` | *Optional\<String>* | :heavy_minus_sign: | Chroma sample location. | topleft |
|
||||||
| `codedHeight` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video height. | 1608 |
|
| `chromaSubsampling` | *Optional\<String>* | :heavy_minus_sign: | Chroma subsampling format. | 4:2:0 |
|
||||||
| `codedWidth` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video width. | 3840 |
|
| `codedHeight` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video height. | 1608 |
|
||||||
| `closedCaptions` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
| `codedWidth` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video width. | 3840 |
|
||||||
| `colorPrimaries` | *Optional\<String>* | :heavy_minus_sign: | Color primaries used. | bt2020 |
|
| `closedCaptions` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
||||||
| `colorRange` | *Optional\<String>* | :heavy_minus_sign: | Color range (e.g., tv). | tv |
|
| `colorPrimaries` | *Optional\<String>* | :heavy_minus_sign: | Color primaries used. | bt2020 |
|
||||||
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
| `colorRange` | *Optional\<String>* | :heavy_minus_sign: | Color range (e.g., tv). | tv |
|
||||||
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
||||||
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
||||||
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
||||||
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
| `key` | *Optional\<String>* | :heavy_minus_sign: | Key to access this stream part. | /library/streams/216389 |
|
||||||
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
||||||
| `hasScalingMatrix` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | false |
|
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
||||||
| `profile` | *Optional\<String>* | :heavy_minus_sign: | Video profile. | main 10 |
|
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
||||||
| `scanType` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
| `hasScalingMatrix` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | false |
|
||||||
| `embeddedInVideo` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
| `profile` | *Optional\<String>* | :heavy_minus_sign: | Video profile. | main 10 |
|
||||||
| `refFrames` | *Optional\<Integer>* | :heavy_minus_sign: | Number of reference frames. | 1 |
|
| `scanType` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
||||||
| `width` | *Optional\<Integer>* | :heavy_minus_sign: | Width of the video stream. | 3840 |
|
| `embeddedInVideo` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
||||||
| `displayTitle` | *String* | :heavy_check_mark: | Display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
| `refFrames` | *Optional\<Integer>* | :heavy_minus_sign: | Number of reference frames. | 1 |
|
||||||
| `extendedDisplayTitle` | *String* | :heavy_check_mark: | Extended display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
| `width` | *Optional\<Integer>* | :heavy_minus_sign: | Width of the video stream. | 3840 |
|
||||||
| `selected` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is selected (applicable for audio streams). | true |
|
| `displayTitle` | *String* | :heavy_check_mark: | Display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
||||||
| `forced` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
| `extendedDisplayTitle` | *String* | :heavy_check_mark: | Extended display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
||||||
| `channels` | *Optional\<Integer>* | :heavy_minus_sign: | Number of audio channels (for audio streams). | 6 |
|
| `selected` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is selected (applicable for audio streams). | true |
|
||||||
| `audioChannelLayout` | *Optional\<String>* | :heavy_minus_sign: | Audio channel layout. | 5.1(side) |
|
| `forced` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
||||||
| `samplingRate` | *Optional\<Integer>* | :heavy_minus_sign: | Sampling rate for the audio stream. | 48000 |
|
| `channels` | *Optional\<Integer>* | :heavy_minus_sign: | Number of audio channels (for audio streams). | 6 |
|
||||||
| `canAutoSync` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream can auto-sync. | false |
|
| `audioChannelLayout` | *Optional\<String>* | :heavy_minus_sign: | Audio channel layout. | 5.1(side) |
|
||||||
| `hearingImpaired` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is for the hearing impaired. | true |
|
| `samplingRate` | *Optional\<Integer>* | :heavy_minus_sign: | Sampling rate for the audio stream. | 48000 |
|
||||||
| `dub` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is a dub. | true |
|
| `canAutoSync` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream can auto-sync. | false |
|
||||||
| `title` | *Optional\<String>* | :heavy_minus_sign: | Optional title for the stream (e.g., language variant). | SDH |
|
| `hearingImpaired` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is for the hearing impaired. | true |
|
||||||
|
| `dub` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is a dub. | true |
|
||||||
|
| `title` | *Optional\<String>* | :heavy_minus_sign: | Optional title for the stream (e.g., language variant). | SDH |
|
||||||
16
docs/models/operations/GetAllMediaLibraryStreamType.md
Normal file
16
docs/models/operations/GetAllMediaLibraryStreamType.md
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# GetAllMediaLibraryStreamType
|
||||||
|
|
||||||
|
Stream type:
|
||||||
|
- 1 = video
|
||||||
|
- 2 = audio
|
||||||
|
- 3 = subtitle
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| ---------- | ---------- |
|
||||||
|
| `Video` | 1 |
|
||||||
|
| `Audio` | 2 |
|
||||||
|
| `Subtitle` | 3 |
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `includeDetails` | [Optional\<IncludeDetails>](../../models/operations/IncludeDetails.md) | :heavy_minus_sign: | Whether or not to include details for a section (types, filters, and sorts). <br/>Only exists for backwards compatibility, media providers other than the server libraries have it on always.<br/> | |
|
| `includeDetails` | [Optional\<IncludeDetails>](../../models/operations/IncludeDetails.md) | :heavy_minus_sign: | Whether or not to include details for a section (types, filters, and sorts).<br/>Only exists for backwards compatibility, media providers other than the server libraries have it on always.<br/> | |
|
||||||
| `sectionKey` | *int* | :heavy_check_mark: | The unique key of the Plex library. <br/>Note: This is unique in the context of the Plex server.<br/> | 9518 |
|
| `sectionKey` | *int* | :heavy_check_mark: | The unique key of the Plex library. <br/>Note: This is unique in the context of the Plex server.<br/> | 9518 |
|
||||||
@@ -1,10 +1,12 @@
|
|||||||
# GetMediaMetaDataCountry
|
# GetMediaMetaDataCountry
|
||||||
|
|
||||||
|
The filter query string for country media items.
|
||||||
|
|
||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ---------------------------------- | ---------------------------------- | ---------------------------------- | ---------------------------------- | ---------------------------------- |
|
| ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- | ---------------------------------------- |
|
||||||
| `id` | *int* | :heavy_check_mark: | The unique country identifier. | 58591 |
|
| `id` | *int* | :heavy_check_mark: | N/A | 259 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string for the country. | country=58591 |
|
| `tag` | *String* | :heavy_check_mark: | The country of origin of this media item | United States of America |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The country name. | United States of America |
|
| `filter` | *Optional\<String>* | :heavy_minus_sign: | N/A | country=19 |
|
||||||
@@ -3,11 +3,10 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
|
| ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | The unique role identifier. | 109501 |
|
| `id` | *int* | :heavy_check_mark: | Unique identifier for the director. | 126522 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string for the role. | actor=109501 |
|
| `tag` | *String* | :heavy_check_mark: | The role of Director | Danny Boyle |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The actor's name. | Bob Odenkirk |
|
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this director. | director=235876 |
|
||||||
| `tagKey` | *String* | :heavy_check_mark: | A key associated with the actor tag. | 5d77683254f42c001f8c3f69 |
|
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the director's tag, used for internal identification. | 5d776831151a60001f24d031 |
|
||||||
| `role` | *Optional\<String>* | :heavy_minus_sign: | The character name or role. | Jimmy McGill |
|
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | The URL of the thumbnail image for the director. | https://metadata-static.plex.tv/8/people/8d65fa96804802e08f2de09fe014408e.jpg |
|
||||||
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | URL for the role thumbnail image. | https://metadata-static.plex.tv/f/people/f2ca7b474cc984efbdd5c503a096285a.jpg |
|
|
||||||
@@ -1,10 +1,12 @@
|
|||||||
# GetMediaMetaDataGenre
|
# GetMediaMetaDataGenre
|
||||||
|
|
||||||
|
The filter query string for similar items.
|
||||||
|
|
||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| -------------------------------- | -------------------------------- | -------------------------------- | -------------------------------- | -------------------------------- |
|
| ---------------------------------- | ---------------------------------- | ---------------------------------- | ---------------------------------- | ---------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | The unique genre identifier. | 1057 |
|
| `id` | *long* | :heavy_check_mark: | N/A | 259 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string for the genre. | genre=1057 |
|
| `tag` | *String* | :heavy_check_mark: | The genre name of this media-item<br/> | Crime |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The genre name. | Crime |
|
| `filter` | *String* | :heavy_check_mark: | N/A | genre=19 |
|
||||||
@@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------- | ------------------------------------------------------------- | ------------------------------------------------------------- | ------------------------------------------------------------- | ------------------------------------------------------------- |
|
| ------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- |
|
||||||
| `alt` | *String* | :heavy_check_mark: | Alternate text for the image. | Better Call Saul |
|
| `alt` | *String* | :heavy_check_mark: | N/A | Episode 1 |
|
||||||
| `type` | *String* | :heavy_check_mark: | The type of image (e.g., coverPoster, background, clearLogo). | coverPoster |
|
| `type` | [GetMediaMetaDataLibraryType](../../models/operations/GetMediaMetaDataLibraryType.md) | :heavy_check_mark: | N/A | background |
|
||||||
| `url` | *String* | :heavy_check_mark: | The URL of the image. | /library/metadata/44288/thumb/1736487993 |
|
| `url` | *String* | :heavy_check_mark: | N/A | /library/metadata/45521/thumb/1644710589 |
|
||||||
11
docs/models/operations/GetMediaMetaDataLibraryType.md
Normal file
11
docs/models/operations/GetMediaMetaDataLibraryType.md
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# GetMediaMetaDataLibraryType
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| -------------- | -------------- |
|
||||||
|
| `COVER_POSTER` | coverPoster |
|
||||||
|
| `BACKGROUND` | background |
|
||||||
|
| `SNAPSHOT` | snapshot |
|
||||||
|
| `CLEAR_LOGO` | clearLogo |
|
||||||
@@ -1,68 +1,83 @@
|
|||||||
# GetMediaMetaDataMetadata
|
# GetMediaMetaDataMetadata
|
||||||
|
|
||||||
|
Unknown
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `ratingKey` | *String* | :heavy_check_mark: | The rating key of the metadata item. | 44288 |
|
| `ratingKey` | *String* | :heavy_check_mark: | The rating key (Media ID) of this media item. Note: Although this is always an integer, it is represented as a string in the API. | 58683 |
|
||||||
| `parentRatingKey` | *Optional\<String>* | :heavy_minus_sign: | The rating key of the parent of this metadata item. | 48047 |
|
| `key` | *String* | :heavy_check_mark: | The unique key for the media item. | /library/metadata/58683 |
|
||||||
| `grandparentRatingKey` | *Optional\<String>* | :heavy_minus_sign: | The rating key of the grandparent of this metadata item. | 45520 |
|
| `guid` | *String* | :heavy_check_mark: | The globally unique identifier for the media item. | plex://movie/5d7768ba96b655001fdc0408 |
|
||||||
| `parentGuid` | *Optional\<String>* | :heavy_minus_sign: | A GUID identifying the parent entity (e.g., season) for the item. | plex://season/618b89208dde18df707ad15c |
|
| `slug` | *String* | :heavy_check_mark: | A URL‐friendly version of the media title. | 4-for-texas |
|
||||||
| `grandparentGuid` | *Optional\<String>* | :heavy_minus_sign: | A GUID identifying the grandparent entity (e.g., show). | plex://show/5e16253691c20300412003a8 |
|
| `studio` | *Optional\<String>* | :heavy_minus_sign: | The studio that produced the media item. | 20th Century Studios |
|
||||||
| `grandparentSlug` | *Optional\<String>* | :heavy_minus_sign: | A URL-friendly identifier (slug) for the grandparent entity. | alice-in-borderland-2020 |
|
| `type` | [GetMediaMetaDataType](../../models/operations/GetMediaMetaDataType.md) | :heavy_check_mark: | N/A | movie |
|
||||||
| `grandparentKey` | *Optional\<String>* | :heavy_minus_sign: | A key identifying the grandparent metadata in the library. | /library/metadata/45520 |
|
| `title` | *String* | :heavy_check_mark: | The title of the media item. | Avatar: The Way of Water |
|
||||||
| `parentKey` | *Optional\<String>* | :heavy_minus_sign: | A key identifying the parent metadata in the library. | /library/metadata/48047 |
|
| `titleSort` | *String* | :heavy_check_mark: | The sort title used for ordering media items. | Whale |
|
||||||
| `key` | *String* | :heavy_check_mark: | The API key to access metadata details. | /library/metadata/44288/children |
|
| `contentRating` | *Optional\<String>* | :heavy_minus_sign: | The content rating for the media item. | PG-13 |
|
||||||
| `guid` | *String* | :heavy_check_mark: | The globally unique identifier for the item. | plex://show/5d9c08254eefaa001f5d6dcb |
|
| `summary` | *String* | :heavy_check_mark: | A synopsis of the media item. | Jake Sully lives with his newfound family formed on the extrasolar moon Pandora.<br/>Once a familiar threat returns to finish what was previously started, Jake must<br/>work with Neytiri and the army of the Na'vi race to protect their home.<br/> |
|
||||||
| `slug` | *Optional\<String>* | :heavy_minus_sign: | A URL-friendly identifier for the item. | better-call-saul |
|
| `rating` | *float* | :heavy_check_mark: | The critic rating for the media item. | 7.6 |
|
||||||
| `studio` | *Optional\<String>* | :heavy_minus_sign: | The studio that produced the content. | Sony Pictures Television |
|
| `audienceRating` | *double* | :heavy_check_mark: | The audience rating for the media item. | 9.2 |
|
||||||
| `type` | *String* | :heavy_check_mark: | The type of content (e.g., show, movie). | show |
|
| `year` | *Optional\<Integer>* | :heavy_minus_sign: | The release year of the media item. | 2022 |
|
||||||
| `title` | *String* | :heavy_check_mark: | The title of the content. | Better Call Saul |
|
| `tagline` | *String* | :heavy_check_mark: | A brief tagline for the media item. | Return to Pandora. |
|
||||||
| `originalTitle` | *Optional\<String>* | :heavy_minus_sign: | The original title of the content. | Wicked: Part I |
|
| `thumb` | *String* | :heavy_check_mark: | The thumbnail image URL for the media item. | /library/metadata/58683/thumb/1703239236 |
|
||||||
| `librarySectionTitle` | *String* | :heavy_check_mark: | The title of the library section. | TV Series |
|
| `art` | *String* | :heavy_check_mark: | The art image URL for the media item. | /library/metadata/58683/art/1703239236 |
|
||||||
| `librarySectionID` | *long* | :heavy_check_mark: | The ID of the library section. | 2 |
|
| `theme` | *String* | :heavy_check_mark: | The theme URL for the media item. | /library/metadata/1/theme/1705636920 |
|
||||||
| `librarySectionKey` | *String* | :heavy_check_mark: | The key of the library section. | /library/sections/2 |
|
| `index` | *int* | :heavy_check_mark: | The index position of the media item. | 1 |
|
||||||
| `contentRating` | *Optional\<String>* | :heavy_minus_sign: | The content rating (e.g., TV-MA). | TV-MA |
|
| `leafCount` | *Optional\<Integer>* | :heavy_minus_sign: | The number of leaf items (end nodes) under this media item. | 14 |
|
||||||
| `summary` | *String* | :heavy_check_mark: | A summary of the content. | Before Saul Goodman, he was Jimmy McGill. And if you're calling Jimmy, you're in real trouble. The prequel to "Breaking Bad" follows small-time attorney, Jimmy McGill, as he transforms into Walter White's morally challenged lawyer, Saul Goodman. |
|
| `viewedLeafCount` | *Optional\<Integer>* | :heavy_minus_sign: | The number of leaf items that have been viewed. | 0 |
|
||||||
| `index` | *Optional\<Long>* | :heavy_minus_sign: | The index or order of the item. | 1 |
|
| `childCount` | *int* | :heavy_check_mark: | The number of child items associated with this media item. | 1 |
|
||||||
| `grandparentTitle` | *Optional\<String>* | :heavy_minus_sign: | The title of the grandparent entity (typically the show's title). | Alice in Borderland |
|
| `seasonCount` | *int* | :heavy_check_mark: | The total number of seasons (for TV shows). | 2022 |
|
||||||
| `parentTitle` | *Optional\<String>* | :heavy_minus_sign: | The title of the parent entity (typically the season's title). | Season 2 |
|
| `duration` | *int* | :heavy_check_mark: | The duration of the media item in milliseconds. | 11558112 |
|
||||||
| `audienceRating` | *Optional\<Float>* | :heavy_minus_sign: | The audience rating for the content. | 8.7 |
|
| `originallyAvailableAt` | [LocalDate](https://docs.oracle.com/javase/8/docs/api/java/time/LocalDate.html) | :heavy_check_mark: | The original release date of the media item. | 2022-12-14 |
|
||||||
| `viewCount` | *Optional\<Long>* | :heavy_minus_sign: | The number of times the item has been viewed. | 4 |
|
| `addedAt` | *long* | :heavy_check_mark: | N/A | 1556281940 |
|
||||||
| `skipCount` | *Optional\<Long>* | :heavy_minus_sign: | The number of times the item has been skipped. | 1 |
|
| `updatedAt` | *Optional\<Long>* | :heavy_minus_sign: | Unix epoch datetime in seconds | 1556281940 |
|
||||||
| `lastViewedAt` | *Optional\<Long>* | :heavy_minus_sign: | Unix timestamp of when the item was last viewed. | 1625764795 |
|
| `audienceRatingImage` | *Optional\<String>* | :heavy_minus_sign: | The URL for the audience rating image. | rottentomatoes://image.rating.upright |
|
||||||
| `year` | *int* | :heavy_check_mark: | The release year. | 2015 |
|
| `chapterSource` | *Optional\<String>* | :heavy_minus_sign: | The source from which chapter data is derived. | media |
|
||||||
| `rating` | *Optional\<Float>* | :heavy_minus_sign: | The general rating | 6 |
|
| `primaryExtraKey` | *Optional\<String>* | :heavy_minus_sign: | The primary extra key associated with this media item. | /library/metadata/58684 |
|
||||||
| `ratingImage` | *Optional\<String>* | :heavy_minus_sign: | The URL or identifier for the rating image (e.g., Rotten Tomatoes rating image). | rottentomatoes://image.rating.ripe |
|
| `originalTitle` | *Optional\<String>* | :heavy_minus_sign: | The original title of the media item (if different). | 映画 ブラッククローバー 魔法帝の剣 |
|
||||||
| `tagline` | *Optional\<String>* | :heavy_minus_sign: | The tagline of the content. | Make the call |
|
| `parentRatingKey` | *Optional\<String>* | :heavy_minus_sign: | The rating key of the parent media item. | 66 |
|
||||||
| `chapterSource` | *Optional\<String>* | :heavy_minus_sign: | N/A | media |
|
| `grandparentRatingKey` | *Optional\<String>* | :heavy_minus_sign: | The rating key of the grandparent media item. | 66 |
|
||||||
| `primaryExtraKey` | *Optional\<String>* | :heavy_minus_sign: | N/A | /library/metadata/134704 |
|
| `parentGuid` | *Optional\<String>* | :heavy_minus_sign: | The GUID of the parent media item. | plex://show/5d9c081b170e24001f2a7be4 |
|
||||||
| `thumb` | *String* | :heavy_check_mark: | URL of the thumbnail image. | /library/metadata/44288/thumb/1736487993 |
|
| `grandparentGuid` | *Optional\<String>* | :heavy_minus_sign: | The GUID of the grandparent media item. | plex://show/5d9c081b170e24001f2a7be4 |
|
||||||
| `art` | *String* | :heavy_check_mark: | URL of the art image. | /library/metadata/44288/art/1736487993 |
|
| `grandparentSlug` | *Optional\<String>* | :heavy_minus_sign: | The slug for the grandparent media item. | alice-in-borderland-2020 |
|
||||||
| `theme` | *Optional\<String>* | :heavy_minus_sign: | URL of the theme image. | /library/metadata/44288/theme/1736487993 |
|
| `grandparentKey` | *Optional\<String>* | :heavy_minus_sign: | The key of the grandparent media item. | /library/metadata/66 |
|
||||||
| `duration` | *int* | :heavy_check_mark: | Duration of the content in milliseconds. | 2700000 |
|
| `parentKey` | *Optional\<String>* | :heavy_minus_sign: | The key of the parent media item. | /library/metadata/66 |
|
||||||
| `originallyAvailableAt` | [LocalDate](https://docs.oracle.com/javase/8/docs/api/java/time/LocalDate.html) | :heavy_minus_sign: | The original release date. | 2015-02-08 |
|
| `grandparentTitle` | *Optional\<String>* | :heavy_minus_sign: | The title of the grandparent media item. | Caprica |
|
||||||
| `leafCount` | *Optional\<Long>* | :heavy_minus_sign: | The total number of episodes (or leaves). | 63 |
|
| `grandparentThumb` | *Optional\<String>* | :heavy_minus_sign: | The thumbnail URL for the grandparent media item. | /library/metadata/66/thumb/1705716261 |
|
||||||
| `viewedLeafCount` | *Optional\<Long>* | :heavy_minus_sign: | The number of episodes that have been viewed. | 4 |
|
| `grandparentTheme` | *Optional\<String>* | :heavy_minus_sign: | The theme URL for the grandparent media item. | /library/metadata/66/theme/1705716261 |
|
||||||
| `childCount` | *Optional\<Integer>* | :heavy_minus_sign: | The number of child items. | 6 |
|
| `grandparentArt` | *Optional\<String>* | :heavy_minus_sign: | The art URL for the grandparent media item. | /library/metadata/66/art/1705716261 |
|
||||||
| `addedAt` | *long* | :heavy_check_mark: | N/A | 1556281940 |
|
| `parentTitle` | *Optional\<String>* | :heavy_minus_sign: | The title of the parent media item. | Caprica |
|
||||||
| `updatedAt` | *long* | :heavy_check_mark: | N/A | 1556281940 |
|
| `parentIndex` | *Optional\<Integer>* | :heavy_minus_sign: | The index position of the parent media item. | 1 |
|
||||||
| `audienceRatingImage` | *Optional\<String>* | :heavy_minus_sign: | The URL for the audience rating image. | themoviedb://image.rating |
|
| `parentThumb` | *Optional\<String>* | :heavy_minus_sign: | The thumbnail URL for the parent media item. | /library/metadata/66/thumb/1705716261 |
|
||||||
| `parentIndex` | *Optional\<Long>* | :heavy_minus_sign: | The index number of the parent entity, which could indicate its order or position. | 2 |
|
| `ratingImage` | *Optional\<String>* | :heavy_minus_sign: | The URL for the rating image. | rottentomatoes://image.rating.ripe |
|
||||||
| `parentThumb` | *Optional\<String>* | :heavy_minus_sign: | The URL of the parent's thumbnail image. | /library/metadata/48047/thumb/1671800243 |
|
| `viewCount` | *Optional\<Integer>* | :heavy_minus_sign: | The number of times this media item has been viewed. | 1 |
|
||||||
| `grandparentThumb` | *Optional\<String>* | :heavy_minus_sign: | The URL of the grandparent's thumbnail image. | /library/metadata/45520/thumb/1736488003 |
|
| `viewOffset` | *Optional\<Integer>* | :heavy_minus_sign: | The current playback offset (in milliseconds). | 5222500 |
|
||||||
| `grandparentArt` | *Optional\<String>* | :heavy_minus_sign: | The URL of the grandparent's art image. | /library/metadata/45520/art/1736488003 |
|
| `skipCount` | *Optional\<Integer>* | :heavy_minus_sign: | The number of times this media item has been skipped. | 1 |
|
||||||
| `media` | List\<[GetMediaMetaDataMedia](../../models/operations/GetMediaMetaDataMedia.md)> | :heavy_minus_sign: | N/A | |
|
| `subtype` | *Optional\<String>* | :heavy_minus_sign: | A classification that further describes the type of media item. For example, 'clip' indicates that the item is a short video clip. | clip |
|
||||||
| `image` | List\<[GetMediaMetaDataImage](../../models/operations/GetMediaMetaDataImage.md)> | :heavy_check_mark: | An array of image objects. | |
|
| `lastRatedAt` | *Optional\<Long>* | :heavy_minus_sign: | The Unix timestamp representing the last time the item was rated. | 1721813113 |
|
||||||
| `ultraBlurColors` | [GetMediaMetaDataUltraBlurColors](../../models/operations/GetMediaMetaDataUltraBlurColors.md) | :heavy_check_mark: | N/A | |
|
| `createdAtAccuracy` | *Optional\<String>* | :heavy_minus_sign: | The accuracy of the creation timestamp. This value indicates the format(s) provided (for example, 'epoch,local' means both epoch and local time formats are available). | epoch,local |
|
||||||
| `genre` | List\<[GetMediaMetaDataGenre](../../models/operations/GetMediaMetaDataGenre.md)> | :heavy_minus_sign: | An array of genre tags. | |
|
| `createdAtTZOffset` | *Optional\<String>* | :heavy_minus_sign: | The time zone offset for the creation timestamp, represented as a string. This offset indicates the difference from UTC. | 0 |
|
||||||
| `country` | List\<[GetMediaMetaDataCountry](../../models/operations/GetMediaMetaDataCountry.md)> | :heavy_minus_sign: | An array of country tags. | |
|
| `lastViewedAt` | *Optional\<Integer>* | :heavy_minus_sign: | Unix timestamp for when the media item was last viewed. | 1682752242 |
|
||||||
| `guids` | List\<[GetMediaMetaDataGuids](../../models/operations/GetMediaMetaDataGuids.md)> | :heavy_minus_sign: | An array of GUID objects. | |
|
| `userRating` | *Optional\<Float>* | :heavy_minus_sign: | The rating provided by a user for the item. This value is expressed as a decimal number. | 10 |
|
||||||
| `ratings` | List\<[Ratings](../../models/operations/Ratings.md)> | :heavy_minus_sign: | An array of rating objects. | |
|
| `image` | List\<[GetMediaMetaDataImage](../../models/operations/GetMediaMetaDataImage.md)> | :heavy_minus_sign: | N/A | |
|
||||||
| `role` | List\<[GetMediaMetaDataRole](../../models/operations/GetMediaMetaDataRole.md)> | :heavy_minus_sign: | An array of Actor roles. | |
|
| `ultraBlurColors` | [Optional\<GetMediaMetaDataUltraBlurColors>](../../models/operations/GetMediaMetaDataUltraBlurColors.md) | :heavy_minus_sign: | N/A | |
|
||||||
| `director` | List\<[GetMediaMetaDataDirector](../../models/operations/GetMediaMetaDataDirector.md)> | :heavy_minus_sign: | An array of Director roles. | |
|
| `librarySectionID` | *long* | :heavy_check_mark: | The identifier for the library section. | 1 |
|
||||||
| `writer` | List\<[GetMediaMetaDataWriter](../../models/operations/GetMediaMetaDataWriter.md)> | :heavy_minus_sign: | An array of Writer roles. | |
|
| `librarySectionTitle` | *String* | :heavy_check_mark: | The title of the library section. | Movies |
|
||||||
| `producer` | List\<[GetMediaMetaDataProducer](../../models/operations/GetMediaMetaDataProducer.md)> | :heavy_minus_sign: | An array of Writer roles. | |
|
| `librarySectionKey` | *String* | :heavy_check_mark: | The key corresponding to the library section. | /library/sections/1 |
|
||||||
| `similar` | List\<[GetMediaMetaDataSimilar](../../models/operations/GetMediaMetaDataSimilar.md)> | :heavy_minus_sign: | An array of similar content objects. | |
|
| `media` | List\<[GetMediaMetaDataMedia](../../models/operations/GetMediaMetaDataMedia.md)> | :heavy_minus_sign: | N/A | |
|
||||||
| `location` | List\<[GetMediaMetaDataLocation](../../models/operations/GetMediaMetaDataLocation.md)> | :heavy_minus_sign: | An array of location objects. | |
|
| `genre` | List\<[GetMediaMetaDataGenre](../../models/operations/GetMediaMetaDataGenre.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `country` | List\<[GetMediaMetaDataCountry](../../models/operations/GetMediaMetaDataCountry.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `director` | List\<[GetMediaMetaDataDirector](../../models/operations/GetMediaMetaDataDirector.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `writer` | List\<[GetMediaMetaDataWriter](../../models/operations/GetMediaMetaDataWriter.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `producer` | List\<[GetMediaMetaDataProducer](../../models/operations/GetMediaMetaDataProducer.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `role` | List\<[GetMediaMetaDataRole](../../models/operations/GetMediaMetaDataRole.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `guids` | List\<[GetMediaMetaDataGuids](../../models/operations/GetMediaMetaDataGuids.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `ratings` | List\<[Ratings](../../models/operations/Ratings.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `similar` | List\<[GetMediaMetaDataSimilar](../../models/operations/GetMediaMetaDataSimilar.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `location` | List\<[GetMediaMetaDataLocation](../../models/operations/GetMediaMetaDataLocation.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `chapter` | List\<[Chapter](../../models/operations/Chapter.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `marker` | List\<[Marker](../../models/operations/Marker.md)> | :heavy_minus_sign: | N/A | |
|
||||||
|
| `extras` | [Optional\<Extras>](../../models/operations/Extras.md) | :heavy_minus_sign: | N/A | |
|
||||||
@@ -3,11 +3,11 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
|
| ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | The unique role identifier. | 109501 |
|
| `id` | *long* | :heavy_check_mark: | Unique identifier for the actor or role. | 126522 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string for the role. | actor=109501 |
|
| `tag` | *String* | :heavy_check_mark: | The display tag for the actor (typically the actor's name). | Teller |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The actor's name. | Bob Odenkirk |
|
| `role` | *Optional\<String>* | :heavy_minus_sign: | The role played by the actor in the media item. | Self - Judge |
|
||||||
| `tagKey` | *String* | :heavy_check_mark: | A key associated with the actor tag. | 5d77683254f42c001f8c3f69 |
|
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this actor. For example, it may indicate that this is an actor with a given key. | actor=126522 |
|
||||||
| `role` | *Optional\<String>* | :heavy_minus_sign: | The character name or role. | Jimmy McGill |
|
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the actor's tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
||||||
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | URL for the role thumbnail image. | https://metadata-static.plex.tv/f/people/f2ca7b474cc984efbdd5c503a096285a.jpg |
|
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | The URL of the thumbnail image for the actor. | https://metadata-static.plex.tv/7/people/708568fd018d7aa8b1032dcf867747e8.jpg |
|
||||||
@@ -3,54 +3,56 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- |
|
| ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
||||||
| `streamType` | *int* | :heavy_check_mark: | Stream type (1=video, 2=audio, 3=subtitle). | 1 |
|
| `streamType` | [GetMediaMetaDataStreamType](../../models/operations/GetMediaMetaDataStreamType.md) | :heavy_check_mark: | Stream type:<br/> - 1 = video<br/> - 2 = audio<br/> - 3 = subtitle<br/> | 1 |
|
||||||
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
| `format` | *Optional\<String>* | :heavy_minus_sign: | Format of the stream (e.g., srt). | srt |
|
||||||
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
||||||
| `index` | *int* | :heavy_check_mark: | Index of the stream. | 0 |
|
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
||||||
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
| `index` | *Optional\<Integer>* | :heavy_minus_sign: | Index of the stream. | 0 |
|
||||||
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
||||||
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
||||||
| `languageCode` | *Optional\<String>* | :heavy_minus_sign: | ISO language code. | eng |
|
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
||||||
| `headerCompression` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates whether header compression is enabled. | true |
|
| `languageCode` | *Optional\<String>* | :heavy_minus_sign: | ISO language code. | eng |
|
||||||
| `doviblCompatID` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision BL compatibility ID. | 1 |
|
| `headerCompression` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates whether header compression is enabled. | true |
|
||||||
| `doviblPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision BL is present. | true |
|
| `doviblCompatID` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision BL compatibility ID. | 1 |
|
||||||
| `dovielPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision EL is present. | false |
|
| `doviblPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision BL is present. | true |
|
||||||
| `doviLevel` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision level. | 6 |
|
| `dovielPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision EL is present. | false |
|
||||||
| `doviPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision is present. | true |
|
| `doviLevel` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision level. | 6 |
|
||||||
| `doviProfile` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision profile. | 8 |
|
| `doviPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision is present. | true |
|
||||||
| `dovirpuPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision RPU is present. | true |
|
| `doviProfile` | *Optional\<Integer>* | :heavy_minus_sign: | Dolby Vision profile. | 8 |
|
||||||
| `doviVersion` | *Optional\<String>* | :heavy_minus_sign: | Dolby Vision version. | 1.0 |
|
| `dovirpuPresent` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if Dolby Vision RPU is present. | true |
|
||||||
| `bitDepth` | *Optional\<Integer>* | :heavy_minus_sign: | Bit depth of the video stream. | 10 |
|
| `doviVersion` | *Optional\<String>* | :heavy_minus_sign: | Dolby Vision version. | 1.0 |
|
||||||
| `chromaLocation` | *Optional\<String>* | :heavy_minus_sign: | Chroma sample location. | topleft |
|
| `bitDepth` | *Optional\<Integer>* | :heavy_minus_sign: | Bit depth of the video stream. | 10 |
|
||||||
| `chromaSubsampling` | *Optional\<String>* | :heavy_minus_sign: | Chroma subsampling format. | 4:2:0 |
|
| `chromaLocation` | *Optional\<String>* | :heavy_minus_sign: | Chroma sample location. | topleft |
|
||||||
| `codedHeight` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video height. | 1608 |
|
| `chromaSubsampling` | *Optional\<String>* | :heavy_minus_sign: | Chroma subsampling format. | 4:2:0 |
|
||||||
| `codedWidth` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video width. | 3840 |
|
| `codedHeight` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video height. | 1608 |
|
||||||
| `closedCaptions` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
| `codedWidth` | *Optional\<Integer>* | :heavy_minus_sign: | Coded video width. | 3840 |
|
||||||
| `colorPrimaries` | *Optional\<String>* | :heavy_minus_sign: | Color primaries used. | bt2020 |
|
| `closedCaptions` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
||||||
| `colorRange` | *Optional\<String>* | :heavy_minus_sign: | Color range (e.g., tv). | tv |
|
| `colorPrimaries` | *Optional\<String>* | :heavy_minus_sign: | Color primaries used. | bt2020 |
|
||||||
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
| `colorRange` | *Optional\<String>* | :heavy_minus_sign: | Color range (e.g., tv). | tv |
|
||||||
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
||||||
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
||||||
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
||||||
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
| `key` | *Optional\<String>* | :heavy_minus_sign: | Key to access this stream part. | /library/streams/216389 |
|
||||||
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
||||||
| `hasScalingMatrix` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | false |
|
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
||||||
| `profile` | *Optional\<String>* | :heavy_minus_sign: | Video profile. | main 10 |
|
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
||||||
| `scanType` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
| `hasScalingMatrix` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | false |
|
||||||
| `embeddedInVideo` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
| `profile` | *Optional\<String>* | :heavy_minus_sign: | Video profile. | main 10 |
|
||||||
| `refFrames` | *Optional\<Integer>* | :heavy_minus_sign: | Number of reference frames. | 1 |
|
| `scanType` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
||||||
| `width` | *Optional\<Integer>* | :heavy_minus_sign: | Width of the video stream. | 3840 |
|
| `embeddedInVideo` | *Optional\<String>* | :heavy_minus_sign: | N/A | progressive |
|
||||||
| `displayTitle` | *String* | :heavy_check_mark: | Display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
| `refFrames` | *Optional\<Integer>* | :heavy_minus_sign: | Number of reference frames. | 1 |
|
||||||
| `extendedDisplayTitle` | *String* | :heavy_check_mark: | Extended display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
| `width` | *Optional\<Integer>* | :heavy_minus_sign: | Width of the video stream. | 3840 |
|
||||||
| `selected` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is selected (applicable for audio streams). | true |
|
| `displayTitle` | *String* | :heavy_check_mark: | Display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
||||||
| `forced` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
| `extendedDisplayTitle` | *String* | :heavy_check_mark: | Extended display title for the stream. | 4K DoVi/HDR10 (HEVC Main 10) |
|
||||||
| `channels` | *Optional\<Integer>* | :heavy_minus_sign: | Number of audio channels (for audio streams). | 6 |
|
| `selected` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is selected (applicable for audio streams). | true |
|
||||||
| `audioChannelLayout` | *Optional\<String>* | :heavy_minus_sign: | Audio channel layout. | 5.1(side) |
|
| `forced` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
||||||
| `samplingRate` | *Optional\<Integer>* | :heavy_minus_sign: | Sampling rate for the audio stream. | 48000 |
|
| `channels` | *Optional\<Integer>* | :heavy_minus_sign: | Number of audio channels (for audio streams). | 6 |
|
||||||
| `canAutoSync` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream can auto-sync. | false |
|
| `audioChannelLayout` | *Optional\<String>* | :heavy_minus_sign: | Audio channel layout. | 5.1(side) |
|
||||||
| `hearingImpaired` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is for the hearing impaired. | true |
|
| `samplingRate` | *Optional\<Integer>* | :heavy_minus_sign: | Sampling rate for the audio stream. | 48000 |
|
||||||
| `dub` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is a dub. | true |
|
| `canAutoSync` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream can auto-sync. | false |
|
||||||
| `title` | *Optional\<String>* | :heavy_minus_sign: | Optional title for the stream (e.g., language variant). | SDH |
|
| `hearingImpaired` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is for the hearing impaired. | true |
|
||||||
|
| `dub` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if the stream is a dub. | true |
|
||||||
|
| `title` | *Optional\<String>* | :heavy_minus_sign: | Optional title for the stream (e.g., language variant). | SDH |
|
||||||
16
docs/models/operations/GetMediaMetaDataStreamType.md
Normal file
16
docs/models/operations/GetMediaMetaDataStreamType.md
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# GetMediaMetaDataStreamType
|
||||||
|
|
||||||
|
Stream type:
|
||||||
|
- 1 = video
|
||||||
|
- 2 = audio
|
||||||
|
- 3 = subtitle
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| ---------- | ---------- |
|
||||||
|
| `Video` | 1 |
|
||||||
|
| `Audio` | 2 |
|
||||||
|
| `Subtitle` | 3 |
|
||||||
16
docs/models/operations/GetMediaMetaDataType.md
Normal file
16
docs/models/operations/GetMediaMetaDataType.md
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# GetMediaMetaDataType
|
||||||
|
|
||||||
|
The type of media content
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| --------- | --------- |
|
||||||
|
| `Movie` | movie |
|
||||||
|
| `TvShow` | show |
|
||||||
|
| `Season` | season |
|
||||||
|
| `Episode` | episode |
|
||||||
|
| `Artist` | artist |
|
||||||
|
| `Album` | album |
|
||||||
@@ -3,9 +3,9 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ----------------------------- | ----------------------------- | ----------------------------- | ----------------------------- | ----------------------------- |
|
| ------------------ | ------------------ | ------------------ | ------------------ | ------------------ |
|
||||||
| `topLeft` | *String* | :heavy_check_mark: | The top-left color value. | 11333a |
|
| `topLeft` | *String* | :heavy_check_mark: | N/A | 11333b |
|
||||||
| `topRight` | *String* | :heavy_check_mark: | The top-right color value. | 1d2721 |
|
| `topRight` | *String* | :heavy_check_mark: | N/A | 0a232d |
|
||||||
| `bottomRight` | *String* | :heavy_check_mark: | The bottom-right color value. | 5c451d |
|
| `bottomRight` | *String* | :heavy_check_mark: | N/A | 73958 |
|
||||||
| `bottomLeft` | *String* | :heavy_check_mark: | The bottom-left color value. | 372c10 |
|
| `bottomLeft` | *String* | :heavy_check_mark: | N/A | 1f5066 |
|
||||||
@@ -3,11 +3,10 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
|
| ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | The unique role identifier. | 109501 |
|
| `id` | *int* | :heavy_check_mark: | Unique identifier for the writer. | 126522 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string for the role. | actor=109501 |
|
| `tag` | *String* | :heavy_check_mark: | The role of Writer | Jamie P. Hanson |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The actor's name. | Bob Odenkirk |
|
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this writer. | writer=126522 |
|
||||||
| `tagKey` | *String* | :heavy_check_mark: | A key associated with the actor tag. | 5d77683254f42c001f8c3f69 |
|
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | The URL of the thumbnail image for the writer. | https://metadata-static.plex.tv/8/people/8d65fa96804802e08f2de09fe014408e.jpg |
|
||||||
| `role` | *Optional\<String>* | :heavy_minus_sign: | The character name or role. | Jimmy McGill |
|
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the writers tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
||||||
| `thumb` | *Optional\<String>* | :heavy_minus_sign: | URL for the role thumbnail image. | https://metadata-static.plex.tv/f/people/f2ca7b474cc984efbdd5c503a096285a.jpg |
|
|
||||||
11
docs/models/operations/Hidden.md
Normal file
11
docs/models/operations/Hidden.md
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# Hidden
|
||||||
|
|
||||||
|
UNKNOWN
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| --------- | --------- |
|
||||||
|
| `Disable` | 0 |
|
||||||
|
| `Enable` | 1 |
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
# IncludeDetails
|
# IncludeDetails
|
||||||
|
|
||||||
Whether or not to include details for a section (types, filters, and sorts).
|
Whether or not to include details for a section (types, filters, and sorts).
|
||||||
Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
# Level
|
# Level
|
||||||
|
|
||||||
An integer log level to write to the PMS log with.
|
An integer log level to write to the PMS log with.
|
||||||
0: Error
|
0: Error
|
||||||
1: Warning
|
1: Warning
|
||||||
2: Info
|
2: Info
|
||||||
3: Debug
|
3: Debug
|
||||||
4: Verbose
|
4: Verbose
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- |
|
| --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- |
|
||||||
| `level` | [Level](../../models/operations/Level.md) | :heavy_check_mark: | An integer log level to write to the PMS log with. <br/>0: Error <br/>1: Warning <br/>2: Info <br/>3: Debug <br/>4: Verbose<br/> | |
|
| `level` | [Level](../../models/operations/Level.md) | :heavy_check_mark: | An integer log level to write to the PMS log with.<br/>0: Error<br/>1: Warning<br/>2: Info<br/>3: Debug<br/>4: Verbose<br/> | |
|
||||||
| `message` | *String* | :heavy_check_mark: | The text of the message to write to the log. | Test log message |
|
| `message` | *String* | :heavy_check_mark: | The text of the message to write to the log. | Test log message |
|
||||||
| `source` | *String* | :heavy_check_mark: | a string indicating the source of the message. | Postman |
|
| `source` | *String* | :heavy_check_mark: | a string indicating the source of the message. | Postman |
|
||||||
15
docs/models/operations/Marker.md
Normal file
15
docs/models/operations/Marker.md
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
# Marker
|
||||||
|
|
||||||
|
The final status of the marker
|
||||||
|
|
||||||
|
|
||||||
|
## Fields
|
||||||
|
|
||||||
|
| Field | Type | Required | Description | Example |
|
||||||
|
| -------------------------------------------------------------- | -------------------------------------------------------------- | -------------------------------------------------------------- | -------------------------------------------------------------- | -------------------------------------------------------------- |
|
||||||
|
| `id` | *long* | :heavy_check_mark: | N/A | 306970 |
|
||||||
|
| `type` | *String* | :heavy_check_mark: | N/A | credits |
|
||||||
|
| `startTimeOffset` | *long* | :heavy_check_mark: | N/A | 4176050 |
|
||||||
|
| `endTimeOffset` | *long* | :heavy_check_mark: | N/A | 4393389 |
|
||||||
|
| `final_` | *Optional\<Boolean>* | :heavy_minus_sign: | N/A | true |
|
||||||
|
| `attributes` | [Optional\<Attributes>](../../models/operations/Attributes.md) | :heavy_minus_sign: | Attributes associated with the marker. | |
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- |
|
| ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | Unique identifier for the producer. | 126522 |
|
| `id` | *int* | :heavy_check_mark: | Unique identifier for the producer. | 126522 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this producer. | producer=126522 |
|
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this producer. | producer=126522 |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The name of the producer | Amelia Knapp |
|
| `tag` | *String* | :heavy_check_mark: | The name of the producer | Amelia Knapp |
|
||||||
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the producer's tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the producer's tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
# QueryParamForce
|
# QueryParamForce
|
||||||
|
|
||||||
Force overwriting of duplicate playlists.
|
Force overwriting of duplicate playlists.
|
||||||
By default, a playlist file uploaded with the same path will overwrite the existing playlist.
|
By default, a playlist file uploaded with the same path will overwrite the existing playlist.
|
||||||
The `force` argument is used to disable overwriting.
|
The `force` argument is used to disable overwriting.
|
||||||
If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.
|
If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -6,10 +6,11 @@
|
|||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- |
|
| -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- | -------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
| `id` | *long* | :heavy_check_mark: | Unique stream identifier. | 1002625 |
|
||||||
| `streamType` | *int* | :heavy_check_mark: | Stream type (1=video, 2=audio, 3=subtitle). | 1 |
|
| `streamType` | [StreamType](../../models/operations/StreamType.md) | :heavy_check_mark: | Stream type:<br/> - 1 = video<br/> - 2 = audio<br/> - 3 = subtitle<br/> | 1 |
|
||||||
|
| `format` | *Optional\<String>* | :heavy_minus_sign: | Format of the stream (e.g., srt). | srt |
|
||||||
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
| `default_` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this stream is default. | true |
|
||||||
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
| `codec` | *String* | :heavy_check_mark: | Codec used by the stream. | hevc |
|
||||||
| `index` | *int* | :heavy_check_mark: | Index of the stream. | 0 |
|
| `index` | *Optional\<Integer>* | :heavy_minus_sign: | Index of the stream. | 0 |
|
||||||
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
| `bitrate` | *Optional\<Integer>* | :heavy_minus_sign: | Bitrate of the stream. | 24743 |
|
||||||
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
| `language` | *Optional\<String>* | :heavy_minus_sign: | Language of the stream. | English |
|
||||||
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
| `languageTag` | *Optional\<String>* | :heavy_minus_sign: | Language tag (e.g., en). | en |
|
||||||
@@ -34,6 +35,7 @@
|
|||||||
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
| `colorSpace` | *Optional\<String>* | :heavy_minus_sign: | Color space. | bt2020nc |
|
||||||
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
| `colorTrc` | *Optional\<String>* | :heavy_minus_sign: | Color transfer characteristics. | smpte2084 |
|
||||||
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
| `frameRate` | *Optional\<Float>* | :heavy_minus_sign: | Frame rate of the stream. | 23.976 |
|
||||||
|
| `key` | *Optional\<String>* | :heavy_minus_sign: | Key to access this stream part. | /library/streams/216389 |
|
||||||
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
| `height` | *Optional\<Integer>* | :heavy_minus_sign: | Height of the video stream. | 1602 |
|
||||||
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
| `level` | *Optional\<Integer>* | :heavy_minus_sign: | Video level. | 150 |
|
||||||
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
| `original` | *Optional\<Boolean>* | :heavy_minus_sign: | Indicates if this is the original stream. | true |
|
||||||
|
|||||||
16
docs/models/operations/StreamType.md
Normal file
16
docs/models/operations/StreamType.md
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# StreamType
|
||||||
|
|
||||||
|
Stream type:
|
||||||
|
- 1 = video
|
||||||
|
- 2 = audio
|
||||||
|
- 3 = subtitle
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Values
|
||||||
|
|
||||||
|
| Name | Value |
|
||||||
|
| ---------- | ---------- |
|
||||||
|
| `Video` | 1 |
|
||||||
|
| `Audio` | 2 |
|
||||||
|
| `Subtitle` | 3 |
|
||||||
@@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
## Fields
|
## Fields
|
||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `path` | *String* | :heavy_check_mark: | absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server. <br/>If the `path` argument is a directory, that path will be scanned for playlist files to be processed. <br/>Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it. <br/>The GUID of each playlist is based on the filename. <br/>If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it. <br/>The GUID of each playlist is based on the filename.<br/> | /home/barkley/playlist.m3u |
|
| `path` | *String* | :heavy_check_mark: | absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server.<br/>If the `path` argument is a directory, that path will be scanned for playlist files to be processed.<br/>Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it.<br/>The GUID of each playlist is based on the filename.<br/>If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it.<br/>The GUID of each playlist is based on the filename.<br/> | /home/barkley/playlist.m3u |
|
||||||
| `force` | [QueryParamForce](../../models/operations/QueryParamForce.md) | :heavy_check_mark: | Force overwriting of duplicate playlists. <br/>By default, a playlist file uploaded with the same path will overwrite the existing playlist. <br/>The `force` argument is used to disable overwriting. <br/>If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.<br/> | |
|
| `force` | [QueryParamForce](../../models/operations/QueryParamForce.md) | :heavy_check_mark: | Force overwriting of duplicate playlists.<br/>By default, a playlist file uploaded with the same path will overwrite the existing playlist.<br/>The `force` argument is used to disable overwriting.<br/>If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.<br/> | |
|
||||||
| `sectionID` | *long* | :heavy_check_mark: | Possibly the section ID to upload the playlist to, we are not certain. | 1 |
|
| `sectionID` | *long* | :heavy_check_mark: | Possibly the section ID to upload the playlist to, we are not certain. | 1 |
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
| Field | Type | Required | Description | Example |
|
| Field | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- |
|
| ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- |
|
||||||
| `id` | *long* | :heavy_check_mark: | Unique identifier for the writer. | 126522 |
|
| `id` | *int* | :heavy_check_mark: | Unique identifier for the writer. | 126522 |
|
||||||
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this writer. | writer=126522 |
|
| `filter` | *String* | :heavy_check_mark: | The filter string used to query this writer. | writer=126522 |
|
||||||
| `tag` | *String* | :heavy_check_mark: | The role of Writer | Jamie P. Hanson |
|
| `tag` | *String* | :heavy_check_mark: | The role of Writer | Jamie P. Hanson |
|
||||||
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the writers tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
| `tagKey` | *Optional\<String>* | :heavy_minus_sign: | A unique key associated with the writers tag, used for internal identification. | 5d77683d85719b001f3a535e |
|
||||||
@@ -25,7 +25,6 @@ import dev.plexapi.sdk.PlexAPI;
|
|||||||
import dev.plexapi.sdk.models.errors.GetGlobalHubsBadRequest;
|
import dev.plexapi.sdk.models.errors.GetGlobalHubsBadRequest;
|
||||||
import dev.plexapi.sdk.models.errors.GetGlobalHubsUnauthorized;
|
import dev.plexapi.sdk.models.errors.GetGlobalHubsUnauthorized;
|
||||||
import dev.plexapi.sdk.models.operations.GetGlobalHubsResponse;
|
import dev.plexapi.sdk.models.operations.GetGlobalHubsResponse;
|
||||||
import dev.plexapi.sdk.models.operations.OnlyTransient;
|
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
@@ -37,8 +36,6 @@ public class Application {
|
|||||||
.build();
|
.build();
|
||||||
|
|
||||||
GetGlobalHubsResponse res = sdk.hubs().getGlobalHubs()
|
GetGlobalHubsResponse res = sdk.hubs().getGlobalHubs()
|
||||||
.count(1262.49)
|
|
||||||
.onlyTransient(OnlyTransient.ONE)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
if (res.object().isPresent()) {
|
if (res.object().isPresent()) {
|
||||||
@@ -136,7 +133,6 @@ import dev.plexapi.sdk.PlexAPI;
|
|||||||
import dev.plexapi.sdk.models.errors.GetLibraryHubsBadRequest;
|
import dev.plexapi.sdk.models.errors.GetLibraryHubsBadRequest;
|
||||||
import dev.plexapi.sdk.models.errors.GetLibraryHubsUnauthorized;
|
import dev.plexapi.sdk.models.errors.GetLibraryHubsUnauthorized;
|
||||||
import dev.plexapi.sdk.models.operations.GetLibraryHubsResponse;
|
import dev.plexapi.sdk.models.operations.GetLibraryHubsResponse;
|
||||||
import dev.plexapi.sdk.models.operations.QueryParamOnlyTransient;
|
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
@@ -149,8 +145,6 @@ public class Application {
|
|||||||
|
|
||||||
GetLibraryHubsResponse res = sdk.hubs().getLibraryHubs()
|
GetLibraryHubsResponse res = sdk.hubs().getLibraryHubs()
|
||||||
.sectionId(6728.76)
|
.sectionId(6728.76)
|
||||||
.count(6728.76)
|
|
||||||
.onlyTransient(QueryParamOnlyTransient.ZERO)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
if (res.object().isPresent()) {
|
if (res.object().isPresent()) {
|
||||||
|
|||||||
@@ -54,7 +54,6 @@ public class Application {
|
|||||||
|
|
||||||
GetFileHashResponse res = sdk.library().getFileHash()
|
GetFileHashResponse res = sdk.library().getFileHash()
|
||||||
.url("file://C:\Image.png&type=13")
|
.url("file://C:\Image.png&type=13")
|
||||||
.type(4462.17)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
@@ -209,14 +208,14 @@ public class Application {
|
|||||||
|
|
||||||
## Library Details Endpoint
|
## Library Details Endpoint
|
||||||
|
|
||||||
This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
||||||
|
|
||||||
The details include:
|
The details include:
|
||||||
|
|
||||||
### Directories
|
### Directories
|
||||||
Organized into three categories:
|
Organized into three categories:
|
||||||
|
|
||||||
- **Primary Directories**:
|
- **Primary Directories**:
|
||||||
- Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
- Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
||||||
- Most can be replicated via media queries.
|
- Most can be replicated via media queries.
|
||||||
- Customizable by users.
|
- Customizable by users.
|
||||||
@@ -257,7 +256,6 @@ import dev.plexapi.sdk.PlexAPI;
|
|||||||
import dev.plexapi.sdk.models.errors.GetLibraryDetailsBadRequest;
|
import dev.plexapi.sdk.models.errors.GetLibraryDetailsBadRequest;
|
||||||
import dev.plexapi.sdk.models.errors.GetLibraryDetailsUnauthorized;
|
import dev.plexapi.sdk.models.errors.GetLibraryDetailsUnauthorized;
|
||||||
import dev.plexapi.sdk.models.operations.GetLibraryDetailsResponse;
|
import dev.plexapi.sdk.models.operations.GetLibraryDetailsResponse;
|
||||||
import dev.plexapi.sdk.models.operations.IncludeDetails;
|
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
@@ -269,7 +267,6 @@ public class Application {
|
|||||||
.build();
|
.build();
|
||||||
|
|
||||||
GetLibraryDetailsResponse res = sdk.library().getLibraryDetails()
|
GetLibraryDetailsResponse res = sdk.library().getLibraryDetails()
|
||||||
.includeDetails(IncludeDetails.ZERO)
|
|
||||||
.sectionKey(9518)
|
.sectionKey(9518)
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
@@ -282,10 +279,10 @@ public class Application {
|
|||||||
|
|
||||||
### Parameters
|
### Parameters
|
||||||
|
|
||||||
| Parameter | Type | Required | Description | Example |
|
| Parameter | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `includeDetails` | [Optional\<IncludeDetails>](../../models/operations/IncludeDetails.md) | :heavy_minus_sign: | Whether or not to include details for a section (types, filters, and sorts). <br/>Only exists for backwards compatibility, media providers other than the server libraries have it on always.<br/> | |
|
| `includeDetails` | [Optional\<IncludeDetails>](../../models/operations/IncludeDetails.md) | :heavy_minus_sign: | Whether or not to include details for a section (types, filters, and sorts).<br/>Only exists for backwards compatibility, media providers other than the server libraries have it on always.<br/> | |
|
||||||
| `sectionKey` | *int* | :heavy_check_mark: | The unique key of the Plex library. <br/>Note: This is unique in the context of the Plex server.<br/> | 9518 |
|
| `sectionKey` | *int* | :heavy_check_mark: | The unique key of the Plex library. <br/>Note: This is unique in the context of the Plex server.<br/> | 9518 |
|
||||||
|
|
||||||
### Response
|
### Response
|
||||||
|
|
||||||
@@ -973,7 +970,6 @@ package hello.world;
|
|||||||
import dev.plexapi.sdk.PlexAPI;
|
import dev.plexapi.sdk.PlexAPI;
|
||||||
import dev.plexapi.sdk.models.operations.PostMediaArtsResponse;
|
import dev.plexapi.sdk.models.operations.PostMediaArtsResponse;
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
|
|
||||||
@@ -986,7 +982,6 @@ public class Application {
|
|||||||
PostMediaArtsResponse res = sdk.library().postMediaArts()
|
PostMediaArtsResponse res = sdk.library().postMediaArts()
|
||||||
.ratingKey(2268L)
|
.ratingKey(2268L)
|
||||||
.url("https://api.mediux.pro/assets/fcfdc487-dd07-4993-a0c1-0a3015362e5b")
|
.url("https://api.mediux.pro/assets/fcfdc487-dd07-4993-a0c1-0a3015362e5b")
|
||||||
.requestBody("0xee51EFC6De".getBytes(StandardCharsets.UTF_8))
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
@@ -1072,7 +1067,6 @@ package hello.world;
|
|||||||
import dev.plexapi.sdk.PlexAPI;
|
import dev.plexapi.sdk.PlexAPI;
|
||||||
import dev.plexapi.sdk.models.operations.PostMediaPosterResponse;
|
import dev.plexapi.sdk.models.operations.PostMediaPosterResponse;
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
|
|
||||||
@@ -1085,7 +1079,6 @@ public class Application {
|
|||||||
PostMediaPosterResponse res = sdk.library().postMediaPoster()
|
PostMediaPosterResponse res = sdk.library().postMediaPoster()
|
||||||
.ratingKey(2268L)
|
.ratingKey(2268L)
|
||||||
.url("https://api.mediux.pro/assets/fcfdc487-dd07-4993-a0c1-0a3015362e5b")
|
.url("https://api.mediux.pro/assets/fcfdc487-dd07-4993-a0c1-0a3015362e5b")
|
||||||
.requestBody("0x7C3d45ad4B".getBytes(StandardCharsets.UTF_8))
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
|
|||||||
@@ -50,11 +50,11 @@ public class Application {
|
|||||||
|
|
||||||
### Parameters
|
### Parameters
|
||||||
|
|
||||||
| Parameter | Type | Required | Description | Example |
|
| Parameter | Type | Required | Description | Example |
|
||||||
| ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- |
|
| --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- |
|
||||||
| `level` | [Level](../../models/operations/Level.md) | :heavy_check_mark: | An integer log level to write to the PMS log with. <br/>0: Error <br/>1: Warning <br/>2: Info <br/>3: Debug <br/>4: Verbose<br/> | |
|
| `level` | [Level](../../models/operations/Level.md) | :heavy_check_mark: | An integer log level to write to the PMS log with.<br/>0: Error<br/>1: Warning<br/>2: Info<br/>3: Debug<br/>4: Verbose<br/> | |
|
||||||
| `message` | *String* | :heavy_check_mark: | The text of the message to write to the log. | Test log message |
|
| `message` | *String* | :heavy_check_mark: | The text of the message to write to the log. | Test log message |
|
||||||
| `source` | *String* | :heavy_check_mark: | a string indicating the source of the message. | Postman |
|
| `source` | *String* | :heavy_check_mark: | a string indicating the source of the message. | Postman |
|
||||||
|
|
||||||
### Response
|
### Response
|
||||||
|
|
||||||
@@ -70,13 +70,13 @@ public class Application {
|
|||||||
|
|
||||||
## logMultiLine
|
## logMultiLine
|
||||||
|
|
||||||
This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
||||||
It accepts a text/plain request body, where each line represents a distinct log entry.
|
It accepts a text/plain request body, where each line represents a distinct log entry.
|
||||||
Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
||||||
|
|
||||||
Log entries are separated by a newline character (`\n`).
|
Log entries are separated by a newline character (`\n`).
|
||||||
Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
||||||
This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
||||||
|
|
||||||
The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
||||||
- `0`: Error - Critical issues that require immediate attention.
|
- `0`: Error - Critical issues that require immediate attention.
|
||||||
|
|||||||
@@ -3,9 +3,9 @@
|
|||||||
|
|
||||||
## Overview
|
## Overview
|
||||||
|
|
||||||
Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
||||||
They can be organized in (optionally nesting) folders.
|
They can be organized in (optionally nesting) folders.
|
||||||
Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
||||||
This may cause the duration and number of items to change.
|
This may cause the duration and number of items to change.
|
||||||
|
|
||||||
|
|
||||||
@@ -95,7 +95,7 @@ package hello.world;
|
|||||||
import dev.plexapi.sdk.PlexAPI;
|
import dev.plexapi.sdk.PlexAPI;
|
||||||
import dev.plexapi.sdk.models.errors.GetPlaylistsBadRequest;
|
import dev.plexapi.sdk.models.errors.GetPlaylistsBadRequest;
|
||||||
import dev.plexapi.sdk.models.errors.GetPlaylistsUnauthorized;
|
import dev.plexapi.sdk.models.errors.GetPlaylistsUnauthorized;
|
||||||
import dev.plexapi.sdk.models.operations.*;
|
import dev.plexapi.sdk.models.operations.GetPlaylistsResponse;
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
@@ -107,8 +107,6 @@ public class Application {
|
|||||||
.build();
|
.build();
|
||||||
|
|
||||||
GetPlaylistsResponse res = sdk.playlists().getPlaylists()
|
GetPlaylistsResponse res = sdk.playlists().getPlaylists()
|
||||||
.playlistType(PlaylistType.AUDIO)
|
|
||||||
.smart(QueryParamSmart.ZERO)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
if (res.object().isPresent()) {
|
if (res.object().isPresent()) {
|
||||||
@@ -268,8 +266,6 @@ public class Application {
|
|||||||
|
|
||||||
UpdatePlaylistResponse res = sdk.playlists().updatePlaylist()
|
UpdatePlaylistResponse res = sdk.playlists().updatePlaylist()
|
||||||
.playlistID(3915)
|
.playlistID(3915)
|
||||||
.title("<value>")
|
|
||||||
.summary("<value>")
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
@@ -503,11 +499,11 @@ public class Application {
|
|||||||
|
|
||||||
### Parameters
|
### Parameters
|
||||||
|
|
||||||
| Parameter | Type | Required | Description | Example |
|
| Parameter | Type | Required | Description | Example |
|
||||||
| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `path` | *String* | :heavy_check_mark: | absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server. <br/>If the `path` argument is a directory, that path will be scanned for playlist files to be processed. <br/>Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it. <br/>The GUID of each playlist is based on the filename. <br/>If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it. <br/>The GUID of each playlist is based on the filename.<br/> | /home/barkley/playlist.m3u |
|
| `path` | *String* | :heavy_check_mark: | absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server.<br/>If the `path` argument is a directory, that path will be scanned for playlist files to be processed.<br/>Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it.<br/>The GUID of each playlist is based on the filename.<br/>If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it.<br/>The GUID of each playlist is based on the filename.<br/> | /home/barkley/playlist.m3u |
|
||||||
| `force` | [QueryParamForce](../../models/operations/QueryParamForce.md) | :heavy_check_mark: | Force overwriting of duplicate playlists. <br/>By default, a playlist file uploaded with the same path will overwrite the existing playlist. <br/>The `force` argument is used to disable overwriting. <br/>If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.<br/> | |
|
| `force` | [QueryParamForce](../../models/operations/QueryParamForce.md) | :heavy_check_mark: | Force overwriting of duplicate playlists.<br/>By default, a playlist file uploaded with the same path will overwrite the existing playlist.<br/>The `force` argument is used to disable overwriting.<br/>If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.<br/> | |
|
||||||
| `sectionID` | *long* | :heavy_check_mark: | Possibly the section ID to upload the playlist to, we are not certain. | 1 |
|
| `sectionID` | *long* | :heavy_check_mark: | Possibly the section ID to upload the playlist to, we are not certain. | 1 |
|
||||||
|
|
||||||
### Response
|
### Response
|
||||||
|
|
||||||
|
|||||||
@@ -225,7 +225,7 @@ package hello.world;
|
|||||||
import dev.plexapi.sdk.PlexAPI;
|
import dev.plexapi.sdk.PlexAPI;
|
||||||
import dev.plexapi.sdk.models.errors.GetServerResourcesBadRequest;
|
import dev.plexapi.sdk.models.errors.GetServerResourcesBadRequest;
|
||||||
import dev.plexapi.sdk.models.errors.GetServerResourcesUnauthorized;
|
import dev.plexapi.sdk.models.errors.GetServerResourcesUnauthorized;
|
||||||
import dev.plexapi.sdk.models.operations.*;
|
import dev.plexapi.sdk.models.operations.GetServerResourcesResponse;
|
||||||
import java.lang.Exception;
|
import java.lang.Exception;
|
||||||
|
|
||||||
public class Application {
|
public class Application {
|
||||||
@@ -237,9 +237,6 @@ public class Application {
|
|||||||
.build();
|
.build();
|
||||||
|
|
||||||
GetServerResourcesResponse res = sdk.plex().getServerResources()
|
GetServerResourcesResponse res = sdk.plex().getServerResources()
|
||||||
.includeHttps(IncludeHttps.Enable)
|
|
||||||
.includeRelay(IncludeRelay.Enable)
|
|
||||||
.includeIPv6(IncludeIPv6.Enable)
|
|
||||||
.clientID("3381b62b-9ab7-4e37-827b-203e9809eb58")
|
.clientID("3381b62b-9ab7-4e37-827b-203e9809eb58")
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
|
|||||||
@@ -49,8 +49,6 @@ public class Application {
|
|||||||
|
|
||||||
PerformSearchResponse res = sdk.search().performSearch()
|
PerformSearchResponse res = sdk.search().performSearch()
|
||||||
.query("dylan")
|
.query("dylan")
|
||||||
.sectionId(9487.88)
|
|
||||||
.limit(5)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
@@ -107,8 +105,6 @@ public class Application {
|
|||||||
|
|
||||||
PerformVoiceSearchResponse res = sdk.search().performVoiceSearch()
|
PerformVoiceSearchResponse res = sdk.search().performVoiceSearch()
|
||||||
.query("dead+poop")
|
.query("dead+poop")
|
||||||
.sectionId(4094.8)
|
|
||||||
.limit(5)
|
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
// handle response
|
// handle response
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
groupId=dev.plexapi
|
groupId=dev.plexapi
|
||||||
artifactId=plexapi
|
artifactId=plexapi
|
||||||
version=0.14.1
|
version=0.16.1
|
||||||
@@ -700,14 +700,14 @@ public class Library implements
|
|||||||
*
|
*
|
||||||
* <p>## Library Details Endpoint
|
* <p>## Library Details Endpoint
|
||||||
*
|
*
|
||||||
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
||||||
*
|
*
|
||||||
* <p>The details include:
|
* <p>The details include:
|
||||||
*
|
*
|
||||||
* <p>### Directories
|
* <p>### Directories
|
||||||
* Organized into three categories:
|
* Organized into three categories:
|
||||||
*
|
*
|
||||||
* <p>- **Primary Directories**:
|
* <p>- **Primary Directories**:
|
||||||
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
||||||
* - Most can be replicated via media queries.
|
* - Most can be replicated via media queries.
|
||||||
* - Customizable by users.
|
* - Customizable by users.
|
||||||
@@ -749,14 +749,14 @@ public class Library implements
|
|||||||
*
|
*
|
||||||
* <p>## Library Details Endpoint
|
* <p>## Library Details Endpoint
|
||||||
*
|
*
|
||||||
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
||||||
*
|
*
|
||||||
* <p>The details include:
|
* <p>The details include:
|
||||||
*
|
*
|
||||||
* <p>### Directories
|
* <p>### Directories
|
||||||
* Organized into three categories:
|
* Organized into three categories:
|
||||||
*
|
*
|
||||||
* <p>- **Primary Directories**:
|
* <p>- **Primary Directories**:
|
||||||
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
||||||
* - Most can be replicated via media queries.
|
* - Most can be replicated via media queries.
|
||||||
* - Customizable by users.
|
* - Customizable by users.
|
||||||
@@ -803,14 +803,14 @@ public class Library implements
|
|||||||
*
|
*
|
||||||
* <p>## Library Details Endpoint
|
* <p>## Library Details Endpoint
|
||||||
*
|
*
|
||||||
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
* <p>This endpoint provides comprehensive details about the library, focusing on organizational aspects rather than the content itself.
|
||||||
*
|
*
|
||||||
* <p>The details include:
|
* <p>The details include:
|
||||||
*
|
*
|
||||||
* <p>### Directories
|
* <p>### Directories
|
||||||
* Organized into three categories:
|
* Organized into three categories:
|
||||||
*
|
*
|
||||||
* <p>- **Primary Directories**:
|
* <p>- **Primary Directories**:
|
||||||
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
* - Used in some clients for quick access to media subsets (e.g., "All", "On Deck").
|
||||||
* - Most can be replicated via media queries.
|
* - Most can be replicated via media queries.
|
||||||
* - Customizable by users.
|
* - Customizable by users.
|
||||||
@@ -841,7 +841,7 @@ public class Library implements
|
|||||||
*
|
*
|
||||||
* <p>> **Note**: Filters and sorts are optional; without them, no filtering controls are rendered.
|
* <p>> **Note**: Filters and sorts are optional; without them, no filtering controls are rendered.
|
||||||
*
|
*
|
||||||
* @param includeDetails Whether or not to include details for a section (types, filters, and sorts).
|
* @param includeDetails Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*
|
*
|
||||||
* @param sectionKey The unique key of the Plex library.
|
* @param sectionKey The unique key of the Plex library.
|
||||||
|
|||||||
@@ -68,11 +68,11 @@ public class Log implements
|
|||||||
*
|
*
|
||||||
* <p>This endpoint will write a single-line log message, including a level and source to the main Plex Media Server log.
|
* <p>This endpoint will write a single-line log message, including a level and source to the main Plex Media Server log.
|
||||||
*
|
*
|
||||||
* @param level An integer log level to write to the PMS log with.
|
* @param level An integer log level to write to the PMS log with.
|
||||||
* 0: Error
|
* 0: Error
|
||||||
* 1: Warning
|
* 1: Warning
|
||||||
* 2: Info
|
* 2: Info
|
||||||
* 3: Debug
|
* 3: Debug
|
||||||
* 4: Verbose
|
* 4: Verbose
|
||||||
*
|
*
|
||||||
* @param message The text of the message to write to the log.
|
* @param message The text of the message to write to the log.
|
||||||
@@ -232,13 +232,13 @@ public class Log implements
|
|||||||
/**
|
/**
|
||||||
* Logging a multi-line message
|
* Logging a multi-line message
|
||||||
*
|
*
|
||||||
* <p>This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
* <p>This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
||||||
* It accepts a text/plain request body, where each line represents a distinct log entry.
|
* It accepts a text/plain request body, where each line represents a distinct log entry.
|
||||||
* Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
* Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
||||||
*
|
*
|
||||||
* <p>Log entries are separated by a newline character (`\n`).
|
* <p>Log entries are separated by a newline character (`\n`).
|
||||||
* Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
* Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
||||||
* This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
* This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
||||||
*
|
*
|
||||||
* <p>The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
* <p>The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
||||||
* - `0`: Error - Critical issues that require immediate attention.
|
* - `0`: Error - Critical issues that require immediate attention.
|
||||||
@@ -263,13 +263,13 @@ public class Log implements
|
|||||||
/**
|
/**
|
||||||
* Logging a multi-line message
|
* Logging a multi-line message
|
||||||
*
|
*
|
||||||
* <p>This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
* <p>This endpoint allows for the batch addition of log entries to the main Plex Media Server log.
|
||||||
* It accepts a text/plain request body, where each line represents a distinct log entry.
|
* It accepts a text/plain request body, where each line represents a distinct log entry.
|
||||||
* Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
* Each log entry consists of URL-encoded key-value pairs, specifying log attributes such as 'level', 'message', and 'source'.
|
||||||
*
|
*
|
||||||
* <p>Log entries are separated by a newline character (`\n`).
|
* <p>Log entries are separated by a newline character (`\n`).
|
||||||
* Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
* Each entry's parameters should be URL-encoded to ensure accurate parsing and handling of special characters.
|
||||||
* This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
* This method is efficient for logging multiple entries in a single API call, reducing the overhead of multiple individual requests.
|
||||||
*
|
*
|
||||||
* <p>The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
* <p>The 'level' parameter specifies the log entry's severity or importance, with the following integer values:
|
||||||
* - `0`: Error - Critical issues that require immediate attention.
|
* - `0`: Error - Critical issues that require immediate attention.
|
||||||
|
|||||||
@@ -76,9 +76,9 @@ import java.util.List;
|
|||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
||||||
* They can be organized in (optionally nesting) folders.
|
* They can be organized in (optionally nesting) folders.
|
||||||
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
||||||
* This may cause the duration and number of items to change.
|
* This may cause the duration and number of items to change.
|
||||||
*/
|
*/
|
||||||
public class Playlists implements
|
public class Playlists implements
|
||||||
@@ -1562,16 +1562,16 @@ public class Playlists implements
|
|||||||
*
|
*
|
||||||
* <p>Imports m3u playlists by passing a path on the server to scan for m3u-formatted playlist files, or a path to a single playlist file.
|
* <p>Imports m3u playlists by passing a path on the server to scan for m3u-formatted playlist files, or a path to a single playlist file.
|
||||||
*
|
*
|
||||||
* @param path absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server.
|
* @param path absolute path to a directory on the server where m3u files are stored, or the absolute path to a playlist file on the server.
|
||||||
* If the `path` argument is a directory, that path will be scanned for playlist files to be processed.
|
* If the `path` argument is a directory, that path will be scanned for playlist files to be processed.
|
||||||
* Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it.
|
* Each file in that directory creates a separate playlist, with a name based on the filename of the file that created it.
|
||||||
* The GUID of each playlist is based on the filename.
|
* The GUID of each playlist is based on the filename.
|
||||||
* If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it.
|
* If the `path` argument is a file, that file will be used to create a new playlist, with the name based on the filename of the file that created it.
|
||||||
* The GUID of each playlist is based on the filename.
|
* The GUID of each playlist is based on the filename.
|
||||||
*
|
*
|
||||||
* @param force Force overwriting of duplicate playlists.
|
* @param force Force overwriting of duplicate playlists.
|
||||||
* By default, a playlist file uploaded with the same path will overwrite the existing playlist.
|
* By default, a playlist file uploaded with the same path will overwrite the existing playlist.
|
||||||
* The `force` argument is used to disable overwriting.
|
* The `force` argument is used to disable overwriting.
|
||||||
* If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.
|
* If the `force` argument is set to 0, a new playlist will be created suffixed with the date and time that the duplicate was uploaded.
|
||||||
*
|
*
|
||||||
* @param sectionID Possibly the section ID to upload the playlist to, we are not certain.
|
* @param sectionID Possibly the section ID to upload the playlist to, we are not certain.
|
||||||
|
|||||||
@@ -117,9 +117,9 @@ public class PlexAPI {
|
|||||||
private final Log log;
|
private final Log log;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
||||||
* They can be organized in (optionally nesting) folders.
|
* They can be organized in (optionally nesting) folders.
|
||||||
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
||||||
* This may cause the duration and number of items to change.
|
* This may cause the duration and number of items to change.
|
||||||
*/
|
*/
|
||||||
private final Playlists playlists;
|
private final Playlists playlists;
|
||||||
@@ -231,9 +231,9 @@ public class PlexAPI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
* Playlists are ordered collections of media. They can be dumb (just a list of media) or smart (based on a media query, such as "all albums from 2017").
|
||||||
* They can be organized in (optionally nesting) folders.
|
* They can be organized in (optionally nesting) folders.
|
||||||
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
* Retrieving a playlist, or its items, will trigger a refresh of its metadata.
|
||||||
* This may cause the duration and number of items to change.
|
* This may cause the duration and number of items to change.
|
||||||
*/
|
*/
|
||||||
public Playlists playlists() {
|
public Playlists playlists() {
|
||||||
@@ -508,4 +508,5 @@ public class PlexAPI {
|
|||||||
this.updater = new Updater(sdkConfiguration);
|
this.updater = new Updater(sdkConfiguration);
|
||||||
this.users = new Users(sdkConfiguration);
|
this.users = new Users(sdkConfiguration);
|
||||||
this.sdkConfiguration.initialize();
|
this.sdkConfiguration.initialize();
|
||||||
}}
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -42,8 +42,8 @@ class SDKConfiguration {
|
|||||||
} };
|
} };
|
||||||
private static final String LANGUAGE = "java";
|
private static final String LANGUAGE = "java";
|
||||||
public static final String OPENAPI_DOC_VERSION = "0.0.3";
|
public static final String OPENAPI_DOC_VERSION = "0.0.3";
|
||||||
public static final String SDK_VERSION = "0.14.1";
|
public static final String SDK_VERSION = "0.16.1";
|
||||||
public static final String GEN_VERSION = "2.565.1";
|
public static final String GEN_VERSION = "2.595.4";
|
||||||
private static final String BASE_PACKAGE = "dev.plexapi.sdk";
|
private static final String BASE_PACKAGE = "dev.plexapi.sdk";
|
||||||
public static final String USER_AGENT =
|
public static final String USER_AGENT =
|
||||||
String.format("speakeasy-sdk/%s %s %s %s %s",
|
String.format("speakeasy-sdk/%s %s %s %s %s",
|
||||||
|
|||||||
172
src/main/java/dev/plexapi/sdk/models/operations/Attributes.java
Normal file
172
src/main/java/dev/plexapi/sdk/models/operations/Attributes.java
Normal file
@@ -0,0 +1,172 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attributes
|
||||||
|
*
|
||||||
|
* <p>Attributes associated with the marker.
|
||||||
|
*/
|
||||||
|
public class Attributes {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The identifier for the attributes.
|
||||||
|
*/
|
||||||
|
@JsonProperty("id")
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("version")
|
||||||
|
private Optional<Long> version;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public Attributes(
|
||||||
|
@JsonProperty("id") long id,
|
||||||
|
@JsonProperty("version") Optional<Long> version) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
Utils.checkNotNull(version, "version");
|
||||||
|
this.id = id;
|
||||||
|
this.version = version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Attributes(
|
||||||
|
long id) {
|
||||||
|
this(id, Optional.empty());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The identifier for the attributes.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public long id() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<Long> version() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static Builder builder() {
|
||||||
|
return new Builder();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The identifier for the attributes.
|
||||||
|
*/
|
||||||
|
public Attributes withId(long id) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
this.id = id;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
public Attributes withVersion(long version) {
|
||||||
|
Utils.checkNotNull(version, "version");
|
||||||
|
this.version = Optional.ofNullable(version);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
public Attributes withVersion(Optional<Long> version) {
|
||||||
|
Utils.checkNotNull(version, "version");
|
||||||
|
this.version = version;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Attributes other = (Attributes) o;
|
||||||
|
return
|
||||||
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
|
Objects.deepEquals(this.version, other.version);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(
|
||||||
|
id,
|
||||||
|
version);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return Utils.toString(Attributes.class,
|
||||||
|
"id", id,
|
||||||
|
"version", version);
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static class Builder {
|
||||||
|
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private Optional<Long> version = Optional.empty();
|
||||||
|
|
||||||
|
private Builder() {
|
||||||
|
// force use of static builder() method
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The identifier for the attributes.
|
||||||
|
*/
|
||||||
|
public Builder id(long id) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
this.id = id;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
public Builder version(long version) {
|
||||||
|
Utils.checkNotNull(version, "version");
|
||||||
|
this.version = Optional.ofNullable(version);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The version number of the marker attributes.
|
||||||
|
*/
|
||||||
|
public Builder version(Optional<Long> version) {
|
||||||
|
Utils.checkNotNull(version, "version");
|
||||||
|
this.version = version;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Attributes build() {
|
||||||
|
return new Attributes(
|
||||||
|
id,
|
||||||
|
version);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
237
src/main/java/dev/plexapi/sdk/models/operations/Chapter.java
Normal file
237
src/main/java/dev/plexapi/sdk/models/operations/Chapter.java
Normal file
@@ -0,0 +1,237 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Chapter
|
||||||
|
*
|
||||||
|
* <p>The thumbnail for the chapter
|
||||||
|
*/
|
||||||
|
public class Chapter {
|
||||||
|
|
||||||
|
@JsonProperty("id")
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
@JsonProperty("filter")
|
||||||
|
private String filter;
|
||||||
|
|
||||||
|
@JsonProperty("index")
|
||||||
|
private long index;
|
||||||
|
|
||||||
|
@JsonProperty("startTimeOffset")
|
||||||
|
private long startTimeOffset;
|
||||||
|
|
||||||
|
@JsonProperty("endTimeOffset")
|
||||||
|
private long endTimeOffset;
|
||||||
|
|
||||||
|
@JsonProperty("thumb")
|
||||||
|
private String thumb;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public Chapter(
|
||||||
|
@JsonProperty("id") long id,
|
||||||
|
@JsonProperty("filter") String filter,
|
||||||
|
@JsonProperty("index") long index,
|
||||||
|
@JsonProperty("startTimeOffset") long startTimeOffset,
|
||||||
|
@JsonProperty("endTimeOffset") long endTimeOffset,
|
||||||
|
@JsonProperty("thumb") String thumb) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
Utils.checkNotNull(startTimeOffset, "startTimeOffset");
|
||||||
|
Utils.checkNotNull(endTimeOffset, "endTimeOffset");
|
||||||
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
|
this.id = id;
|
||||||
|
this.filter = filter;
|
||||||
|
this.index = index;
|
||||||
|
this.startTimeOffset = startTimeOffset;
|
||||||
|
this.endTimeOffset = endTimeOffset;
|
||||||
|
this.thumb = thumb;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public long id() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public String filter() {
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public long index() {
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public long startTimeOffset() {
|
||||||
|
return startTimeOffset;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public long endTimeOffset() {
|
||||||
|
return endTimeOffset;
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public String thumb() {
|
||||||
|
return thumb;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static Builder builder() {
|
||||||
|
return new Builder();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withId(long id) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
this.id = id;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withFilter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withIndex(long index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = index;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withStartTimeOffset(long startTimeOffset) {
|
||||||
|
Utils.checkNotNull(startTimeOffset, "startTimeOffset");
|
||||||
|
this.startTimeOffset = startTimeOffset;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withEndTimeOffset(long endTimeOffset) {
|
||||||
|
Utils.checkNotNull(endTimeOffset, "endTimeOffset");
|
||||||
|
this.endTimeOffset = endTimeOffset;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter withThumb(String thumb) {
|
||||||
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
|
this.thumb = thumb;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Chapter other = (Chapter) o;
|
||||||
|
return
|
||||||
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
|
Objects.deepEquals(this.filter, other.filter) &&
|
||||||
|
Objects.deepEquals(this.index, other.index) &&
|
||||||
|
Objects.deepEquals(this.startTimeOffset, other.startTimeOffset) &&
|
||||||
|
Objects.deepEquals(this.endTimeOffset, other.endTimeOffset) &&
|
||||||
|
Objects.deepEquals(this.thumb, other.thumb);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(
|
||||||
|
id,
|
||||||
|
filter,
|
||||||
|
index,
|
||||||
|
startTimeOffset,
|
||||||
|
endTimeOffset,
|
||||||
|
thumb);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return Utils.toString(Chapter.class,
|
||||||
|
"id", id,
|
||||||
|
"filter", filter,
|
||||||
|
"index", index,
|
||||||
|
"startTimeOffset", startTimeOffset,
|
||||||
|
"endTimeOffset", endTimeOffset,
|
||||||
|
"thumb", thumb);
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static class Builder {
|
||||||
|
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private String filter;
|
||||||
|
|
||||||
|
private Long index;
|
||||||
|
|
||||||
|
private Long startTimeOffset;
|
||||||
|
|
||||||
|
private Long endTimeOffset;
|
||||||
|
|
||||||
|
private String thumb;
|
||||||
|
|
||||||
|
private Builder() {
|
||||||
|
// force use of static builder() method
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder id(long id) {
|
||||||
|
Utils.checkNotNull(id, "id");
|
||||||
|
this.id = id;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder filter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder index(long index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = index;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder startTimeOffset(long startTimeOffset) {
|
||||||
|
Utils.checkNotNull(startTimeOffset, "startTimeOffset");
|
||||||
|
this.startTimeOffset = startTimeOffset;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder endTimeOffset(long endTimeOffset) {
|
||||||
|
Utils.checkNotNull(endTimeOffset, "endTimeOffset");
|
||||||
|
this.endTimeOffset = endTimeOffset;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder thumb(String thumb) {
|
||||||
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
|
this.thumb = thumb;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Chapter build() {
|
||||||
|
return new Chapter(
|
||||||
|
id,
|
||||||
|
filter,
|
||||||
|
index,
|
||||||
|
startTimeOffset,
|
||||||
|
endTimeOffset,
|
||||||
|
thumb);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -9,7 +9,7 @@ import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
|||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Long;
|
import java.lang.Integer;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
@@ -23,7 +23,7 @@ import java.util.Optional;
|
|||||||
public class Country {
|
public class Country {
|
||||||
|
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private long id;
|
private int id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The country of origin of this media item
|
* The country of origin of this media item
|
||||||
@@ -37,7 +37,7 @@ public class Country {
|
|||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public Country(
|
public Country(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") int id,
|
||||||
@JsonProperty("tag") String tag,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("filter") Optional<String> filter) {
|
@JsonProperty("filter") Optional<String> filter) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
@@ -49,13 +49,13 @@ public class Country {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Country(
|
public Country(
|
||||||
long id,
|
int id,
|
||||||
String tag) {
|
String tag) {
|
||||||
this(id, tag, Optional.empty());
|
this(id, tag, Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long id() {
|
public int id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,7 +76,7 @@ public class Country {
|
|||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Country withId(long id) {
|
public Country withId(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
@@ -137,7 +137,7 @@ public class Country {
|
|||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private Long id;
|
private Integer id;
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
@@ -147,7 +147,7 @@ public class Country {
|
|||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder id(long id) {
|
public Builder id(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
|
|||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* CreatePlaylistQueryParamType
|
* CreatePlaylistQueryParamType
|
||||||
*
|
*
|
||||||
* <p>type of playlist to create
|
* <p>type of playlist to create
|
||||||
*/
|
*/
|
||||||
public enum CreatePlaylistQueryParamType {
|
@JsonDeserialize(using = CreatePlaylistQueryParamType._Deserializer.class)
|
||||||
AUDIO("audio"),
|
@JsonSerialize(using = CreatePlaylistQueryParamType._Serializer.class)
|
||||||
VIDEO("video"),
|
public class CreatePlaylistQueryParamType {
|
||||||
PHOTO("photo");
|
|
||||||
|
public static final CreatePlaylistQueryParamType AUDIO = new CreatePlaylistQueryParamType("audio");
|
||||||
|
public static final CreatePlaylistQueryParamType VIDEO = new CreatePlaylistQueryParamType("video");
|
||||||
|
public static final CreatePlaylistQueryParamType PHOTO = new CreatePlaylistQueryParamType("photo");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, CreatePlaylistQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<String, CreatePlaylistQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private CreatePlaylistQueryParamType(String value) {
|
private CreatePlaylistQueryParamType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a CreatePlaylistQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as CreatePlaylistQueryParamType
|
||||||
|
*/
|
||||||
|
public static CreatePlaylistQueryParamType of(String value) {
|
||||||
|
synchronized (CreatePlaylistQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new CreatePlaylistQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<CreatePlaylistQueryParamType> fromValue(String value) {
|
public Optional<CreatePlaylistQueryParamTypeEnum> asEnum() {
|
||||||
for (CreatePlaylistQueryParamType o: CreatePlaylistQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
CreatePlaylistQueryParamType other = (CreatePlaylistQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "CreatePlaylistQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static CreatePlaylistQueryParamType[] values() {
|
||||||
|
synchronized (CreatePlaylistQueryParamType.class) {
|
||||||
|
return values.values().toArray(new CreatePlaylistQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, CreatePlaylistQueryParamType> createValuesMap() {
|
||||||
|
Map<String, CreatePlaylistQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put("audio", AUDIO);
|
||||||
|
map.put("video", VIDEO);
|
||||||
|
map.put("photo", PHOTO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, CreatePlaylistQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, CreatePlaylistQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("audio", CreatePlaylistQueryParamTypeEnum.AUDIO);
|
||||||
|
map.put("video", CreatePlaylistQueryParamTypeEnum.VIDEO);
|
||||||
|
map.put("photo", CreatePlaylistQueryParamTypeEnum.PHOTO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<CreatePlaylistQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(CreatePlaylistQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(CreatePlaylistQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<CreatePlaylistQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(CreatePlaylistQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CreatePlaylistQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return CreatePlaylistQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum CreatePlaylistQueryParamTypeEnum {
|
||||||
|
|
||||||
|
AUDIO("audio"),
|
||||||
|
VIDEO("video"),
|
||||||
|
PHOTO("photo"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private CreatePlaylistQueryParamTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,38 +3,182 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* EnableCreditsMarkerGeneration
|
* EnableCreditsMarkerGeneration
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates if credits markers detection is enabled. (-1 = Library default, 0 = Disabled).
|
* <p>Setting that indicates if credits markers detection is enabled. (-1 = Library default, 0 = Disabled).
|
||||||
*/
|
*/
|
||||||
public enum EnableCreditsMarkerGeneration {
|
@JsonDeserialize(using = EnableCreditsMarkerGeneration._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = EnableCreditsMarkerGeneration._Serializer.class)
|
||||||
Disabled("0");
|
public class EnableCreditsMarkerGeneration {
|
||||||
|
|
||||||
|
public static final EnableCreditsMarkerGeneration LibraryDefault = new EnableCreditsMarkerGeneration("-1");
|
||||||
|
public static final EnableCreditsMarkerGeneration Disabled = new EnableCreditsMarkerGeneration("0");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, EnableCreditsMarkerGeneration> values = createValuesMap();
|
||||||
|
private static final Map<String, EnableCreditsMarkerGenerationEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private EnableCreditsMarkerGeneration(String value) {
|
private EnableCreditsMarkerGeneration(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a EnableCreditsMarkerGeneration with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as EnableCreditsMarkerGeneration
|
||||||
|
*/
|
||||||
|
public static EnableCreditsMarkerGeneration of(String value) {
|
||||||
|
synchronized (EnableCreditsMarkerGeneration.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new EnableCreditsMarkerGeneration(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<EnableCreditsMarkerGeneration> fromValue(String value) {
|
public Optional<EnableCreditsMarkerGenerationEnum> asEnum() {
|
||||||
for (EnableCreditsMarkerGeneration o: EnableCreditsMarkerGeneration.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
EnableCreditsMarkerGeneration other = (EnableCreditsMarkerGeneration) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "EnableCreditsMarkerGeneration [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static EnableCreditsMarkerGeneration[] values() {
|
||||||
|
synchronized (EnableCreditsMarkerGeneration.class) {
|
||||||
|
return values.values().toArray(new EnableCreditsMarkerGeneration[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, EnableCreditsMarkerGeneration> createValuesMap() {
|
||||||
|
Map<String, EnableCreditsMarkerGeneration> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", Disabled);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, EnableCreditsMarkerGenerationEnum> createEnumsMap() {
|
||||||
|
Map<String, EnableCreditsMarkerGenerationEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", EnableCreditsMarkerGenerationEnum.LibraryDefault);
|
||||||
|
map.put("0", EnableCreditsMarkerGenerationEnum.Disabled);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<EnableCreditsMarkerGeneration> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(EnableCreditsMarkerGeneration.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(EnableCreditsMarkerGeneration value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<EnableCreditsMarkerGeneration> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(EnableCreditsMarkerGeneration.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EnableCreditsMarkerGeneration deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return EnableCreditsMarkerGeneration.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum EnableCreditsMarkerGenerationEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
Disabled("0"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private EnableCreditsMarkerGenerationEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* EpisodeSort
|
* EpisodeSort
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates how episodes are sorted for the show. (-1 = Library default, 0 = Oldest first, 1 = Newest first).
|
* <p>Setting that indicates how episodes are sorted for the show. (-1 = Library default, 0 = Oldest first, 1 = Newest first).
|
||||||
*/
|
*/
|
||||||
public enum EpisodeSort {
|
@JsonDeserialize(using = EpisodeSort._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = EpisodeSort._Serializer.class)
|
||||||
OldestFirst("0"),
|
public class EpisodeSort {
|
||||||
NewestFirst("1");
|
|
||||||
|
public static final EpisodeSort LibraryDefault = new EpisodeSort("-1");
|
||||||
|
public static final EpisodeSort OldestFirst = new EpisodeSort("0");
|
||||||
|
public static final EpisodeSort NewestFirst = new EpisodeSort("1");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, EpisodeSort> values = createValuesMap();
|
||||||
|
private static final Map<String, EpisodeSortEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private EpisodeSort(String value) {
|
private EpisodeSort(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a EpisodeSort with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as EpisodeSort
|
||||||
|
*/
|
||||||
|
public static EpisodeSort of(String value) {
|
||||||
|
synchronized (EpisodeSort.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new EpisodeSort(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<EpisodeSort> fromValue(String value) {
|
public Optional<EpisodeSortEnum> asEnum() {
|
||||||
for (EpisodeSort o: EpisodeSort.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
EpisodeSort other = (EpisodeSort) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "EpisodeSort [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static EpisodeSort[] values() {
|
||||||
|
synchronized (EpisodeSort.class) {
|
||||||
|
return values.values().toArray(new EpisodeSort[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, EpisodeSort> createValuesMap() {
|
||||||
|
Map<String, EpisodeSort> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", OldestFirst);
|
||||||
|
map.put("1", NewestFirst);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, EpisodeSortEnum> createEnumsMap() {
|
||||||
|
Map<String, EpisodeSortEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", EpisodeSortEnum.LibraryDefault);
|
||||||
|
map.put("0", EpisodeSortEnum.OldestFirst);
|
||||||
|
map.put("1", EpisodeSortEnum.NewestFirst);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<EpisodeSort> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(EpisodeSort.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(EpisodeSort value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<EpisodeSort> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(EpisodeSort.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EpisodeSort deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return EpisodeSort.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum EpisodeSortEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
OldestFirst("0"),
|
||||||
|
NewestFirst("1"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private EpisodeSortEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
125
src/main/java/dev/plexapi/sdk/models/operations/Extras.java
Normal file
125
src/main/java/dev/plexapi/sdk/models/operations/Extras.java
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
public class Extras {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("size")
|
||||||
|
private Optional<Long> size;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public Extras(
|
||||||
|
@JsonProperty("size") Optional<Long> size) {
|
||||||
|
Utils.checkNotNull(size, "size");
|
||||||
|
this.size = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Extras() {
|
||||||
|
this(Optional.empty());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<Long> size() {
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static Builder builder() {
|
||||||
|
return new Builder();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
public Extras withSize(long size) {
|
||||||
|
Utils.checkNotNull(size, "size");
|
||||||
|
this.size = Optional.ofNullable(size);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
public Extras withSize(Optional<Long> size) {
|
||||||
|
Utils.checkNotNull(size, "size");
|
||||||
|
this.size = size;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Extras other = (Extras) o;
|
||||||
|
return
|
||||||
|
Objects.deepEquals(this.size, other.size);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(
|
||||||
|
size);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return Utils.toString(Extras.class,
|
||||||
|
"size", size);
|
||||||
|
}
|
||||||
|
|
||||||
|
public final static class Builder {
|
||||||
|
|
||||||
|
private Optional<Long> size = Optional.empty();
|
||||||
|
|
||||||
|
private Builder() {
|
||||||
|
// force use of static builder() method
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
public Builder size(long size) {
|
||||||
|
Utils.checkNotNull(size, "size");
|
||||||
|
this.size = Optional.ofNullable(size);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the extras.
|
||||||
|
*/
|
||||||
|
public Builder size(Optional<Long> size) {
|
||||||
|
Utils.checkNotNull(size, "size");
|
||||||
|
this.size = size;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Extras build() {
|
||||||
|
return new Extras(
|
||||||
|
size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* Filter
|
* Filter
|
||||||
*
|
*
|
||||||
* <p>Filter
|
* <p>Filter
|
||||||
*/
|
*/
|
||||||
public enum Filter {
|
@JsonDeserialize(using = Filter._Deserializer.class)
|
||||||
ALL("all"),
|
@JsonSerialize(using = Filter._Serializer.class)
|
||||||
AVAILABLE("available"),
|
public class Filter {
|
||||||
RELEASED("released");
|
|
||||||
|
public static final Filter ALL = new Filter("all");
|
||||||
|
public static final Filter AVAILABLE = new Filter("available");
|
||||||
|
public static final Filter RELEASED = new Filter("released");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, Filter> values = createValuesMap();
|
||||||
|
private static final Map<String, FilterEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private Filter(String value) {
|
private Filter(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a Filter with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as Filter
|
||||||
|
*/
|
||||||
|
public static Filter of(String value) {
|
||||||
|
synchronized (Filter.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new Filter(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<Filter> fromValue(String value) {
|
public Optional<FilterEnum> asEnum() {
|
||||||
for (Filter o: Filter.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
Filter other = (Filter) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Filter [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static Filter[] values() {
|
||||||
|
synchronized (Filter.class) {
|
||||||
|
return values.values().toArray(new Filter[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, Filter> createValuesMap() {
|
||||||
|
Map<String, Filter> map = new LinkedHashMap<>();
|
||||||
|
map.put("all", ALL);
|
||||||
|
map.put("available", AVAILABLE);
|
||||||
|
map.put("released", RELEASED);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, FilterEnum> createEnumsMap() {
|
||||||
|
Map<String, FilterEnum> map = new HashMap<>();
|
||||||
|
map.put("all", FilterEnum.ALL);
|
||||||
|
map.put("available", FilterEnum.AVAILABLE);
|
||||||
|
map.put("released", FilterEnum.RELEASED);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<Filter> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(Filter.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(Filter value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<Filter> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(Filter.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Filter deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return Filter.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum FilterEnum {
|
||||||
|
|
||||||
|
ALL("all"),
|
||||||
|
AVAILABLE("available"),
|
||||||
|
RELEASED("released"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private FilterEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* FlattenSeasons
|
* FlattenSeasons
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates if seasons are set to hidden for the show. (-1 = Library default, 0 = Hide, 1 = Show).
|
* <p>Setting that indicates if seasons are set to hidden for the show. (-1 = Library default, 0 = Hide, 1 = Show).
|
||||||
*/
|
*/
|
||||||
public enum FlattenSeasons {
|
@JsonDeserialize(using = FlattenSeasons._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = FlattenSeasons._Serializer.class)
|
||||||
Hide("0"),
|
public class FlattenSeasons {
|
||||||
Show("1");
|
|
||||||
|
public static final FlattenSeasons LibraryDefault = new FlattenSeasons("-1");
|
||||||
|
public static final FlattenSeasons Hide = new FlattenSeasons("0");
|
||||||
|
public static final FlattenSeasons Show = new FlattenSeasons("1");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, FlattenSeasons> values = createValuesMap();
|
||||||
|
private static final Map<String, FlattenSeasonsEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private FlattenSeasons(String value) {
|
private FlattenSeasons(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a FlattenSeasons with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as FlattenSeasons
|
||||||
|
*/
|
||||||
|
public static FlattenSeasons of(String value) {
|
||||||
|
synchronized (FlattenSeasons.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new FlattenSeasons(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<FlattenSeasons> fromValue(String value) {
|
public Optional<FlattenSeasonsEnum> asEnum() {
|
||||||
for (FlattenSeasons o: FlattenSeasons.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
FlattenSeasons other = (FlattenSeasons) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "FlattenSeasons [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static FlattenSeasons[] values() {
|
||||||
|
synchronized (FlattenSeasons.class) {
|
||||||
|
return values.values().toArray(new FlattenSeasons[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, FlattenSeasons> createValuesMap() {
|
||||||
|
Map<String, FlattenSeasons> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", Hide);
|
||||||
|
map.put("1", Show);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, FlattenSeasonsEnum> createEnumsMap() {
|
||||||
|
Map<String, FlattenSeasonsEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", FlattenSeasonsEnum.LibraryDefault);
|
||||||
|
map.put("0", FlattenSeasonsEnum.Hide);
|
||||||
|
map.put("1", FlattenSeasonsEnum.Show);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<FlattenSeasons> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(FlattenSeasons.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(FlattenSeasons value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<FlattenSeasons> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(FlattenSeasons.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FlattenSeasons deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return FlattenSeasons.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum FlattenSeasonsEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
Hide("0"),
|
||||||
|
Show("1"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private FlattenSeasonsEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetActorsLibraryQueryParamType
|
* GetActorsLibraryQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetActorsLibraryQueryParamType {
|
@JsonDeserialize(using = GetActorsLibraryQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetActorsLibraryQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetActorsLibraryQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetActorsLibraryQueryParamType Movie = new GetActorsLibraryQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetActorsLibraryQueryParamType TvShow = new GetActorsLibraryQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetActorsLibraryQueryParamType Season = new GetActorsLibraryQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetActorsLibraryQueryParamType Episode = new GetActorsLibraryQueryParamType(4L);
|
||||||
|
public static final GetActorsLibraryQueryParamType Audio = new GetActorsLibraryQueryParamType(8L);
|
||||||
|
public static final GetActorsLibraryQueryParamType Album = new GetActorsLibraryQueryParamType(9L);
|
||||||
|
public static final GetActorsLibraryQueryParamType Track = new GetActorsLibraryQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetActorsLibraryQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetActorsLibraryQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetActorsLibraryQueryParamType(long value) {
|
private GetActorsLibraryQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetActorsLibraryQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetActorsLibraryQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetActorsLibraryQueryParamType of(long value) {
|
||||||
|
synchronized (GetActorsLibraryQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetActorsLibraryQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetActorsLibraryQueryParamType> fromValue(long value) {
|
public Optional<GetActorsLibraryQueryParamTypeEnum> asEnum() {
|
||||||
for (GetActorsLibraryQueryParamType o: GetActorsLibraryQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetActorsLibraryQueryParamType other = (GetActorsLibraryQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetActorsLibraryQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetActorsLibraryQueryParamType[] values() {
|
||||||
|
synchronized (GetActorsLibraryQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetActorsLibraryQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetActorsLibraryQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetActorsLibraryQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetActorsLibraryQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetActorsLibraryQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetActorsLibraryQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetActorsLibraryQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetActorsLibraryQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetActorsLibraryQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetActorsLibraryQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetActorsLibraryQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetActorsLibraryQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetActorsLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetActorsLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetActorsLibraryQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetActorsLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetActorsLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetActorsLibraryQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetActorsLibraryQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetActorsLibraryQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetActorsLibraryQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -5,54 +5,95 @@ package dev.plexapi.sdk.models.operations;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import dev.plexapi.sdk.utils.LazySingletonValue;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Boolean;
|
import java.lang.Boolean;
|
||||||
import java.lang.Integer;
|
|
||||||
import java.lang.Long;
|
import java.lang.Long;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
public class GetAllLibrariesDirectory {
|
public class GetAllLibrariesDirectory {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
@JsonProperty("allowSync")
|
@JsonProperty("allowSync")
|
||||||
private boolean allowSync;
|
private boolean allowSync;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the background artwork of the media container.
|
||||||
|
*/
|
||||||
@JsonProperty("art")
|
@JsonProperty("art")
|
||||||
private String art;
|
private String art;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The relative path to the composite media item.
|
||||||
|
*/
|
||||||
@JsonProperty("composite")
|
@JsonProperty("composite")
|
||||||
private String composite;
|
private String composite;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonProperty("filters")
|
@JsonProperty("filters")
|
||||||
private boolean filters;
|
private boolean filters;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the library is currently being refreshed or updated
|
||||||
|
*/
|
||||||
@JsonProperty("refreshing")
|
@JsonProperty("refreshing")
|
||||||
private boolean refreshing;
|
private boolean refreshing;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the thumbnail image of the media container.
|
||||||
|
*/
|
||||||
@JsonProperty("thumb")
|
@JsonProperty("thumb")
|
||||||
private String thumb;
|
private String thumb;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The library key representing the unique identifier
|
||||||
|
*/
|
||||||
@JsonProperty("key")
|
@JsonProperty("key")
|
||||||
private String key;
|
private String key;
|
||||||
|
|
||||||
@JsonProperty("type")
|
@JsonProperty("type")
|
||||||
private String type;
|
private GetAllLibrariesType type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The title of the library
|
||||||
|
*/
|
||||||
@JsonProperty("title")
|
@JsonProperty("title")
|
||||||
private String title;
|
private String title;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex agent used to match and retrieve media metadata.
|
||||||
|
*/
|
||||||
@JsonProperty("agent")
|
@JsonProperty("agent")
|
||||||
private String agent;
|
private String agent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonProperty("scanner")
|
@JsonProperty("scanner")
|
||||||
private String scanner;
|
private String scanner;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex library language that has been set
|
||||||
|
*/
|
||||||
@JsonProperty("language")
|
@JsonProperty("language")
|
||||||
private String language;
|
private String language;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The universally unique identifier for the library.
|
||||||
|
*/
|
||||||
@JsonProperty("uuid")
|
@JsonProperty("uuid")
|
||||||
private String uuid;
|
private String uuid;
|
||||||
|
|
||||||
@@ -62,11 +103,9 @@ public class GetAllLibrariesDirectory {
|
|||||||
@JsonProperty("updatedAt")
|
@JsonProperty("updatedAt")
|
||||||
private long updatedAt;
|
private long updatedAt;
|
||||||
|
|
||||||
/**
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
* Unix epoch datetime in seconds
|
|
||||||
*/
|
|
||||||
@JsonProperty("createdAt")
|
@JsonProperty("createdAt")
|
||||||
private long createdAt;
|
private Optional<Long> createdAt;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unix epoch datetime in seconds
|
* Unix epoch datetime in seconds
|
||||||
@@ -74,20 +113,28 @@ public class GetAllLibrariesDirectory {
|
|||||||
@JsonProperty("scannedAt")
|
@JsonProperty("scannedAt")
|
||||||
private long scannedAt;
|
private long scannedAt;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonProperty("content")
|
@JsonProperty("content")
|
||||||
private boolean content;
|
private boolean content;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonProperty("directory")
|
@JsonProperty("directory")
|
||||||
private boolean directory;
|
private boolean directory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unix epoch datetime in seconds
|
* Timestamp (in seconds) representing the last time the content was modified.
|
||||||
|
* NOTE: Some Plex server have some absurd values for this field, like 8457612157633039800 so it should be int64
|
||||||
*/
|
*/
|
||||||
@JsonProperty("contentChangedAt")
|
@JsonProperty("contentChangedAt")
|
||||||
private long contentChangedAt;
|
private long contentChangedAt;
|
||||||
|
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("hidden")
|
@JsonProperty("hidden")
|
||||||
private int hidden;
|
private Optional<? extends Hidden> hidden;
|
||||||
|
|
||||||
@JsonProperty("Location")
|
@JsonProperty("Location")
|
||||||
private List<GetAllLibrariesLocation> location;
|
private List<GetAllLibrariesLocation> location;
|
||||||
@@ -101,19 +148,19 @@ public class GetAllLibrariesDirectory {
|
|||||||
@JsonProperty("refreshing") boolean refreshing,
|
@JsonProperty("refreshing") boolean refreshing,
|
||||||
@JsonProperty("thumb") String thumb,
|
@JsonProperty("thumb") String thumb,
|
||||||
@JsonProperty("key") String key,
|
@JsonProperty("key") String key,
|
||||||
@JsonProperty("type") String type,
|
@JsonProperty("type") GetAllLibrariesType type,
|
||||||
@JsonProperty("title") String title,
|
@JsonProperty("title") String title,
|
||||||
@JsonProperty("agent") String agent,
|
@JsonProperty("agent") String agent,
|
||||||
@JsonProperty("scanner") String scanner,
|
@JsonProperty("scanner") String scanner,
|
||||||
@JsonProperty("language") String language,
|
@JsonProperty("language") String language,
|
||||||
@JsonProperty("uuid") String uuid,
|
@JsonProperty("uuid") String uuid,
|
||||||
@JsonProperty("updatedAt") long updatedAt,
|
@JsonProperty("updatedAt") long updatedAt,
|
||||||
@JsonProperty("createdAt") long createdAt,
|
@JsonProperty("createdAt") Optional<Long> createdAt,
|
||||||
@JsonProperty("scannedAt") long scannedAt,
|
@JsonProperty("scannedAt") long scannedAt,
|
||||||
@JsonProperty("content") boolean content,
|
@JsonProperty("content") boolean content,
|
||||||
@JsonProperty("directory") boolean directory,
|
@JsonProperty("directory") boolean directory,
|
||||||
@JsonProperty("contentChangedAt") long contentChangedAt,
|
@JsonProperty("contentChangedAt") long contentChangedAt,
|
||||||
@JsonProperty("hidden") int hidden,
|
@JsonProperty("hidden") Optional<? extends Hidden> hidden,
|
||||||
@JsonProperty("Location") List<GetAllLibrariesLocation> location) {
|
@JsonProperty("Location") List<GetAllLibrariesLocation> location) {
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
Utils.checkNotNull(art, "art");
|
Utils.checkNotNull(art, "art");
|
||||||
@@ -158,67 +205,126 @@ public class GetAllLibrariesDirectory {
|
|||||||
this.hidden = hidden;
|
this.hidden = hidden;
|
||||||
this.location = location;
|
this.location = location;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesDirectory(
|
||||||
|
boolean allowSync,
|
||||||
|
String art,
|
||||||
|
String composite,
|
||||||
|
boolean filters,
|
||||||
|
boolean refreshing,
|
||||||
|
String thumb,
|
||||||
|
String key,
|
||||||
|
GetAllLibrariesType type,
|
||||||
|
String title,
|
||||||
|
String agent,
|
||||||
|
String scanner,
|
||||||
|
String language,
|
||||||
|
String uuid,
|
||||||
|
long updatedAt,
|
||||||
|
long scannedAt,
|
||||||
|
boolean content,
|
||||||
|
boolean directory,
|
||||||
|
long contentChangedAt,
|
||||||
|
List<GetAllLibrariesLocation> location) {
|
||||||
|
this(allowSync, art, composite, filters, refreshing, thumb, key, type, title, agent, scanner, language, uuid, updatedAt, Optional.empty(), scannedAt, content, directory, contentChangedAt, Optional.empty(), location);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean allowSync() {
|
public boolean allowSync() {
|
||||||
return allowSync;
|
return allowSync;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the background artwork of the media container.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String art() {
|
public String art() {
|
||||||
return art;
|
return art;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The relative path to the composite media item.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String composite() {
|
public String composite() {
|
||||||
return composite;
|
return composite;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean filters() {
|
public boolean filters() {
|
||||||
return filters;
|
return filters;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the library is currently being refreshed or updated
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean refreshing() {
|
public boolean refreshing() {
|
||||||
return refreshing;
|
return refreshing;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the thumbnail image of the media container.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String thumb() {
|
public String thumb() {
|
||||||
return thumb;
|
return thumb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The library key representing the unique identifier
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String key() {
|
public String key() {
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String type() {
|
public GetAllLibrariesType type() {
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The title of the library
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String title() {
|
public String title() {
|
||||||
return title;
|
return title;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex agent used to match and retrieve media metadata.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String agent() {
|
public String agent() {
|
||||||
return agent;
|
return agent;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String scanner() {
|
public String scanner() {
|
||||||
return scanner;
|
return scanner;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex library language that has been set
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String language() {
|
public String language() {
|
||||||
return language;
|
return language;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The universally unique identifier for the library.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String uuid() {
|
public String uuid() {
|
||||||
return uuid;
|
return uuid;
|
||||||
@@ -232,11 +338,8 @@ public class GetAllLibrariesDirectory {
|
|||||||
return updatedAt;
|
return updatedAt;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Unix epoch datetime in seconds
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long createdAt() {
|
public Optional<Long> createdAt() {
|
||||||
return createdAt;
|
return createdAt;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -248,27 +351,35 @@ public class GetAllLibrariesDirectory {
|
|||||||
return scannedAt;
|
return scannedAt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean content() {
|
public boolean content() {
|
||||||
return content;
|
return content;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean directory() {
|
public boolean directory() {
|
||||||
return directory;
|
return directory;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unix epoch datetime in seconds
|
* Timestamp (in seconds) representing the last time the content was modified.
|
||||||
|
* NOTE: Some Plex server have some absurd values for this field, like 8457612157633039800 so it should be int64
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long contentChangedAt() {
|
public long contentChangedAt() {
|
||||||
return contentChangedAt;
|
return contentChangedAt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int hidden() {
|
public Optional<Hidden> hidden() {
|
||||||
return hidden;
|
return (Optional<Hidden>) hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
@@ -280,78 +391,114 @@ public class GetAllLibrariesDirectory {
|
|||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withAllowSync(boolean allowSync) {
|
public GetAllLibrariesDirectory withAllowSync(boolean allowSync) {
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
this.allowSync = allowSync;
|
this.allowSync = allowSync;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the background artwork of the media container.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withArt(String art) {
|
public GetAllLibrariesDirectory withArt(String art) {
|
||||||
Utils.checkNotNull(art, "art");
|
Utils.checkNotNull(art, "art");
|
||||||
this.art = art;
|
this.art = art;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The relative path to the composite media item.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withComposite(String composite) {
|
public GetAllLibrariesDirectory withComposite(String composite) {
|
||||||
Utils.checkNotNull(composite, "composite");
|
Utils.checkNotNull(composite, "composite");
|
||||||
this.composite = composite;
|
this.composite = composite;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withFilters(boolean filters) {
|
public GetAllLibrariesDirectory withFilters(boolean filters) {
|
||||||
Utils.checkNotNull(filters, "filters");
|
Utils.checkNotNull(filters, "filters");
|
||||||
this.filters = filters;
|
this.filters = filters;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the library is currently being refreshed or updated
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withRefreshing(boolean refreshing) {
|
public GetAllLibrariesDirectory withRefreshing(boolean refreshing) {
|
||||||
Utils.checkNotNull(refreshing, "refreshing");
|
Utils.checkNotNull(refreshing, "refreshing");
|
||||||
this.refreshing = refreshing;
|
this.refreshing = refreshing;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the thumbnail image of the media container.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withThumb(String thumb) {
|
public GetAllLibrariesDirectory withThumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The library key representing the unique identifier
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withKey(String key) {
|
public GetAllLibrariesDirectory withKey(String key) {
|
||||||
Utils.checkNotNull(key, "key");
|
Utils.checkNotNull(key, "key");
|
||||||
this.key = key;
|
this.key = key;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetAllLibrariesDirectory withType(String type) {
|
public GetAllLibrariesDirectory withType(GetAllLibrariesType type) {
|
||||||
Utils.checkNotNull(type, "type");
|
Utils.checkNotNull(type, "type");
|
||||||
this.type = type;
|
this.type = type;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The title of the library
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withTitle(String title) {
|
public GetAllLibrariesDirectory withTitle(String title) {
|
||||||
Utils.checkNotNull(title, "title");
|
Utils.checkNotNull(title, "title");
|
||||||
this.title = title;
|
this.title = title;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex agent used to match and retrieve media metadata.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withAgent(String agent) {
|
public GetAllLibrariesDirectory withAgent(String agent) {
|
||||||
Utils.checkNotNull(agent, "agent");
|
Utils.checkNotNull(agent, "agent");
|
||||||
this.agent = agent;
|
this.agent = agent;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withScanner(String scanner) {
|
public GetAllLibrariesDirectory withScanner(String scanner) {
|
||||||
Utils.checkNotNull(scanner, "scanner");
|
Utils.checkNotNull(scanner, "scanner");
|
||||||
this.scanner = scanner;
|
this.scanner = scanner;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex library language that has been set
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withLanguage(String language) {
|
public GetAllLibrariesDirectory withLanguage(String language) {
|
||||||
Utils.checkNotNull(language, "language");
|
Utils.checkNotNull(language, "language");
|
||||||
this.language = language;
|
this.language = language;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The universally unique identifier for the library.
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withUuid(String uuid) {
|
public GetAllLibrariesDirectory withUuid(String uuid) {
|
||||||
Utils.checkNotNull(uuid, "uuid");
|
Utils.checkNotNull(uuid, "uuid");
|
||||||
this.uuid = uuid;
|
this.uuid = uuid;
|
||||||
@@ -367,10 +514,13 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Unix epoch datetime in seconds
|
|
||||||
*/
|
|
||||||
public GetAllLibrariesDirectory withCreatedAt(long createdAt) {
|
public GetAllLibrariesDirectory withCreatedAt(long createdAt) {
|
||||||
|
Utils.checkNotNull(createdAt, "createdAt");
|
||||||
|
this.createdAt = Optional.ofNullable(createdAt);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesDirectory withCreatedAt(Optional<Long> createdAt) {
|
||||||
Utils.checkNotNull(createdAt, "createdAt");
|
Utils.checkNotNull(createdAt, "createdAt");
|
||||||
this.createdAt = createdAt;
|
this.createdAt = createdAt;
|
||||||
return this;
|
return this;
|
||||||
@@ -385,12 +535,18 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withContent(boolean content) {
|
public GetAllLibrariesDirectory withContent(boolean content) {
|
||||||
Utils.checkNotNull(content, "content");
|
Utils.checkNotNull(content, "content");
|
||||||
this.content = content;
|
this.content = content;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public GetAllLibrariesDirectory withDirectory(boolean directory) {
|
public GetAllLibrariesDirectory withDirectory(boolean directory) {
|
||||||
Utils.checkNotNull(directory, "directory");
|
Utils.checkNotNull(directory, "directory");
|
||||||
this.directory = directory;
|
this.directory = directory;
|
||||||
@@ -398,7 +554,8 @@ public class GetAllLibrariesDirectory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unix epoch datetime in seconds
|
* Timestamp (in seconds) representing the last time the content was modified.
|
||||||
|
* NOTE: Some Plex server have some absurd values for this field, like 8457612157633039800 so it should be int64
|
||||||
*/
|
*/
|
||||||
public GetAllLibrariesDirectory withContentChangedAt(long contentChangedAt) {
|
public GetAllLibrariesDirectory withContentChangedAt(long contentChangedAt) {
|
||||||
Utils.checkNotNull(contentChangedAt, "contentChangedAt");
|
Utils.checkNotNull(contentChangedAt, "contentChangedAt");
|
||||||
@@ -406,7 +563,13 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetAllLibrariesDirectory withHidden(int hidden) {
|
public GetAllLibrariesDirectory withHidden(Hidden hidden) {
|
||||||
|
Utils.checkNotNull(hidden, "hidden");
|
||||||
|
this.hidden = Optional.ofNullable(hidden);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesDirectory withHidden(Optional<? extends Hidden> hidden) {
|
||||||
Utils.checkNotNull(hidden, "hidden");
|
Utils.checkNotNull(hidden, "hidden");
|
||||||
this.hidden = hidden;
|
this.hidden = hidden;
|
||||||
return this;
|
return this;
|
||||||
@@ -520,7 +683,7 @@ public class GetAllLibrariesDirectory {
|
|||||||
|
|
||||||
private String key;
|
private String key;
|
||||||
|
|
||||||
private String type;
|
private GetAllLibrariesType type;
|
||||||
|
|
||||||
private String title;
|
private String title;
|
||||||
|
|
||||||
@@ -534,7 +697,7 @@ public class GetAllLibrariesDirectory {
|
|||||||
|
|
||||||
private Long updatedAt;
|
private Long updatedAt;
|
||||||
|
|
||||||
private Long createdAt;
|
private Optional<Long> createdAt = Optional.empty();
|
||||||
|
|
||||||
private Long scannedAt;
|
private Long scannedAt;
|
||||||
|
|
||||||
@@ -544,7 +707,7 @@ public class GetAllLibrariesDirectory {
|
|||||||
|
|
||||||
private Long contentChangedAt;
|
private Long contentChangedAt;
|
||||||
|
|
||||||
private Integer hidden;
|
private Optional<? extends Hidden> hidden;
|
||||||
|
|
||||||
private List<GetAllLibrariesLocation> location;
|
private List<GetAllLibrariesLocation> location;
|
||||||
|
|
||||||
@@ -552,78 +715,114 @@ public class GetAllLibrariesDirectory {
|
|||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
public Builder allowSync(boolean allowSync) {
|
public Builder allowSync(boolean allowSync) {
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
this.allowSync = allowSync;
|
this.allowSync = allowSync;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the background artwork of the media container.
|
||||||
|
*/
|
||||||
public Builder art(String art) {
|
public Builder art(String art) {
|
||||||
Utils.checkNotNull(art, "art");
|
Utils.checkNotNull(art, "art");
|
||||||
this.art = art;
|
this.art = art;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The relative path to the composite media item.
|
||||||
|
*/
|
||||||
public Builder composite(String composite) {
|
public Builder composite(String composite) {
|
||||||
Utils.checkNotNull(composite, "composite");
|
Utils.checkNotNull(composite, "composite");
|
||||||
this.composite = composite;
|
this.composite = composite;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public Builder filters(boolean filters) {
|
public Builder filters(boolean filters) {
|
||||||
Utils.checkNotNull(filters, "filters");
|
Utils.checkNotNull(filters, "filters");
|
||||||
this.filters = filters;
|
this.filters = filters;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the library is currently being refreshed or updated
|
||||||
|
*/
|
||||||
public Builder refreshing(boolean refreshing) {
|
public Builder refreshing(boolean refreshing) {
|
||||||
Utils.checkNotNull(refreshing, "refreshing");
|
Utils.checkNotNull(refreshing, "refreshing");
|
||||||
this.refreshing = refreshing;
|
this.refreshing = refreshing;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* URL for the thumbnail image of the media container.
|
||||||
|
*/
|
||||||
public Builder thumb(String thumb) {
|
public Builder thumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The library key representing the unique identifier
|
||||||
|
*/
|
||||||
public Builder key(String key) {
|
public Builder key(String key) {
|
||||||
Utils.checkNotNull(key, "key");
|
Utils.checkNotNull(key, "key");
|
||||||
this.key = key;
|
this.key = key;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder type(String type) {
|
public Builder type(GetAllLibrariesType type) {
|
||||||
Utils.checkNotNull(type, "type");
|
Utils.checkNotNull(type, "type");
|
||||||
this.type = type;
|
this.type = type;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The title of the library
|
||||||
|
*/
|
||||||
public Builder title(String title) {
|
public Builder title(String title) {
|
||||||
Utils.checkNotNull(title, "title");
|
Utils.checkNotNull(title, "title");
|
||||||
this.title = title;
|
this.title = title;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex agent used to match and retrieve media metadata.
|
||||||
|
*/
|
||||||
public Builder agent(String agent) {
|
public Builder agent(String agent) {
|
||||||
Utils.checkNotNull(agent, "agent");
|
Utils.checkNotNull(agent, "agent");
|
||||||
this.agent = agent;
|
this.agent = agent;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public Builder scanner(String scanner) {
|
public Builder scanner(String scanner) {
|
||||||
Utils.checkNotNull(scanner, "scanner");
|
Utils.checkNotNull(scanner, "scanner");
|
||||||
this.scanner = scanner;
|
this.scanner = scanner;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plex library language that has been set
|
||||||
|
*/
|
||||||
public Builder language(String language) {
|
public Builder language(String language) {
|
||||||
Utils.checkNotNull(language, "language");
|
Utils.checkNotNull(language, "language");
|
||||||
this.language = language;
|
this.language = language;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The universally unique identifier for the library.
|
||||||
|
*/
|
||||||
public Builder uuid(String uuid) {
|
public Builder uuid(String uuid) {
|
||||||
Utils.checkNotNull(uuid, "uuid");
|
Utils.checkNotNull(uuid, "uuid");
|
||||||
this.uuid = uuid;
|
this.uuid = uuid;
|
||||||
@@ -639,10 +838,13 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Unix epoch datetime in seconds
|
|
||||||
*/
|
|
||||||
public Builder createdAt(long createdAt) {
|
public Builder createdAt(long createdAt) {
|
||||||
|
Utils.checkNotNull(createdAt, "createdAt");
|
||||||
|
this.createdAt = Optional.ofNullable(createdAt);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder createdAt(Optional<Long> createdAt) {
|
||||||
Utils.checkNotNull(createdAt, "createdAt");
|
Utils.checkNotNull(createdAt, "createdAt");
|
||||||
this.createdAt = createdAt;
|
this.createdAt = createdAt;
|
||||||
return this;
|
return this;
|
||||||
@@ -657,12 +859,18 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public Builder content(boolean content) {
|
public Builder content(boolean content) {
|
||||||
Utils.checkNotNull(content, "content");
|
Utils.checkNotNull(content, "content");
|
||||||
this.content = content;
|
this.content = content;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UNKNOWN
|
||||||
|
*/
|
||||||
public Builder directory(boolean directory) {
|
public Builder directory(boolean directory) {
|
||||||
Utils.checkNotNull(directory, "directory");
|
Utils.checkNotNull(directory, "directory");
|
||||||
this.directory = directory;
|
this.directory = directory;
|
||||||
@@ -670,7 +878,8 @@ public class GetAllLibrariesDirectory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unix epoch datetime in seconds
|
* Timestamp (in seconds) representing the last time the content was modified.
|
||||||
|
* NOTE: Some Plex server have some absurd values for this field, like 8457612157633039800 so it should be int64
|
||||||
*/
|
*/
|
||||||
public Builder contentChangedAt(long contentChangedAt) {
|
public Builder contentChangedAt(long contentChangedAt) {
|
||||||
Utils.checkNotNull(contentChangedAt, "contentChangedAt");
|
Utils.checkNotNull(contentChangedAt, "contentChangedAt");
|
||||||
@@ -678,7 +887,13 @@ public class GetAllLibrariesDirectory {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder hidden(int hidden) {
|
public Builder hidden(Hidden hidden) {
|
||||||
|
Utils.checkNotNull(hidden, "hidden");
|
||||||
|
this.hidden = Optional.ofNullable(hidden);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder hidden(Optional<? extends Hidden> hidden) {
|
||||||
Utils.checkNotNull(hidden, "hidden");
|
Utils.checkNotNull(hidden, "hidden");
|
||||||
this.hidden = hidden;
|
this.hidden = hidden;
|
||||||
return this;
|
return this;
|
||||||
@@ -691,6 +906,9 @@ public class GetAllLibrariesDirectory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GetAllLibrariesDirectory build() {
|
public GetAllLibrariesDirectory build() {
|
||||||
|
if (hidden == null) {
|
||||||
|
hidden = _SINGLETON_VALUE_Hidden.value();
|
||||||
|
}
|
||||||
return new GetAllLibrariesDirectory(
|
return new GetAllLibrariesDirectory(
|
||||||
allowSync,
|
allowSync,
|
||||||
art,
|
art,
|
||||||
@@ -714,5 +932,11 @@ public class GetAllLibrariesDirectory {
|
|||||||
hidden,
|
hidden,
|
||||||
location);
|
location);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final LazySingletonValue<Optional<? extends Hidden>> _SINGLETON_VALUE_Hidden =
|
||||||
|
new LazySingletonValue<>(
|
||||||
|
"hidden",
|
||||||
|
"0",
|
||||||
|
new TypeReference<Optional<? extends Hidden>>() {});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,9 +14,15 @@ import java.util.Objects;
|
|||||||
|
|
||||||
public class GetAllLibrariesLocation {
|
public class GetAllLibrariesLocation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ID of the location.
|
||||||
|
*/
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private int id;
|
private int id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The path to the media item.
|
||||||
|
*/
|
||||||
@JsonProperty("path")
|
@JsonProperty("path")
|
||||||
private String path;
|
private String path;
|
||||||
|
|
||||||
@@ -30,11 +36,17 @@ public class GetAllLibrariesLocation {
|
|||||||
this.path = path;
|
this.path = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ID of the location.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int id() {
|
public int id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The path to the media item.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String path() {
|
public String path() {
|
||||||
return path;
|
return path;
|
||||||
@@ -44,12 +56,18 @@ public class GetAllLibrariesLocation {
|
|||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ID of the location.
|
||||||
|
*/
|
||||||
public GetAllLibrariesLocation withId(int id) {
|
public GetAllLibrariesLocation withId(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The path to the media item.
|
||||||
|
*/
|
||||||
public GetAllLibrariesLocation withPath(String path) {
|
public GetAllLibrariesLocation withPath(String path) {
|
||||||
Utils.checkNotNull(path, "path");
|
Utils.checkNotNull(path, "path");
|
||||||
this.path = path;
|
this.path = path;
|
||||||
@@ -95,12 +113,18 @@ public class GetAllLibrariesLocation {
|
|||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ID of the location.
|
||||||
|
*/
|
||||||
public Builder id(int id) {
|
public Builder id(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The path to the media item.
|
||||||
|
*/
|
||||||
public Builder path(String path) {
|
public Builder path(String path) {
|
||||||
Utils.checkNotNull(path, "path");
|
Utils.checkNotNull(path, "path");
|
||||||
this.path = path;
|
this.path = path;
|
||||||
|
|||||||
@@ -5,35 +5,49 @@ package dev.plexapi.sdk.models.operations;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Boolean;
|
import java.lang.Boolean;
|
||||||
import java.lang.Integer;
|
import java.lang.Integer;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
public class GetAllLibrariesMediaContainer {
|
public class GetAllLibrariesMediaContainer {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of media items returned in this response.
|
||||||
|
*/
|
||||||
@JsonProperty("size")
|
@JsonProperty("size")
|
||||||
private int size;
|
private int size;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
@JsonProperty("allowSync")
|
@JsonProperty("allowSync")
|
||||||
private boolean allowSync;
|
private boolean allowSync;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The primary title of the media container.
|
||||||
|
*/
|
||||||
@JsonProperty("title1")
|
@JsonProperty("title1")
|
||||||
private String title1;
|
private String title1;
|
||||||
|
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("Directory")
|
@JsonProperty("Directory")
|
||||||
private List<GetAllLibrariesDirectory> directory;
|
private Optional<? extends List<GetAllLibrariesDirectory>> directory;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetAllLibrariesMediaContainer(
|
public GetAllLibrariesMediaContainer(
|
||||||
@JsonProperty("size") int size,
|
@JsonProperty("size") int size,
|
||||||
@JsonProperty("allowSync") boolean allowSync,
|
@JsonProperty("allowSync") boolean allowSync,
|
||||||
@JsonProperty("title1") String title1,
|
@JsonProperty("title1") String title1,
|
||||||
@JsonProperty("Directory") List<GetAllLibrariesDirectory> directory) {
|
@JsonProperty("Directory") Optional<? extends List<GetAllLibrariesDirectory>> directory) {
|
||||||
Utils.checkNotNull(size, "size");
|
Utils.checkNotNull(size, "size");
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
Utils.checkNotNull(title1, "title1");
|
Utils.checkNotNull(title1, "title1");
|
||||||
@@ -43,43 +57,69 @@ public class GetAllLibrariesMediaContainer {
|
|||||||
this.title1 = title1;
|
this.title1 = title1;
|
||||||
this.directory = directory;
|
this.directory = directory;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesMediaContainer(
|
||||||
|
int size,
|
||||||
|
boolean allowSync,
|
||||||
|
String title1) {
|
||||||
|
this(size, allowSync, title1, Optional.empty());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of media items returned in this response.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int size() {
|
public int size() {
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public boolean allowSync() {
|
public boolean allowSync() {
|
||||||
return allowSync;
|
return allowSync;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The primary title of the media container.
|
||||||
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String title1() {
|
public String title1() {
|
||||||
return title1;
|
return title1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public List<GetAllLibrariesDirectory> directory() {
|
public Optional<List<GetAllLibrariesDirectory>> directory() {
|
||||||
return directory;
|
return (Optional<List<GetAllLibrariesDirectory>>) directory;
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static Builder builder() {
|
public final static Builder builder() {
|
||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of media items returned in this response.
|
||||||
|
*/
|
||||||
public GetAllLibrariesMediaContainer withSize(int size) {
|
public GetAllLibrariesMediaContainer withSize(int size) {
|
||||||
Utils.checkNotNull(size, "size");
|
Utils.checkNotNull(size, "size");
|
||||||
this.size = size;
|
this.size = size;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
public GetAllLibrariesMediaContainer withAllowSync(boolean allowSync) {
|
public GetAllLibrariesMediaContainer withAllowSync(boolean allowSync) {
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
this.allowSync = allowSync;
|
this.allowSync = allowSync;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The primary title of the media container.
|
||||||
|
*/
|
||||||
public GetAllLibrariesMediaContainer withTitle1(String title1) {
|
public GetAllLibrariesMediaContainer withTitle1(String title1) {
|
||||||
Utils.checkNotNull(title1, "title1");
|
Utils.checkNotNull(title1, "title1");
|
||||||
this.title1 = title1;
|
this.title1 = title1;
|
||||||
@@ -87,6 +127,12 @@ public class GetAllLibrariesMediaContainer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GetAllLibrariesMediaContainer withDirectory(List<GetAllLibrariesDirectory> directory) {
|
public GetAllLibrariesMediaContainer withDirectory(List<GetAllLibrariesDirectory> directory) {
|
||||||
|
Utils.checkNotNull(directory, "directory");
|
||||||
|
this.directory = Optional.ofNullable(directory);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesMediaContainer withDirectory(Optional<? extends List<GetAllLibrariesDirectory>> directory) {
|
||||||
Utils.checkNotNull(directory, "directory");
|
Utils.checkNotNull(directory, "directory");
|
||||||
this.directory = directory;
|
this.directory = directory;
|
||||||
return this;
|
return this;
|
||||||
@@ -135,24 +181,33 @@ public class GetAllLibrariesMediaContainer {
|
|||||||
|
|
||||||
private String title1;
|
private String title1;
|
||||||
|
|
||||||
private List<GetAllLibrariesDirectory> directory;
|
private Optional<? extends List<GetAllLibrariesDirectory>> directory = Optional.empty();
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of media items returned in this response.
|
||||||
|
*/
|
||||||
public Builder size(int size) {
|
public Builder size(int size) {
|
||||||
Utils.checkNotNull(size, "size");
|
Utils.checkNotNull(size, "size");
|
||||||
this.size = size;
|
this.size = size;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether syncing is allowed.
|
||||||
|
*/
|
||||||
public Builder allowSync(boolean allowSync) {
|
public Builder allowSync(boolean allowSync) {
|
||||||
Utils.checkNotNull(allowSync, "allowSync");
|
Utils.checkNotNull(allowSync, "allowSync");
|
||||||
this.allowSync = allowSync;
|
this.allowSync = allowSync;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The primary title of the media container.
|
||||||
|
*/
|
||||||
public Builder title1(String title1) {
|
public Builder title1(String title1) {
|
||||||
Utils.checkNotNull(title1, "title1");
|
Utils.checkNotNull(title1, "title1");
|
||||||
this.title1 = title1;
|
this.title1 = title1;
|
||||||
@@ -160,6 +215,12 @@ public class GetAllLibrariesMediaContainer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Builder directory(List<GetAllLibrariesDirectory> directory) {
|
public Builder directory(List<GetAllLibrariesDirectory> directory) {
|
||||||
|
Utils.checkNotNull(directory, "directory");
|
||||||
|
this.directory = Optional.ofNullable(directory);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder directory(Optional<? extends List<GetAllLibrariesDirectory>> directory) {
|
||||||
Utils.checkNotNull(directory, "directory");
|
Utils.checkNotNull(directory, "directory");
|
||||||
this.directory = directory;
|
this.directory = directory;
|
||||||
return this;
|
return this;
|
||||||
|
|||||||
@@ -5,11 +5,15 @@ package dev.plexapi.sdk.models.operations;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GetAllLibrariesResponseBody
|
* GetAllLibrariesResponseBody
|
||||||
@@ -18,19 +22,25 @@ import java.util.Objects;
|
|||||||
*/
|
*/
|
||||||
public class GetAllLibrariesResponseBody {
|
public class GetAllLibrariesResponseBody {
|
||||||
|
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("MediaContainer")
|
@JsonProperty("MediaContainer")
|
||||||
private GetAllLibrariesMediaContainer mediaContainer;
|
private Optional<? extends GetAllLibrariesMediaContainer> mediaContainer;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetAllLibrariesResponseBody(
|
public GetAllLibrariesResponseBody(
|
||||||
@JsonProperty("MediaContainer") GetAllLibrariesMediaContainer mediaContainer) {
|
@JsonProperty("MediaContainer") Optional<? extends GetAllLibrariesMediaContainer> mediaContainer) {
|
||||||
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
||||||
this.mediaContainer = mediaContainer;
|
this.mediaContainer = mediaContainer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesResponseBody() {
|
||||||
|
this(Optional.empty());
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public GetAllLibrariesMediaContainer mediaContainer() {
|
public Optional<GetAllLibrariesMediaContainer> mediaContainer() {
|
||||||
return mediaContainer;
|
return (Optional<GetAllLibrariesMediaContainer>) mediaContainer;
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static Builder builder() {
|
public final static Builder builder() {
|
||||||
@@ -38,6 +48,12 @@ public class GetAllLibrariesResponseBody {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GetAllLibrariesResponseBody withMediaContainer(GetAllLibrariesMediaContainer mediaContainer) {
|
public GetAllLibrariesResponseBody withMediaContainer(GetAllLibrariesMediaContainer mediaContainer) {
|
||||||
|
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
||||||
|
this.mediaContainer = Optional.ofNullable(mediaContainer);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetAllLibrariesResponseBody withMediaContainer(Optional<? extends GetAllLibrariesMediaContainer> mediaContainer) {
|
||||||
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
||||||
this.mediaContainer = mediaContainer;
|
this.mediaContainer = mediaContainer;
|
||||||
return this;
|
return this;
|
||||||
@@ -71,13 +87,19 @@ public class GetAllLibrariesResponseBody {
|
|||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private GetAllLibrariesMediaContainer mediaContainer;
|
private Optional<? extends GetAllLibrariesMediaContainer> mediaContainer = Optional.empty();
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder mediaContainer(GetAllLibrariesMediaContainer mediaContainer) {
|
public Builder mediaContainer(GetAllLibrariesMediaContainer mediaContainer) {
|
||||||
|
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
||||||
|
this.mediaContainer = Optional.ofNullable(mediaContainer);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder mediaContainer(Optional<? extends GetAllLibrariesMediaContainer> mediaContainer) {
|
||||||
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
Utils.checkNotNull(mediaContainer, "mediaContainer");
|
||||||
this.mediaContainer = mediaContainer;
|
this.mediaContainer = mediaContainer;
|
||||||
return this;
|
return this;
|
||||||
|
|||||||
@@ -0,0 +1,200 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* GetAllLibrariesType
|
||||||
|
*
|
||||||
|
* <p>The library type
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetAllLibrariesType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetAllLibrariesType._Serializer.class)
|
||||||
|
public class GetAllLibrariesType {
|
||||||
|
|
||||||
|
public static final GetAllLibrariesType Movie = new GetAllLibrariesType("movie");
|
||||||
|
public static final GetAllLibrariesType TvShow = new GetAllLibrariesType("show");
|
||||||
|
public static final GetAllLibrariesType Season = new GetAllLibrariesType("season");
|
||||||
|
public static final GetAllLibrariesType Episode = new GetAllLibrariesType("episode");
|
||||||
|
public static final GetAllLibrariesType Artist = new GetAllLibrariesType("artist");
|
||||||
|
public static final GetAllLibrariesType Album = new GetAllLibrariesType("album");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetAllLibrariesType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetAllLibrariesTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetAllLibrariesType(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetAllLibrariesType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetAllLibrariesType
|
||||||
|
*/
|
||||||
|
public static GetAllLibrariesType of(String value) {
|
||||||
|
synchronized (GetAllLibrariesType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetAllLibrariesType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<GetAllLibrariesTypeEnum> asEnum() {
|
||||||
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetAllLibrariesType other = (GetAllLibrariesType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetAllLibrariesType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetAllLibrariesType[] values() {
|
||||||
|
synchronized (GetAllLibrariesType.class) {
|
||||||
|
return values.values().toArray(new GetAllLibrariesType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllLibrariesType> createValuesMap() {
|
||||||
|
Map<String, GetAllLibrariesType> map = new LinkedHashMap<>();
|
||||||
|
map.put("movie", Movie);
|
||||||
|
map.put("show", TvShow);
|
||||||
|
map.put("season", Season);
|
||||||
|
map.put("episode", Episode);
|
||||||
|
map.put("artist", Artist);
|
||||||
|
map.put("album", Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllLibrariesTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetAllLibrariesTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("movie", GetAllLibrariesTypeEnum.Movie);
|
||||||
|
map.put("show", GetAllLibrariesTypeEnum.TvShow);
|
||||||
|
map.put("season", GetAllLibrariesTypeEnum.Season);
|
||||||
|
map.put("episode", GetAllLibrariesTypeEnum.Episode);
|
||||||
|
map.put("artist", GetAllLibrariesTypeEnum.Artist);
|
||||||
|
map.put("album", GetAllLibrariesTypeEnum.Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetAllLibrariesType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetAllLibrariesType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetAllLibrariesType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetAllLibrariesType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetAllLibrariesType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetAllLibrariesType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetAllLibrariesType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetAllLibrariesTypeEnum {
|
||||||
|
|
||||||
|
Movie("movie"),
|
||||||
|
TvShow("show"),
|
||||||
|
Season("season"),
|
||||||
|
Episode("episode"),
|
||||||
|
Artist("artist"),
|
||||||
|
Album("album"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetAllLibrariesTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -3,35 +3,185 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public enum GetAllMediaLibraryLibraryResponseType {
|
/**
|
||||||
COVER_POSTER("coverPoster"),
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
BACKGROUND("background"),
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
SNAPSHOT("snapshot"),
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
CLEAR_LOGO("clearLogo");
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetAllMediaLibraryLibraryResponseType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetAllMediaLibraryLibraryResponseType._Serializer.class)
|
||||||
|
public class GetAllMediaLibraryLibraryResponseType {
|
||||||
|
|
||||||
|
public static final GetAllMediaLibraryLibraryResponseType COVER_POSTER = new GetAllMediaLibraryLibraryResponseType("coverPoster");
|
||||||
|
public static final GetAllMediaLibraryLibraryResponseType BACKGROUND = new GetAllMediaLibraryLibraryResponseType("background");
|
||||||
|
public static final GetAllMediaLibraryLibraryResponseType SNAPSHOT = new GetAllMediaLibraryLibraryResponseType("snapshot");
|
||||||
|
public static final GetAllMediaLibraryLibraryResponseType CLEAR_LOGO = new GetAllMediaLibraryLibraryResponseType("clearLogo");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryResponseType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryResponseTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetAllMediaLibraryLibraryResponseType(String value) {
|
private GetAllMediaLibraryLibraryResponseType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetAllMediaLibraryLibraryResponseType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetAllMediaLibraryLibraryResponseType
|
||||||
|
*/
|
||||||
|
public static GetAllMediaLibraryLibraryResponseType of(String value) {
|
||||||
|
synchronized (GetAllMediaLibraryLibraryResponseType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetAllMediaLibraryLibraryResponseType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetAllMediaLibraryLibraryResponseType> fromValue(String value) {
|
public Optional<GetAllMediaLibraryLibraryResponseTypeEnum> asEnum() {
|
||||||
for (GetAllMediaLibraryLibraryResponseType o: GetAllMediaLibraryLibraryResponseType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetAllMediaLibraryLibraryResponseType other = (GetAllMediaLibraryLibraryResponseType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetAllMediaLibraryLibraryResponseType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetAllMediaLibraryLibraryResponseType[] values() {
|
||||||
|
synchronized (GetAllMediaLibraryLibraryResponseType.class) {
|
||||||
|
return values.values().toArray(new GetAllMediaLibraryLibraryResponseType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryResponseType> createValuesMap() {
|
||||||
|
Map<String, GetAllMediaLibraryLibraryResponseType> map = new LinkedHashMap<>();
|
||||||
|
map.put("coverPoster", COVER_POSTER);
|
||||||
|
map.put("background", BACKGROUND);
|
||||||
|
map.put("snapshot", SNAPSHOT);
|
||||||
|
map.put("clearLogo", CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryResponseTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetAllMediaLibraryLibraryResponseTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("coverPoster", GetAllMediaLibraryLibraryResponseTypeEnum.COVER_POSTER);
|
||||||
|
map.put("background", GetAllMediaLibraryLibraryResponseTypeEnum.BACKGROUND);
|
||||||
|
map.put("snapshot", GetAllMediaLibraryLibraryResponseTypeEnum.SNAPSHOT);
|
||||||
|
map.put("clearLogo", GetAllMediaLibraryLibraryResponseTypeEnum.CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetAllMediaLibraryLibraryResponseType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetAllMediaLibraryLibraryResponseType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetAllMediaLibraryLibraryResponseType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetAllMediaLibraryLibraryResponseType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetAllMediaLibraryLibraryResponseType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetAllMediaLibraryLibraryResponseType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetAllMediaLibraryLibraryResponseType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetAllMediaLibraryLibraryResponseTypeEnum {
|
||||||
|
|
||||||
|
COVER_POSTER("coverPoster"),
|
||||||
|
BACKGROUND("background"),
|
||||||
|
SNAPSHOT("snapshot"),
|
||||||
|
CLEAR_LOGO("clearLogo"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetAllMediaLibraryLibraryResponseTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,42 +3,198 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetAllMediaLibraryLibraryType
|
* GetAllMediaLibraryLibraryType
|
||||||
*
|
*
|
||||||
* <p>The type of media content
|
* <p>The type of media content
|
||||||
*/
|
*/
|
||||||
public enum GetAllMediaLibraryLibraryType {
|
@JsonDeserialize(using = GetAllMediaLibraryLibraryType._Deserializer.class)
|
||||||
Movie("movie"),
|
@JsonSerialize(using = GetAllMediaLibraryLibraryType._Serializer.class)
|
||||||
TvShow("show"),
|
public class GetAllMediaLibraryLibraryType {
|
||||||
Season("season"),
|
|
||||||
Episode("episode"),
|
public static final GetAllMediaLibraryLibraryType Movie = new GetAllMediaLibraryLibraryType("movie");
|
||||||
Artist("artist"),
|
public static final GetAllMediaLibraryLibraryType TvShow = new GetAllMediaLibraryLibraryType("show");
|
||||||
Album("album");
|
public static final GetAllMediaLibraryLibraryType Season = new GetAllMediaLibraryLibraryType("season");
|
||||||
|
public static final GetAllMediaLibraryLibraryType Episode = new GetAllMediaLibraryLibraryType("episode");
|
||||||
|
public static final GetAllMediaLibraryLibraryType Artist = new GetAllMediaLibraryLibraryType("artist");
|
||||||
|
public static final GetAllMediaLibraryLibraryType Album = new GetAllMediaLibraryLibraryType("album");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetAllMediaLibraryLibraryType(String value) {
|
private GetAllMediaLibraryLibraryType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetAllMediaLibraryLibraryType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetAllMediaLibraryLibraryType
|
||||||
|
*/
|
||||||
|
public static GetAllMediaLibraryLibraryType of(String value) {
|
||||||
|
synchronized (GetAllMediaLibraryLibraryType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetAllMediaLibraryLibraryType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetAllMediaLibraryLibraryType> fromValue(String value) {
|
public Optional<GetAllMediaLibraryLibraryTypeEnum> asEnum() {
|
||||||
for (GetAllMediaLibraryLibraryType o: GetAllMediaLibraryLibraryType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetAllMediaLibraryLibraryType other = (GetAllMediaLibraryLibraryType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetAllMediaLibraryLibraryType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetAllMediaLibraryLibraryType[] values() {
|
||||||
|
synchronized (GetAllMediaLibraryLibraryType.class) {
|
||||||
|
return values.values().toArray(new GetAllMediaLibraryLibraryType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryType> createValuesMap() {
|
||||||
|
Map<String, GetAllMediaLibraryLibraryType> map = new LinkedHashMap<>();
|
||||||
|
map.put("movie", Movie);
|
||||||
|
map.put("show", TvShow);
|
||||||
|
map.put("season", Season);
|
||||||
|
map.put("episode", Episode);
|
||||||
|
map.put("artist", Artist);
|
||||||
|
map.put("album", Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetAllMediaLibraryLibraryTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetAllMediaLibraryLibraryTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("movie", GetAllMediaLibraryLibraryTypeEnum.Movie);
|
||||||
|
map.put("show", GetAllMediaLibraryLibraryTypeEnum.TvShow);
|
||||||
|
map.put("season", GetAllMediaLibraryLibraryTypeEnum.Season);
|
||||||
|
map.put("episode", GetAllMediaLibraryLibraryTypeEnum.Episode);
|
||||||
|
map.put("artist", GetAllMediaLibraryLibraryTypeEnum.Artist);
|
||||||
|
map.put("album", GetAllMediaLibraryLibraryTypeEnum.Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetAllMediaLibraryLibraryType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetAllMediaLibraryLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetAllMediaLibraryLibraryType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetAllMediaLibraryLibraryType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetAllMediaLibraryLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetAllMediaLibraryLibraryType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetAllMediaLibraryLibraryType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetAllMediaLibraryLibraryTypeEnum {
|
||||||
|
|
||||||
|
Movie("movie"),
|
||||||
|
TvShow("show"),
|
||||||
|
Season("season"),
|
||||||
|
Episode("episode"),
|
||||||
|
Artist("artist"),
|
||||||
|
Album("album"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetAllMediaLibraryLibraryTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetAllMediaLibraryQueryParamType
|
* GetAllMediaLibraryQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetAllMediaLibraryQueryParamType {
|
@JsonDeserialize(using = GetAllMediaLibraryQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetAllMediaLibraryQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetAllMediaLibraryQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetAllMediaLibraryQueryParamType Movie = new GetAllMediaLibraryQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetAllMediaLibraryQueryParamType TvShow = new GetAllMediaLibraryQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetAllMediaLibraryQueryParamType Season = new GetAllMediaLibraryQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetAllMediaLibraryQueryParamType Episode = new GetAllMediaLibraryQueryParamType(4L);
|
||||||
|
public static final GetAllMediaLibraryQueryParamType Audio = new GetAllMediaLibraryQueryParamType(8L);
|
||||||
|
public static final GetAllMediaLibraryQueryParamType Album = new GetAllMediaLibraryQueryParamType(9L);
|
||||||
|
public static final GetAllMediaLibraryQueryParamType Track = new GetAllMediaLibraryQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetAllMediaLibraryQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetAllMediaLibraryQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetAllMediaLibraryQueryParamType(long value) {
|
private GetAllMediaLibraryQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetAllMediaLibraryQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetAllMediaLibraryQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetAllMediaLibraryQueryParamType of(long value) {
|
||||||
|
synchronized (GetAllMediaLibraryQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetAllMediaLibraryQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetAllMediaLibraryQueryParamType> fromValue(long value) {
|
public Optional<GetAllMediaLibraryQueryParamTypeEnum> asEnum() {
|
||||||
for (GetAllMediaLibraryQueryParamType o: GetAllMediaLibraryQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetAllMediaLibraryQueryParamType other = (GetAllMediaLibraryQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetAllMediaLibraryQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetAllMediaLibraryQueryParamType[] values() {
|
||||||
|
synchronized (GetAllMediaLibraryQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetAllMediaLibraryQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetAllMediaLibraryQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetAllMediaLibraryQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetAllMediaLibraryQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetAllMediaLibraryQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetAllMediaLibraryQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetAllMediaLibraryQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetAllMediaLibraryQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetAllMediaLibraryQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetAllMediaLibraryQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetAllMediaLibraryQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetAllMediaLibraryQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetAllMediaLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetAllMediaLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetAllMediaLibraryQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetAllMediaLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetAllMediaLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetAllMediaLibraryQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetAllMediaLibraryQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetAllMediaLibraryQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetAllMediaLibraryQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -27,10 +27,20 @@ public class GetAllMediaLibraryStream {
|
|||||||
private long id;
|
private long id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
@JsonProperty("streamType")
|
@JsonProperty("streamType")
|
||||||
private int streamType;
|
private GetAllMediaLibraryStreamType streamType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("format")
|
||||||
|
private Optional<String> format;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
@@ -48,8 +58,9 @@ public class GetAllMediaLibraryStream {
|
|||||||
/**
|
/**
|
||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("index")
|
@JsonProperty("index")
|
||||||
private int index;
|
private Optional<Integer> index;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bitrate of the stream.
|
* Bitrate of the stream.
|
||||||
@@ -216,6 +227,13 @@ public class GetAllMediaLibraryStream {
|
|||||||
@JsonProperty("frameRate")
|
@JsonProperty("frameRate")
|
||||||
private Optional<Float> frameRate;
|
private Optional<Float> frameRate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("key")
|
||||||
|
private Optional<String> key;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -345,10 +363,11 @@ public class GetAllMediaLibraryStream {
|
|||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetAllMediaLibraryStream(
|
public GetAllMediaLibraryStream(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") long id,
|
||||||
@JsonProperty("streamType") int streamType,
|
@JsonProperty("streamType") GetAllMediaLibraryStreamType streamType,
|
||||||
|
@JsonProperty("format") Optional<String> format,
|
||||||
@JsonProperty("default") Optional<Boolean> default_,
|
@JsonProperty("default") Optional<Boolean> default_,
|
||||||
@JsonProperty("codec") String codec,
|
@JsonProperty("codec") String codec,
|
||||||
@JsonProperty("index") int index,
|
@JsonProperty("index") Optional<Integer> index,
|
||||||
@JsonProperty("bitrate") Optional<Integer> bitrate,
|
@JsonProperty("bitrate") Optional<Integer> bitrate,
|
||||||
@JsonProperty("language") Optional<String> language,
|
@JsonProperty("language") Optional<String> language,
|
||||||
@JsonProperty("languageTag") Optional<String> languageTag,
|
@JsonProperty("languageTag") Optional<String> languageTag,
|
||||||
@@ -373,6 +392,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
@JsonProperty("colorSpace") Optional<String> colorSpace,
|
@JsonProperty("colorSpace") Optional<String> colorSpace,
|
||||||
@JsonProperty("colorTrc") Optional<String> colorTrc,
|
@JsonProperty("colorTrc") Optional<String> colorTrc,
|
||||||
@JsonProperty("frameRate") Optional<Float> frameRate,
|
@JsonProperty("frameRate") Optional<Float> frameRate,
|
||||||
|
@JsonProperty("key") Optional<String> key,
|
||||||
@JsonProperty("height") Optional<Integer> height,
|
@JsonProperty("height") Optional<Integer> height,
|
||||||
@JsonProperty("level") Optional<Integer> level,
|
@JsonProperty("level") Optional<Integer> level,
|
||||||
@JsonProperty("original") Optional<Boolean> original,
|
@JsonProperty("original") Optional<Boolean> original,
|
||||||
@@ -395,6 +415,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
@JsonProperty("title") Optional<String> title) {
|
@JsonProperty("title") Optional<String> title) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
Utils.checkNotNull(default_, "default_");
|
Utils.checkNotNull(default_, "default_");
|
||||||
Utils.checkNotNull(codec, "codec");
|
Utils.checkNotNull(codec, "codec");
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
@@ -422,6 +443,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
Utils.checkNotNull(colorSpace, "colorSpace");
|
Utils.checkNotNull(colorSpace, "colorSpace");
|
||||||
Utils.checkNotNull(colorTrc, "colorTrc");
|
Utils.checkNotNull(colorTrc, "colorTrc");
|
||||||
Utils.checkNotNull(frameRate, "frameRate");
|
Utils.checkNotNull(frameRate, "frameRate");
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
Utils.checkNotNull(height, "height");
|
Utils.checkNotNull(height, "height");
|
||||||
Utils.checkNotNull(level, "level");
|
Utils.checkNotNull(level, "level");
|
||||||
Utils.checkNotNull(original, "original");
|
Utils.checkNotNull(original, "original");
|
||||||
@@ -444,6 +466,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
Utils.checkNotNull(title, "title");
|
Utils.checkNotNull(title, "title");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
|
this.format = format;
|
||||||
this.default_ = default_;
|
this.default_ = default_;
|
||||||
this.codec = codec;
|
this.codec = codec;
|
||||||
this.index = index;
|
this.index = index;
|
||||||
@@ -471,6 +494,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
this.colorSpace = colorSpace;
|
this.colorSpace = colorSpace;
|
||||||
this.colorTrc = colorTrc;
|
this.colorTrc = colorTrc;
|
||||||
this.frameRate = frameRate;
|
this.frameRate = frameRate;
|
||||||
|
this.key = key;
|
||||||
this.height = height;
|
this.height = height;
|
||||||
this.level = level;
|
this.level = level;
|
||||||
this.original = original;
|
this.original = original;
|
||||||
@@ -495,12 +519,11 @@ public class GetAllMediaLibraryStream {
|
|||||||
|
|
||||||
public GetAllMediaLibraryStream(
|
public GetAllMediaLibraryStream(
|
||||||
long id,
|
long id,
|
||||||
int streamType,
|
GetAllMediaLibraryStreamType streamType,
|
||||||
String codec,
|
String codec,
|
||||||
int index,
|
|
||||||
String displayTitle,
|
String displayTitle,
|
||||||
String extendedDisplayTitle) {
|
String extendedDisplayTitle) {
|
||||||
this(id, streamType, Optional.empty(), codec, index, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), displayTitle, extendedDisplayTitle, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty());
|
this(id, streamType, Optional.empty(), Optional.empty(), codec, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), displayTitle, extendedDisplayTitle, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -512,13 +535,24 @@ public class GetAllMediaLibraryStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int streamType() {
|
public GetAllMediaLibraryStreamType streamType() {
|
||||||
return streamType;
|
return streamType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> format() {
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -539,7 +573,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int index() {
|
public Optional<Integer> index() {
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -732,6 +766,14 @@ public class GetAllMediaLibraryStream {
|
|||||||
return frameRate;
|
return frameRate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> key() {
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -894,14 +936,35 @@ public class GetAllMediaLibraryStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
public GetAllMediaLibraryStream withStreamType(int streamType) {
|
public GetAllMediaLibraryStream withStreamType(GetAllMediaLibraryStreamType streamType) {
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public GetAllMediaLibraryStream withFormat(String format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = Optional.ofNullable(format);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public GetAllMediaLibraryStream withFormat(Optional<String> format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = format;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -933,6 +996,15 @@ public class GetAllMediaLibraryStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
public GetAllMediaLibraryStream withIndex(int index) {
|
public GetAllMediaLibraryStream withIndex(int index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = Optional.ofNullable(index);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Index of the stream.
|
||||||
|
*/
|
||||||
|
public GetAllMediaLibraryStream withIndex(Optional<Integer> index) {
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
this.index = index;
|
this.index = index;
|
||||||
return this;
|
return this;
|
||||||
@@ -1364,6 +1436,24 @@ public class GetAllMediaLibraryStream {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public GetAllMediaLibraryStream withKey(String key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = Optional.ofNullable(key);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public GetAllMediaLibraryStream withKey(Optional<String> key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = key;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -1695,6 +1785,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.streamType, other.streamType) &&
|
Objects.deepEquals(this.streamType, other.streamType) &&
|
||||||
|
Objects.deepEquals(this.format, other.format) &&
|
||||||
Objects.deepEquals(this.default_, other.default_) &&
|
Objects.deepEquals(this.default_, other.default_) &&
|
||||||
Objects.deepEquals(this.codec, other.codec) &&
|
Objects.deepEquals(this.codec, other.codec) &&
|
||||||
Objects.deepEquals(this.index, other.index) &&
|
Objects.deepEquals(this.index, other.index) &&
|
||||||
@@ -1722,6 +1813,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
Objects.deepEquals(this.colorSpace, other.colorSpace) &&
|
Objects.deepEquals(this.colorSpace, other.colorSpace) &&
|
||||||
Objects.deepEquals(this.colorTrc, other.colorTrc) &&
|
Objects.deepEquals(this.colorTrc, other.colorTrc) &&
|
||||||
Objects.deepEquals(this.frameRate, other.frameRate) &&
|
Objects.deepEquals(this.frameRate, other.frameRate) &&
|
||||||
|
Objects.deepEquals(this.key, other.key) &&
|
||||||
Objects.deepEquals(this.height, other.height) &&
|
Objects.deepEquals(this.height, other.height) &&
|
||||||
Objects.deepEquals(this.level, other.level) &&
|
Objects.deepEquals(this.level, other.level) &&
|
||||||
Objects.deepEquals(this.original, other.original) &&
|
Objects.deepEquals(this.original, other.original) &&
|
||||||
@@ -1749,6 +1841,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
streamType,
|
streamType,
|
||||||
|
format,
|
||||||
default_,
|
default_,
|
||||||
codec,
|
codec,
|
||||||
index,
|
index,
|
||||||
@@ -1776,6 +1869,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
colorSpace,
|
colorSpace,
|
||||||
colorTrc,
|
colorTrc,
|
||||||
frameRate,
|
frameRate,
|
||||||
|
key,
|
||||||
height,
|
height,
|
||||||
level,
|
level,
|
||||||
original,
|
original,
|
||||||
@@ -1803,6 +1897,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
return Utils.toString(GetAllMediaLibraryStream.class,
|
return Utils.toString(GetAllMediaLibraryStream.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"streamType", streamType,
|
"streamType", streamType,
|
||||||
|
"format", format,
|
||||||
"default_", default_,
|
"default_", default_,
|
||||||
"codec", codec,
|
"codec", codec,
|
||||||
"index", index,
|
"index", index,
|
||||||
@@ -1830,6 +1925,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
"colorSpace", colorSpace,
|
"colorSpace", colorSpace,
|
||||||
"colorTrc", colorTrc,
|
"colorTrc", colorTrc,
|
||||||
"frameRate", frameRate,
|
"frameRate", frameRate,
|
||||||
|
"key", key,
|
||||||
"height", height,
|
"height", height,
|
||||||
"level", level,
|
"level", level,
|
||||||
"original", original,
|
"original", original,
|
||||||
@@ -1856,13 +1952,15 @@ public class GetAllMediaLibraryStream {
|
|||||||
|
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
private Integer streamType;
|
private GetAllMediaLibraryStreamType streamType;
|
||||||
|
|
||||||
|
private Optional<String> format = Optional.empty();
|
||||||
|
|
||||||
private Optional<Boolean> default_ = Optional.empty();
|
private Optional<Boolean> default_ = Optional.empty();
|
||||||
|
|
||||||
private String codec;
|
private String codec;
|
||||||
|
|
||||||
private Integer index;
|
private Optional<Integer> index = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> bitrate = Optional.empty();
|
private Optional<Integer> bitrate = Optional.empty();
|
||||||
|
|
||||||
@@ -1912,6 +2010,8 @@ public class GetAllMediaLibraryStream {
|
|||||||
|
|
||||||
private Optional<Float> frameRate = Optional.empty();
|
private Optional<Float> frameRate = Optional.empty();
|
||||||
|
|
||||||
|
private Optional<String> key = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> height = Optional.empty();
|
private Optional<Integer> height = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> level = Optional.empty();
|
private Optional<Integer> level = Optional.empty();
|
||||||
@@ -1966,14 +2066,35 @@ public class GetAllMediaLibraryStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
public Builder streamType(int streamType) {
|
public Builder streamType(GetAllMediaLibraryStreamType streamType) {
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public Builder format(String format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = Optional.ofNullable(format);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public Builder format(Optional<String> format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = format;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -2005,6 +2126,15 @@ public class GetAllMediaLibraryStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
public Builder index(int index) {
|
public Builder index(int index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = Optional.ofNullable(index);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Index of the stream.
|
||||||
|
*/
|
||||||
|
public Builder index(Optional<Integer> index) {
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
this.index = index;
|
this.index = index;
|
||||||
return this;
|
return this;
|
||||||
@@ -2436,6 +2566,24 @@ public class GetAllMediaLibraryStream {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public Builder key(String key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = Optional.ofNullable(key);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public Builder key(Optional<String> key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = key;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -2758,6 +2906,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
return new GetAllMediaLibraryStream(
|
return new GetAllMediaLibraryStream(
|
||||||
id,
|
id,
|
||||||
streamType,
|
streamType,
|
||||||
|
format,
|
||||||
default_,
|
default_,
|
||||||
codec,
|
codec,
|
||||||
index,
|
index,
|
||||||
@@ -2785,6 +2934,7 @@ public class GetAllMediaLibraryStream {
|
|||||||
colorSpace,
|
colorSpace,
|
||||||
colorTrc,
|
colorTrc,
|
||||||
frameRate,
|
frameRate,
|
||||||
|
key,
|
||||||
height,
|
height,
|
||||||
level,
|
level,
|
||||||
original,
|
original,
|
||||||
|
|||||||
@@ -0,0 +1,192 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Integer;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* GetAllMediaLibraryStreamType
|
||||||
|
*
|
||||||
|
* <p>Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetAllMediaLibraryStreamType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetAllMediaLibraryStreamType._Serializer.class)
|
||||||
|
public class GetAllMediaLibraryStreamType {
|
||||||
|
|
||||||
|
public static final GetAllMediaLibraryStreamType Video = new GetAllMediaLibraryStreamType(1);
|
||||||
|
public static final GetAllMediaLibraryStreamType Audio = new GetAllMediaLibraryStreamType(2);
|
||||||
|
public static final GetAllMediaLibraryStreamType Subtitle = new GetAllMediaLibraryStreamType(3);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Integer, GetAllMediaLibraryStreamType> values = createValuesMap();
|
||||||
|
private static final Map<Integer, GetAllMediaLibraryStreamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
|
private final int value;
|
||||||
|
|
||||||
|
private GetAllMediaLibraryStreamType(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetAllMediaLibraryStreamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetAllMediaLibraryStreamType
|
||||||
|
*/
|
||||||
|
public static GetAllMediaLibraryStreamType of(int value) {
|
||||||
|
synchronized (GetAllMediaLibraryStreamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetAllMediaLibraryStreamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<GetAllMediaLibraryStreamTypeEnum> asEnum() {
|
||||||
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetAllMediaLibraryStreamType other = (GetAllMediaLibraryStreamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetAllMediaLibraryStreamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetAllMediaLibraryStreamType[] values() {
|
||||||
|
synchronized (GetAllMediaLibraryStreamType.class) {
|
||||||
|
return values.values().toArray(new GetAllMediaLibraryStreamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Integer, GetAllMediaLibraryStreamType> createValuesMap() {
|
||||||
|
Map<Integer, GetAllMediaLibraryStreamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1, Video);
|
||||||
|
map.put(2, Audio);
|
||||||
|
map.put(3, Subtitle);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Integer, GetAllMediaLibraryStreamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Integer, GetAllMediaLibraryStreamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1, GetAllMediaLibraryStreamTypeEnum.Video);
|
||||||
|
map.put(2, GetAllMediaLibraryStreamTypeEnum.Audio);
|
||||||
|
map.put(3, GetAllMediaLibraryStreamTypeEnum.Subtitle);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetAllMediaLibraryStreamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetAllMediaLibraryStreamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetAllMediaLibraryStreamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetAllMediaLibraryStreamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetAllMediaLibraryStreamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetAllMediaLibraryStreamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
int v = p.readValueAs(new TypeReference<Integer>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetAllMediaLibraryStreamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetAllMediaLibraryStreamTypeEnum {
|
||||||
|
|
||||||
|
Video(1),
|
||||||
|
Audio(2),
|
||||||
|
Subtitle(3),;
|
||||||
|
|
||||||
|
private final int value;
|
||||||
|
|
||||||
|
private GetAllMediaLibraryStreamTypeEnum(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetCountriesLibraryQueryParamType
|
* GetCountriesLibraryQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetCountriesLibraryQueryParamType {
|
@JsonDeserialize(using = GetCountriesLibraryQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetCountriesLibraryQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetCountriesLibraryQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetCountriesLibraryQueryParamType Movie = new GetCountriesLibraryQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetCountriesLibraryQueryParamType TvShow = new GetCountriesLibraryQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetCountriesLibraryQueryParamType Season = new GetCountriesLibraryQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetCountriesLibraryQueryParamType Episode = new GetCountriesLibraryQueryParamType(4L);
|
||||||
|
public static final GetCountriesLibraryQueryParamType Audio = new GetCountriesLibraryQueryParamType(8L);
|
||||||
|
public static final GetCountriesLibraryQueryParamType Album = new GetCountriesLibraryQueryParamType(9L);
|
||||||
|
public static final GetCountriesLibraryQueryParamType Track = new GetCountriesLibraryQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetCountriesLibraryQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetCountriesLibraryQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetCountriesLibraryQueryParamType(long value) {
|
private GetCountriesLibraryQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetCountriesLibraryQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetCountriesLibraryQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetCountriesLibraryQueryParamType of(long value) {
|
||||||
|
synchronized (GetCountriesLibraryQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetCountriesLibraryQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetCountriesLibraryQueryParamType> fromValue(long value) {
|
public Optional<GetCountriesLibraryQueryParamTypeEnum> asEnum() {
|
||||||
for (GetCountriesLibraryQueryParamType o: GetCountriesLibraryQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetCountriesLibraryQueryParamType other = (GetCountriesLibraryQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetCountriesLibraryQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetCountriesLibraryQueryParamType[] values() {
|
||||||
|
synchronized (GetCountriesLibraryQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetCountriesLibraryQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetCountriesLibraryQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetCountriesLibraryQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetCountriesLibraryQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetCountriesLibraryQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetCountriesLibraryQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetCountriesLibraryQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetCountriesLibraryQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetCountriesLibraryQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetCountriesLibraryQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetCountriesLibraryQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetCountriesLibraryQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetCountriesLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetCountriesLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetCountriesLibraryQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetCountriesLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetCountriesLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetCountriesLibraryQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetCountriesLibraryQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetCountriesLibraryQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetCountriesLibraryQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetGenresLibraryQueryParamType
|
* GetGenresLibraryQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetGenresLibraryQueryParamType {
|
@JsonDeserialize(using = GetGenresLibraryQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetGenresLibraryQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetGenresLibraryQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetGenresLibraryQueryParamType Movie = new GetGenresLibraryQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetGenresLibraryQueryParamType TvShow = new GetGenresLibraryQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetGenresLibraryQueryParamType Season = new GetGenresLibraryQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetGenresLibraryQueryParamType Episode = new GetGenresLibraryQueryParamType(4L);
|
||||||
|
public static final GetGenresLibraryQueryParamType Audio = new GetGenresLibraryQueryParamType(8L);
|
||||||
|
public static final GetGenresLibraryQueryParamType Album = new GetGenresLibraryQueryParamType(9L);
|
||||||
|
public static final GetGenresLibraryQueryParamType Track = new GetGenresLibraryQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetGenresLibraryQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetGenresLibraryQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetGenresLibraryQueryParamType(long value) {
|
private GetGenresLibraryQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetGenresLibraryQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetGenresLibraryQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetGenresLibraryQueryParamType of(long value) {
|
||||||
|
synchronized (GetGenresLibraryQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetGenresLibraryQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetGenresLibraryQueryParamType> fromValue(long value) {
|
public Optional<GetGenresLibraryQueryParamTypeEnum> asEnum() {
|
||||||
for (GetGenresLibraryQueryParamType o: GetGenresLibraryQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetGenresLibraryQueryParamType other = (GetGenresLibraryQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetGenresLibraryQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetGenresLibraryQueryParamType[] values() {
|
||||||
|
synchronized (GetGenresLibraryQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetGenresLibraryQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetGenresLibraryQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetGenresLibraryQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetGenresLibraryQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetGenresLibraryQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetGenresLibraryQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetGenresLibraryQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetGenresLibraryQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetGenresLibraryQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetGenresLibraryQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetGenresLibraryQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetGenresLibraryQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetGenresLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetGenresLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetGenresLibraryQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetGenresLibraryQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetGenresLibraryQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetGenresLibraryQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetGenresLibraryQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetGenresLibraryQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetGenresLibraryQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ import java.util.Optional;
|
|||||||
public class GetLibraryDetailsRequest {
|
public class GetLibraryDetailsRequest {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
@SpeakeasyMetadata("queryParam:style=form,explode=true,name=includeDetails")
|
@SpeakeasyMetadata("queryParam:style=form,explode=true,name=includeDetails")
|
||||||
@@ -48,7 +48,7 @@ public class GetLibraryDetailsRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@@ -71,7 +71,7 @@ public class GetLibraryDetailsRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
public GetLibraryDetailsRequest withIncludeDetails(IncludeDetails includeDetails) {
|
public GetLibraryDetailsRequest withIncludeDetails(IncludeDetails includeDetails) {
|
||||||
@@ -81,7 +81,7 @@ public class GetLibraryDetailsRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
public GetLibraryDetailsRequest withIncludeDetails(Optional<? extends IncludeDetails> includeDetails) {
|
public GetLibraryDetailsRequest withIncludeDetails(Optional<? extends IncludeDetails> includeDetails) {
|
||||||
@@ -140,7 +140,7 @@ public class GetLibraryDetailsRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
public Builder includeDetails(IncludeDetails includeDetails) {
|
public Builder includeDetails(IncludeDetails includeDetails) {
|
||||||
@@ -150,7 +150,7 @@ public class GetLibraryDetailsRequest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not to include details for a section (types, filters, and sorts).
|
* Whether or not to include details for a section (types, filters, and sorts).
|
||||||
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
* Only exists for backwards compatibility, media providers other than the server libraries have it on always.
|
||||||
*/
|
*/
|
||||||
public Builder includeDetails(Optional<? extends IncludeDetails> includeDetails) {
|
public Builder includeDetails(Optional<? extends IncludeDetails> includeDetails) {
|
||||||
|
|||||||
@@ -3,35 +3,185 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public enum GetLibraryItemsLibraryResponse200Type {
|
/**
|
||||||
COVER_POSTER("coverPoster"),
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
BACKGROUND("background"),
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
SNAPSHOT("snapshot"),
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
CLEAR_LOGO("clearLogo");
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetLibraryItemsLibraryResponse200Type._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetLibraryItemsLibraryResponse200Type._Serializer.class)
|
||||||
|
public class GetLibraryItemsLibraryResponse200Type {
|
||||||
|
|
||||||
|
public static final GetLibraryItemsLibraryResponse200Type COVER_POSTER = new GetLibraryItemsLibraryResponse200Type("coverPoster");
|
||||||
|
public static final GetLibraryItemsLibraryResponse200Type BACKGROUND = new GetLibraryItemsLibraryResponse200Type("background");
|
||||||
|
public static final GetLibraryItemsLibraryResponse200Type SNAPSHOT = new GetLibraryItemsLibraryResponse200Type("snapshot");
|
||||||
|
public static final GetLibraryItemsLibraryResponse200Type CLEAR_LOGO = new GetLibraryItemsLibraryResponse200Type("clearLogo");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryResponse200Type> values = createValuesMap();
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryResponse200TypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetLibraryItemsLibraryResponse200Type(String value) {
|
private GetLibraryItemsLibraryResponse200Type(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetLibraryItemsLibraryResponse200Type with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetLibraryItemsLibraryResponse200Type
|
||||||
|
*/
|
||||||
|
public static GetLibraryItemsLibraryResponse200Type of(String value) {
|
||||||
|
synchronized (GetLibraryItemsLibraryResponse200Type.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetLibraryItemsLibraryResponse200Type(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetLibraryItemsLibraryResponse200Type> fromValue(String value) {
|
public Optional<GetLibraryItemsLibraryResponse200TypeEnum> asEnum() {
|
||||||
for (GetLibraryItemsLibraryResponse200Type o: GetLibraryItemsLibraryResponse200Type.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetLibraryItemsLibraryResponse200Type other = (GetLibraryItemsLibraryResponse200Type) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetLibraryItemsLibraryResponse200Type [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetLibraryItemsLibraryResponse200Type[] values() {
|
||||||
|
synchronized (GetLibraryItemsLibraryResponse200Type.class) {
|
||||||
|
return values.values().toArray(new GetLibraryItemsLibraryResponse200Type[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryResponse200Type> createValuesMap() {
|
||||||
|
Map<String, GetLibraryItemsLibraryResponse200Type> map = new LinkedHashMap<>();
|
||||||
|
map.put("coverPoster", COVER_POSTER);
|
||||||
|
map.put("background", BACKGROUND);
|
||||||
|
map.put("snapshot", SNAPSHOT);
|
||||||
|
map.put("clearLogo", CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryResponse200TypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetLibraryItemsLibraryResponse200TypeEnum> map = new HashMap<>();
|
||||||
|
map.put("coverPoster", GetLibraryItemsLibraryResponse200TypeEnum.COVER_POSTER);
|
||||||
|
map.put("background", GetLibraryItemsLibraryResponse200TypeEnum.BACKGROUND);
|
||||||
|
map.put("snapshot", GetLibraryItemsLibraryResponse200TypeEnum.SNAPSHOT);
|
||||||
|
map.put("clearLogo", GetLibraryItemsLibraryResponse200TypeEnum.CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetLibraryItemsLibraryResponse200Type> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetLibraryItemsLibraryResponse200Type.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetLibraryItemsLibraryResponse200Type value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetLibraryItemsLibraryResponse200Type> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetLibraryItemsLibraryResponse200Type.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetLibraryItemsLibraryResponse200Type deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetLibraryItemsLibraryResponse200Type.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetLibraryItemsLibraryResponse200TypeEnum {
|
||||||
|
|
||||||
|
COVER_POSTER("coverPoster"),
|
||||||
|
BACKGROUND("background"),
|
||||||
|
SNAPSHOT("snapshot"),
|
||||||
|
CLEAR_LOGO("clearLogo"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetLibraryItemsLibraryResponse200TypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,42 +3,198 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetLibraryItemsLibraryType
|
* GetLibraryItemsLibraryType
|
||||||
*
|
*
|
||||||
* <p>The type of media content
|
* <p>The type of media content
|
||||||
*/
|
*/
|
||||||
public enum GetLibraryItemsLibraryType {
|
@JsonDeserialize(using = GetLibraryItemsLibraryType._Deserializer.class)
|
||||||
Movie("movie"),
|
@JsonSerialize(using = GetLibraryItemsLibraryType._Serializer.class)
|
||||||
TvShow("show"),
|
public class GetLibraryItemsLibraryType {
|
||||||
Season("season"),
|
|
||||||
Episode("episode"),
|
public static final GetLibraryItemsLibraryType Movie = new GetLibraryItemsLibraryType("movie");
|
||||||
Artist("artist"),
|
public static final GetLibraryItemsLibraryType TvShow = new GetLibraryItemsLibraryType("show");
|
||||||
Album("album");
|
public static final GetLibraryItemsLibraryType Season = new GetLibraryItemsLibraryType("season");
|
||||||
|
public static final GetLibraryItemsLibraryType Episode = new GetLibraryItemsLibraryType("episode");
|
||||||
|
public static final GetLibraryItemsLibraryType Artist = new GetLibraryItemsLibraryType("artist");
|
||||||
|
public static final GetLibraryItemsLibraryType Album = new GetLibraryItemsLibraryType("album");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetLibraryItemsLibraryType(String value) {
|
private GetLibraryItemsLibraryType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetLibraryItemsLibraryType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetLibraryItemsLibraryType
|
||||||
|
*/
|
||||||
|
public static GetLibraryItemsLibraryType of(String value) {
|
||||||
|
synchronized (GetLibraryItemsLibraryType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetLibraryItemsLibraryType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetLibraryItemsLibraryType> fromValue(String value) {
|
public Optional<GetLibraryItemsLibraryTypeEnum> asEnum() {
|
||||||
for (GetLibraryItemsLibraryType o: GetLibraryItemsLibraryType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetLibraryItemsLibraryType other = (GetLibraryItemsLibraryType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetLibraryItemsLibraryType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetLibraryItemsLibraryType[] values() {
|
||||||
|
synchronized (GetLibraryItemsLibraryType.class) {
|
||||||
|
return values.values().toArray(new GetLibraryItemsLibraryType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryType> createValuesMap() {
|
||||||
|
Map<String, GetLibraryItemsLibraryType> map = new LinkedHashMap<>();
|
||||||
|
map.put("movie", Movie);
|
||||||
|
map.put("show", TvShow);
|
||||||
|
map.put("season", Season);
|
||||||
|
map.put("episode", Episode);
|
||||||
|
map.put("artist", Artist);
|
||||||
|
map.put("album", Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetLibraryItemsLibraryTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetLibraryItemsLibraryTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("movie", GetLibraryItemsLibraryTypeEnum.Movie);
|
||||||
|
map.put("show", GetLibraryItemsLibraryTypeEnum.TvShow);
|
||||||
|
map.put("season", GetLibraryItemsLibraryTypeEnum.Season);
|
||||||
|
map.put("episode", GetLibraryItemsLibraryTypeEnum.Episode);
|
||||||
|
map.put("artist", GetLibraryItemsLibraryTypeEnum.Artist);
|
||||||
|
map.put("album", GetLibraryItemsLibraryTypeEnum.Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetLibraryItemsLibraryType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetLibraryItemsLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetLibraryItemsLibraryType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetLibraryItemsLibraryType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetLibraryItemsLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetLibraryItemsLibraryType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetLibraryItemsLibraryType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetLibraryItemsLibraryTypeEnum {
|
||||||
|
|
||||||
|
Movie("movie"),
|
||||||
|
TvShow("show"),
|
||||||
|
Season("season"),
|
||||||
|
Episode("episode"),
|
||||||
|
Artist("artist"),
|
||||||
|
Album("album"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetLibraryItemsLibraryTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetLibraryItemsQueryParamType
|
* GetLibraryItemsQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetLibraryItemsQueryParamType {
|
@JsonDeserialize(using = GetLibraryItemsQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetLibraryItemsQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetLibraryItemsQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetLibraryItemsQueryParamType Movie = new GetLibraryItemsQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetLibraryItemsQueryParamType TvShow = new GetLibraryItemsQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetLibraryItemsQueryParamType Season = new GetLibraryItemsQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetLibraryItemsQueryParamType Episode = new GetLibraryItemsQueryParamType(4L);
|
||||||
|
public static final GetLibraryItemsQueryParamType Audio = new GetLibraryItemsQueryParamType(8L);
|
||||||
|
public static final GetLibraryItemsQueryParamType Album = new GetLibraryItemsQueryParamType(9L);
|
||||||
|
public static final GetLibraryItemsQueryParamType Track = new GetLibraryItemsQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetLibraryItemsQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetLibraryItemsQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetLibraryItemsQueryParamType(long value) {
|
private GetLibraryItemsQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetLibraryItemsQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetLibraryItemsQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetLibraryItemsQueryParamType of(long value) {
|
||||||
|
synchronized (GetLibraryItemsQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetLibraryItemsQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetLibraryItemsQueryParamType> fromValue(long value) {
|
public Optional<GetLibraryItemsQueryParamTypeEnum> asEnum() {
|
||||||
for (GetLibraryItemsQueryParamType o: GetLibraryItemsQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetLibraryItemsQueryParamType other = (GetLibraryItemsQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetLibraryItemsQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetLibraryItemsQueryParamType[] values() {
|
||||||
|
synchronized (GetLibraryItemsQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetLibraryItemsQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetLibraryItemsQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetLibraryItemsQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetLibraryItemsQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetLibraryItemsQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetLibraryItemsQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetLibraryItemsQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetLibraryItemsQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetLibraryItemsQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetLibraryItemsQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetLibraryItemsQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetLibraryItemsQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetLibraryItemsQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetLibraryItemsQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetLibraryItemsQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetLibraryItemsQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetLibraryItemsQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetLibraryItemsQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetLibraryItemsQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetLibraryItemsQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetLibraryItemsQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -5,77 +5,77 @@ package dev.plexapi.sdk.models.operations;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Integer;
|
import java.lang.Integer;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GetMediaMetaDataCountry
|
||||||
|
*
|
||||||
|
* <p>The filter query string for country media items.
|
||||||
|
*/
|
||||||
public class GetMediaMetaDataCountry {
|
public class GetMediaMetaDataCountry {
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique country identifier.
|
|
||||||
*/
|
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private int id;
|
private int id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the country.
|
* The country of origin of this media item
|
||||||
*/
|
|
||||||
@JsonProperty("filter")
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The country name.
|
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tag")
|
@JsonProperty("tag")
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("filter")
|
||||||
|
private Optional<String> filter;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataCountry(
|
public GetMediaMetaDataCountry(
|
||||||
@JsonProperty("id") int id,
|
@JsonProperty("id") int id,
|
||||||
@JsonProperty("filter") String filter,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("tag") String tag) {
|
@JsonProperty("filter") Optional<String> filter) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.filter = filter;
|
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
|
this.filter = filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetMediaMetaDataCountry(
|
||||||
|
int id,
|
||||||
|
String tag) {
|
||||||
|
this(id, tag, Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique country identifier.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int id() {
|
public int id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the country.
|
* The country of origin of this media item
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String filter() {
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The country name.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tag() {
|
public String tag() {
|
||||||
return tag;
|
return tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> filter() {
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
public final static Builder builder() {
|
public final static Builder builder() {
|
||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique country identifier.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataCountry withId(int id) {
|
public GetMediaMetaDataCountry withId(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
@@ -83,16 +83,7 @@ public class GetMediaMetaDataCountry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the country.
|
* The country of origin of this media item
|
||||||
*/
|
|
||||||
public GetMediaMetaDataCountry withFilter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The country name.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataCountry withTag(String tag) {
|
public GetMediaMetaDataCountry withTag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -100,6 +91,18 @@ public class GetMediaMetaDataCountry {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GetMediaMetaDataCountry withFilter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = Optional.ofNullable(filter);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GetMediaMetaDataCountry withFilter(Optional<String> filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(java.lang.Object o) {
|
public boolean equals(java.lang.Object o) {
|
||||||
@@ -112,41 +115,38 @@ public class GetMediaMetaDataCountry {
|
|||||||
GetMediaMetaDataCountry other = (GetMediaMetaDataCountry) o;
|
GetMediaMetaDataCountry other = (GetMediaMetaDataCountry) o;
|
||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.filter, other.filter) &&
|
Objects.deepEquals(this.tag, other.tag) &&
|
||||||
Objects.deepEquals(this.tag, other.tag);
|
Objects.deepEquals(this.filter, other.filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
filter,
|
tag,
|
||||||
tag);
|
filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return Utils.toString(GetMediaMetaDataCountry.class,
|
return Utils.toString(GetMediaMetaDataCountry.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"filter", filter,
|
"tag", tag,
|
||||||
"tag", tag);
|
"filter", filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private Integer id;
|
private Integer id;
|
||||||
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
|
private Optional<String> filter = Optional.empty();
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique country identifier.
|
|
||||||
*/
|
|
||||||
public Builder id(int id) {
|
public Builder id(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
@@ -154,28 +154,31 @@ public class GetMediaMetaDataCountry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the country.
|
* The country of origin of this media item
|
||||||
*/
|
|
||||||
public Builder filter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The country name.
|
|
||||||
*/
|
*/
|
||||||
public Builder tag(String tag) {
|
public Builder tag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Builder filter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = Optional.ofNullable(filter);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder filter(Optional<String> filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataCountry build() {
|
public GetMediaMetaDataCountry build() {
|
||||||
return new GetMediaMetaDataCountry(
|
return new GetMediaMetaDataCountry(
|
||||||
id,
|
id,
|
||||||
filter,
|
tag,
|
||||||
tag);
|
filter);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
|||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Long;
|
import java.lang.Integer;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
@@ -18,38 +18,32 @@ import java.util.Optional;
|
|||||||
public class GetMediaMetaDataDirector {
|
public class GetMediaMetaDataDirector {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the director.
|
||||||
*/
|
*/
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private long id;
|
private int id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Director
|
||||||
*/
|
|
||||||
@JsonProperty("filter")
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tag")
|
@JsonProperty("tag")
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this director.
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tagKey")
|
@JsonProperty("filter")
|
||||||
private String tagKey;
|
private String filter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
*/
|
*/
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("role")
|
@JsonProperty("tagKey")
|
||||||
private Optional<String> role;
|
private Optional<String> tagKey;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
*/
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("thumb")
|
@JsonProperty("thumb")
|
||||||
@@ -57,52 +51,40 @@ public class GetMediaMetaDataDirector {
|
|||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataDirector(
|
public GetMediaMetaDataDirector(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") int id,
|
||||||
@JsonProperty("filter") String filter,
|
|
||||||
@JsonProperty("tag") String tag,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("tagKey") String tagKey,
|
@JsonProperty("filter") String filter,
|
||||||
@JsonProperty("role") Optional<String> role,
|
@JsonProperty("tagKey") Optional<String> tagKey,
|
||||||
@JsonProperty("thumb") Optional<String> thumb) {
|
@JsonProperty("thumb") Optional<String> thumb) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.filter = filter;
|
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
|
this.filter = filter;
|
||||||
this.tagKey = tagKey;
|
this.tagKey = tagKey;
|
||||||
this.role = role;
|
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataDirector(
|
public GetMediaMetaDataDirector(
|
||||||
long id,
|
int id,
|
||||||
String filter,
|
|
||||||
String tag,
|
String tag,
|
||||||
String tagKey) {
|
String filter) {
|
||||||
this(id, filter, tag, tagKey, Optional.empty(), Optional.empty());
|
this(id, tag, filter, Optional.empty(), Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the director.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long id() {
|
public int id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Director
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String filter() {
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tag() {
|
public String tag() {
|
||||||
@@ -110,23 +92,23 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this director.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tagKey() {
|
public String filter() {
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> tagKey() {
|
||||||
return tagKey;
|
return tagKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public Optional<String> role() {
|
|
||||||
return role;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public Optional<String> thumb() {
|
public Optional<String> thumb() {
|
||||||
@@ -138,25 +120,16 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the director.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataDirector withId(long id) {
|
public GetMediaMetaDataDirector withId(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Director
|
||||||
*/
|
|
||||||
public GetMediaMetaDataDirector withFilter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataDirector withTag(String tag) {
|
public GetMediaMetaDataDirector withTag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -165,34 +138,34 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this director.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataDirector withFilter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataDirector withTagKey(String tagKey) {
|
public GetMediaMetaDataDirector withTagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataDirector withTagKey(Optional<String> tagKey) {
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
this.tagKey = tagKey;
|
this.tagKey = tagKey;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
|
||||||
public GetMediaMetaDataDirector withRole(String role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = Optional.ofNullable(role);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataDirector withRole(Optional<String> role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = role;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataDirector withThumb(String thumb) {
|
public GetMediaMetaDataDirector withThumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -201,7 +174,7 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataDirector withThumb(Optional<String> thumb) {
|
public GetMediaMetaDataDirector withThumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -221,10 +194,9 @@ public class GetMediaMetaDataDirector {
|
|||||||
GetMediaMetaDataDirector other = (GetMediaMetaDataDirector) o;
|
GetMediaMetaDataDirector other = (GetMediaMetaDataDirector) o;
|
||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.filter, other.filter) &&
|
|
||||||
Objects.deepEquals(this.tag, other.tag) &&
|
Objects.deepEquals(this.tag, other.tag) &&
|
||||||
|
Objects.deepEquals(this.filter, other.filter) &&
|
||||||
Objects.deepEquals(this.tagKey, other.tagKey) &&
|
Objects.deepEquals(this.tagKey, other.tagKey) &&
|
||||||
Objects.deepEquals(this.role, other.role) &&
|
|
||||||
Objects.deepEquals(this.thumb, other.thumb);
|
Objects.deepEquals(this.thumb, other.thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -232,10 +204,9 @@ public class GetMediaMetaDataDirector {
|
|||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
|
filter,
|
||||||
tagKey,
|
tagKey,
|
||||||
role,
|
|
||||||
thumb);
|
thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -243,24 +214,21 @@ public class GetMediaMetaDataDirector {
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
return Utils.toString(GetMediaMetaDataDirector.class,
|
return Utils.toString(GetMediaMetaDataDirector.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"filter", filter,
|
|
||||||
"tag", tag,
|
"tag", tag,
|
||||||
|
"filter", filter,
|
||||||
"tagKey", tagKey,
|
"tagKey", tagKey,
|
||||||
"role", role,
|
|
||||||
"thumb", thumb);
|
"thumb", thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private Long id;
|
private Integer id;
|
||||||
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
private String tagKey;
|
private String filter;
|
||||||
|
|
||||||
private Optional<String> role = Optional.empty();
|
private Optional<String> tagKey = Optional.empty();
|
||||||
|
|
||||||
private Optional<String> thumb = Optional.empty();
|
private Optional<String> thumb = Optional.empty();
|
||||||
|
|
||||||
@@ -269,25 +237,16 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the director.
|
||||||
*/
|
*/
|
||||||
public Builder id(long id) {
|
public Builder id(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Director
|
||||||
*/
|
|
||||||
public Builder filter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public Builder tag(String tag) {
|
public Builder tag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -296,34 +255,34 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this director.
|
||||||
|
*/
|
||||||
|
public Builder filter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
*/
|
*/
|
||||||
public Builder tagKey(String tagKey) {
|
public Builder tagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the director's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public Builder tagKey(Optional<String> tagKey) {
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
this.tagKey = tagKey;
|
this.tagKey = tagKey;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
|
||||||
public Builder role(String role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = Optional.ofNullable(role);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
|
||||||
public Builder role(Optional<String> role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = role;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
public Builder thumb(String thumb) {
|
public Builder thumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -332,7 +291,7 @@ public class GetMediaMetaDataDirector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the director.
|
||||||
*/
|
*/
|
||||||
public Builder thumb(Optional<String> thumb) {
|
public Builder thumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -343,10 +302,9 @@ public class GetMediaMetaDataDirector {
|
|||||||
public GetMediaMetaDataDirector build() {
|
public GetMediaMetaDataDirector build() {
|
||||||
return new GetMediaMetaDataDirector(
|
return new GetMediaMetaDataDirector(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
|
filter,
|
||||||
tagKey,
|
tagKey,
|
||||||
role,
|
|
||||||
thumb);
|
thumb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,70 +12,60 @@ import java.lang.Override;
|
|||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GetMediaMetaDataGenre
|
||||||
|
*
|
||||||
|
* <p>The filter query string for similar items.
|
||||||
|
*/
|
||||||
public class GetMediaMetaDataGenre {
|
public class GetMediaMetaDataGenre {
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique genre identifier.
|
|
||||||
*/
|
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private long id;
|
private long id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the genre.
|
* The genre name of this media-item
|
||||||
*/
|
|
||||||
@JsonProperty("filter")
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The genre name.
|
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tag")
|
@JsonProperty("tag")
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
|
@JsonProperty("filter")
|
||||||
|
private String filter;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataGenre(
|
public GetMediaMetaDataGenre(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") long id,
|
||||||
@JsonProperty("filter") String filter,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("tag") String tag) {
|
@JsonProperty("filter") String filter) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.filter = filter;
|
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
|
this.filter = filter;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique genre identifier.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long id() {
|
public long id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the genre.
|
* The genre name of this media-item
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String filter() {
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The genre name.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tag() {
|
public String tag() {
|
||||||
return tag;
|
return tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@JsonIgnore
|
||||||
|
public String filter() {
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
public final static Builder builder() {
|
public final static Builder builder() {
|
||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique genre identifier.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataGenre withId(long id) {
|
public GetMediaMetaDataGenre withId(long id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
@@ -83,16 +73,7 @@ public class GetMediaMetaDataGenre {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the genre.
|
* The genre name of this media-item
|
||||||
*/
|
|
||||||
public GetMediaMetaDataGenre withFilter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The genre name.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataGenre withTag(String tag) {
|
public GetMediaMetaDataGenre withTag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -100,6 +81,12 @@ public class GetMediaMetaDataGenre {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GetMediaMetaDataGenre withFilter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(java.lang.Object o) {
|
public boolean equals(java.lang.Object o) {
|
||||||
@@ -112,41 +99,38 @@ public class GetMediaMetaDataGenre {
|
|||||||
GetMediaMetaDataGenre other = (GetMediaMetaDataGenre) o;
|
GetMediaMetaDataGenre other = (GetMediaMetaDataGenre) o;
|
||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.filter, other.filter) &&
|
Objects.deepEquals(this.tag, other.tag) &&
|
||||||
Objects.deepEquals(this.tag, other.tag);
|
Objects.deepEquals(this.filter, other.filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
filter,
|
tag,
|
||||||
tag);
|
filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return Utils.toString(GetMediaMetaDataGenre.class,
|
return Utils.toString(GetMediaMetaDataGenre.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"filter", filter,
|
"tag", tag,
|
||||||
"tag", tag);
|
"filter", filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
|
private String filter;
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The unique genre identifier.
|
|
||||||
*/
|
|
||||||
public Builder id(long id) {
|
public Builder id(long id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
@@ -154,28 +138,25 @@ public class GetMediaMetaDataGenre {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the genre.
|
* The genre name of this media-item
|
||||||
*/
|
|
||||||
public Builder filter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The genre name.
|
|
||||||
*/
|
*/
|
||||||
public Builder tag(String tag) {
|
public Builder tag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Builder filter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataGenre build() {
|
public GetMediaMetaDataGenre build() {
|
||||||
return new GetMediaMetaDataGenre(
|
return new GetMediaMetaDataGenre(
|
||||||
id,
|
id,
|
||||||
filter,
|
tag,
|
||||||
tag);
|
filter);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,28 +13,19 @@ import java.util.Objects;
|
|||||||
|
|
||||||
public class GetMediaMetaDataImage {
|
public class GetMediaMetaDataImage {
|
||||||
|
|
||||||
/**
|
|
||||||
* Alternate text for the image.
|
|
||||||
*/
|
|
||||||
@JsonProperty("alt")
|
@JsonProperty("alt")
|
||||||
private String alt;
|
private String alt;
|
||||||
|
|
||||||
/**
|
|
||||||
* The type of image (e.g., coverPoster, background, clearLogo).
|
|
||||||
*/
|
|
||||||
@JsonProperty("type")
|
@JsonProperty("type")
|
||||||
private String type;
|
private GetMediaMetaDataLibraryType type;
|
||||||
|
|
||||||
/**
|
|
||||||
* The URL of the image.
|
|
||||||
*/
|
|
||||||
@JsonProperty("url")
|
@JsonProperty("url")
|
||||||
private String url;
|
private String url;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataImage(
|
public GetMediaMetaDataImage(
|
||||||
@JsonProperty("alt") String alt,
|
@JsonProperty("alt") String alt,
|
||||||
@JsonProperty("type") String type,
|
@JsonProperty("type") GetMediaMetaDataLibraryType type,
|
||||||
@JsonProperty("url") String url) {
|
@JsonProperty("url") String url) {
|
||||||
Utils.checkNotNull(alt, "alt");
|
Utils.checkNotNull(alt, "alt");
|
||||||
Utils.checkNotNull(type, "type");
|
Utils.checkNotNull(type, "type");
|
||||||
@@ -44,25 +35,16 @@ public class GetMediaMetaDataImage {
|
|||||||
this.url = url;
|
this.url = url;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Alternate text for the image.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String alt() {
|
public String alt() {
|
||||||
return alt;
|
return alt;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The type of image (e.g., coverPoster, background, clearLogo).
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String type() {
|
public GetMediaMetaDataLibraryType type() {
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The URL of the image.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String url() {
|
public String url() {
|
||||||
return url;
|
return url;
|
||||||
@@ -72,27 +54,18 @@ public class GetMediaMetaDataImage {
|
|||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Alternate text for the image.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataImage withAlt(String alt) {
|
public GetMediaMetaDataImage withAlt(String alt) {
|
||||||
Utils.checkNotNull(alt, "alt");
|
Utils.checkNotNull(alt, "alt");
|
||||||
this.alt = alt;
|
this.alt = alt;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public GetMediaMetaDataImage withType(GetMediaMetaDataLibraryType type) {
|
||||||
* The type of image (e.g., coverPoster, background, clearLogo).
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataImage withType(String type) {
|
|
||||||
Utils.checkNotNull(type, "type");
|
Utils.checkNotNull(type, "type");
|
||||||
this.type = type;
|
this.type = type;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The URL of the image.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataImage withUrl(String url) {
|
public GetMediaMetaDataImage withUrl(String url) {
|
||||||
Utils.checkNotNull(url, "url");
|
Utils.checkNotNull(url, "url");
|
||||||
this.url = url;
|
this.url = url;
|
||||||
@@ -135,7 +108,7 @@ public class GetMediaMetaDataImage {
|
|||||||
|
|
||||||
private String alt;
|
private String alt;
|
||||||
|
|
||||||
private String type;
|
private GetMediaMetaDataLibraryType type;
|
||||||
|
|
||||||
private String url;
|
private String url;
|
||||||
|
|
||||||
@@ -143,27 +116,18 @@ public class GetMediaMetaDataImage {
|
|||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Alternate text for the image.
|
|
||||||
*/
|
|
||||||
public Builder alt(String alt) {
|
public Builder alt(String alt) {
|
||||||
Utils.checkNotNull(alt, "alt");
|
Utils.checkNotNull(alt, "alt");
|
||||||
this.alt = alt;
|
this.alt = alt;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public Builder type(GetMediaMetaDataLibraryType type) {
|
||||||
* The type of image (e.g., coverPoster, background, clearLogo).
|
|
||||||
*/
|
|
||||||
public Builder type(String type) {
|
|
||||||
Utils.checkNotNull(type, "type");
|
Utils.checkNotNull(type, "type");
|
||||||
this.type = type;
|
this.type = type;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The URL of the image.
|
|
||||||
*/
|
|
||||||
public Builder url(String url) {
|
public Builder url(String url) {
|
||||||
Utils.checkNotNull(url, "url");
|
Utils.checkNotNull(url, "url");
|
||||||
this.url = url;
|
this.url = url;
|
||||||
|
|||||||
@@ -0,0 +1,187 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetMediaMetaDataLibraryType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetMediaMetaDataLibraryType._Serializer.class)
|
||||||
|
public class GetMediaMetaDataLibraryType {
|
||||||
|
|
||||||
|
public static final GetMediaMetaDataLibraryType COVER_POSTER = new GetMediaMetaDataLibraryType("coverPoster");
|
||||||
|
public static final GetMediaMetaDataLibraryType BACKGROUND = new GetMediaMetaDataLibraryType("background");
|
||||||
|
public static final GetMediaMetaDataLibraryType SNAPSHOT = new GetMediaMetaDataLibraryType("snapshot");
|
||||||
|
public static final GetMediaMetaDataLibraryType CLEAR_LOGO = new GetMediaMetaDataLibraryType("clearLogo");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetMediaMetaDataLibraryType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetMediaMetaDataLibraryTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataLibraryType(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetMediaMetaDataLibraryType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetMediaMetaDataLibraryType
|
||||||
|
*/
|
||||||
|
public static GetMediaMetaDataLibraryType of(String value) {
|
||||||
|
synchronized (GetMediaMetaDataLibraryType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetMediaMetaDataLibraryType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<GetMediaMetaDataLibraryTypeEnum> asEnum() {
|
||||||
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetMediaMetaDataLibraryType other = (GetMediaMetaDataLibraryType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetMediaMetaDataLibraryType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetMediaMetaDataLibraryType[] values() {
|
||||||
|
synchronized (GetMediaMetaDataLibraryType.class) {
|
||||||
|
return values.values().toArray(new GetMediaMetaDataLibraryType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetMediaMetaDataLibraryType> createValuesMap() {
|
||||||
|
Map<String, GetMediaMetaDataLibraryType> map = new LinkedHashMap<>();
|
||||||
|
map.put("coverPoster", COVER_POSTER);
|
||||||
|
map.put("background", BACKGROUND);
|
||||||
|
map.put("snapshot", SNAPSHOT);
|
||||||
|
map.put("clearLogo", CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetMediaMetaDataLibraryTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetMediaMetaDataLibraryTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("coverPoster", GetMediaMetaDataLibraryTypeEnum.COVER_POSTER);
|
||||||
|
map.put("background", GetMediaMetaDataLibraryTypeEnum.BACKGROUND);
|
||||||
|
map.put("snapshot", GetMediaMetaDataLibraryTypeEnum.SNAPSHOT);
|
||||||
|
map.put("clearLogo", GetMediaMetaDataLibraryTypeEnum.CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetMediaMetaDataLibraryType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetMediaMetaDataLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetMediaMetaDataLibraryType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetMediaMetaDataLibraryType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetMediaMetaDataLibraryType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetMediaMetaDataLibraryType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetMediaMetaDataLibraryType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetMediaMetaDataLibraryTypeEnum {
|
||||||
|
|
||||||
|
COVER_POSTER("coverPoster"),
|
||||||
|
BACKGROUND("background"),
|
||||||
|
SNAPSHOT("snapshot"),
|
||||||
|
CLEAR_LOGO("clearLogo"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataLibraryTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -18,38 +18,39 @@ import java.util.Optional;
|
|||||||
public class GetMediaMetaDataRole {
|
public class GetMediaMetaDataRole {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the actor or role.
|
||||||
*/
|
*/
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private long id;
|
private long id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The display tag for the actor (typically the actor's name).
|
||||||
*/
|
|
||||||
@JsonProperty("filter")
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tag")
|
@JsonProperty("tag")
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The role played by the actor in the media item.
|
||||||
*/
|
|
||||||
@JsonProperty("tagKey")
|
|
||||||
private String tagKey;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
*/
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("role")
|
@JsonProperty("role")
|
||||||
private Optional<String> role;
|
private Optional<String> role;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The filter string used to query this actor. For example, it may indicate that this is an actor with a given key.
|
||||||
|
*/
|
||||||
|
@JsonProperty("filter")
|
||||||
|
private String filter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("tagKey")
|
||||||
|
private Optional<String> tagKey;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("thumb")
|
@JsonProperty("thumb")
|
||||||
@@ -58,35 +59,34 @@ public class GetMediaMetaDataRole {
|
|||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataRole(
|
public GetMediaMetaDataRole(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") long id,
|
||||||
@JsonProperty("filter") String filter,
|
|
||||||
@JsonProperty("tag") String tag,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("tagKey") String tagKey,
|
|
||||||
@JsonProperty("role") Optional<String> role,
|
@JsonProperty("role") Optional<String> role,
|
||||||
|
@JsonProperty("filter") String filter,
|
||||||
|
@JsonProperty("tagKey") Optional<String> tagKey,
|
||||||
@JsonProperty("thumb") Optional<String> thumb) {
|
@JsonProperty("thumb") Optional<String> thumb) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
|
||||||
Utils.checkNotNull(role, "role");
|
Utils.checkNotNull(role, "role");
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.filter = filter;
|
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
this.tagKey = tagKey;
|
|
||||||
this.role = role;
|
this.role = role;
|
||||||
|
this.filter = filter;
|
||||||
|
this.tagKey = tagKey;
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataRole(
|
public GetMediaMetaDataRole(
|
||||||
long id,
|
long id,
|
||||||
String filter,
|
|
||||||
String tag,
|
String tag,
|
||||||
String tagKey) {
|
String filter) {
|
||||||
this(id, filter, tag, tagKey, Optional.empty(), Optional.empty());
|
this(id, tag, Optional.empty(), filter, Optional.empty(), Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the actor or role.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long id() {
|
public long id() {
|
||||||
@@ -94,15 +94,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The display tag for the actor (typically the actor's name).
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String filter() {
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tag() {
|
public String tag() {
|
||||||
@@ -110,15 +102,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The role played by the actor in the media item.
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String tagKey() {
|
|
||||||
return tagKey;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public Optional<String> role() {
|
public Optional<String> role() {
|
||||||
@@ -126,7 +110,23 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The filter string used to query this actor. For example, it may indicate that this is an actor with a given key.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public String filter() {
|
||||||
|
return filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> tagKey() {
|
||||||
|
return tagKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public Optional<String> thumb() {
|
public Optional<String> thumb() {
|
||||||
@@ -138,7 +138,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the actor or role.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withId(long id) {
|
public GetMediaMetaDataRole withId(long id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
@@ -147,16 +147,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The display tag for the actor (typically the actor's name).
|
||||||
*/
|
|
||||||
public GetMediaMetaDataRole withFilter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withTag(String tag) {
|
public GetMediaMetaDataRole withTag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -165,16 +156,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The role played by the actor in the media item.
|
||||||
*/
|
|
||||||
public GetMediaMetaDataRole withTagKey(String tagKey) {
|
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
|
||||||
this.tagKey = tagKey;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withRole(String role) {
|
public GetMediaMetaDataRole withRole(String role) {
|
||||||
Utils.checkNotNull(role, "role");
|
Utils.checkNotNull(role, "role");
|
||||||
@@ -183,7 +165,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The role played by the actor in the media item.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withRole(Optional<String> role) {
|
public GetMediaMetaDataRole withRole(Optional<String> role) {
|
||||||
Utils.checkNotNull(role, "role");
|
Utils.checkNotNull(role, "role");
|
||||||
@@ -192,7 +174,34 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The filter string used to query this actor. For example, it may indicate that this is an actor with a given key.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataRole withFilter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataRole withTagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataRole withTagKey(Optional<String> tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = tagKey;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withThumb(String thumb) {
|
public GetMediaMetaDataRole withThumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -201,7 +210,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataRole withThumb(Optional<String> thumb) {
|
public GetMediaMetaDataRole withThumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -221,10 +230,10 @@ public class GetMediaMetaDataRole {
|
|||||||
GetMediaMetaDataRole other = (GetMediaMetaDataRole) o;
|
GetMediaMetaDataRole other = (GetMediaMetaDataRole) o;
|
||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.filter, other.filter) &&
|
|
||||||
Objects.deepEquals(this.tag, other.tag) &&
|
Objects.deepEquals(this.tag, other.tag) &&
|
||||||
Objects.deepEquals(this.tagKey, other.tagKey) &&
|
|
||||||
Objects.deepEquals(this.role, other.role) &&
|
Objects.deepEquals(this.role, other.role) &&
|
||||||
|
Objects.deepEquals(this.filter, other.filter) &&
|
||||||
|
Objects.deepEquals(this.tagKey, other.tagKey) &&
|
||||||
Objects.deepEquals(this.thumb, other.thumb);
|
Objects.deepEquals(this.thumb, other.thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -232,10 +241,10 @@ public class GetMediaMetaDataRole {
|
|||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
tagKey,
|
|
||||||
role,
|
role,
|
||||||
|
filter,
|
||||||
|
tagKey,
|
||||||
thumb);
|
thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -243,10 +252,10 @@ public class GetMediaMetaDataRole {
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
return Utils.toString(GetMediaMetaDataRole.class,
|
return Utils.toString(GetMediaMetaDataRole.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"filter", filter,
|
|
||||||
"tag", tag,
|
"tag", tag,
|
||||||
"tagKey", tagKey,
|
|
||||||
"role", role,
|
"role", role,
|
||||||
|
"filter", filter,
|
||||||
|
"tagKey", tagKey,
|
||||||
"thumb", thumb);
|
"thumb", thumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -254,14 +263,14 @@ public class GetMediaMetaDataRole {
|
|||||||
|
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
private String tagKey;
|
|
||||||
|
|
||||||
private Optional<String> role = Optional.empty();
|
private Optional<String> role = Optional.empty();
|
||||||
|
|
||||||
|
private String filter;
|
||||||
|
|
||||||
|
private Optional<String> tagKey = Optional.empty();
|
||||||
|
|
||||||
private Optional<String> thumb = Optional.empty();
|
private Optional<String> thumb = Optional.empty();
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
@@ -269,7 +278,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the actor or role.
|
||||||
*/
|
*/
|
||||||
public Builder id(long id) {
|
public Builder id(long id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
@@ -278,16 +287,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The display tag for the actor (typically the actor's name).
|
||||||
*/
|
|
||||||
public Builder filter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public Builder tag(String tag) {
|
public Builder tag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -296,16 +296,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The role played by the actor in the media item.
|
||||||
*/
|
|
||||||
public Builder tagKey(String tagKey) {
|
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
|
||||||
this.tagKey = tagKey;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
*/
|
||||||
public Builder role(String role) {
|
public Builder role(String role) {
|
||||||
Utils.checkNotNull(role, "role");
|
Utils.checkNotNull(role, "role");
|
||||||
@@ -314,7 +305,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The role played by the actor in the media item.
|
||||||
*/
|
*/
|
||||||
public Builder role(Optional<String> role) {
|
public Builder role(Optional<String> role) {
|
||||||
Utils.checkNotNull(role, "role");
|
Utils.checkNotNull(role, "role");
|
||||||
@@ -323,7 +314,34 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The filter string used to query this actor. For example, it may indicate that this is an actor with a given key.
|
||||||
|
*/
|
||||||
|
public Builder filter(String filter) {
|
||||||
|
Utils.checkNotNull(filter, "filter");
|
||||||
|
this.filter = filter;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public Builder tagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the actor's tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public Builder tagKey(Optional<String> tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = tagKey;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
public Builder thumb(String thumb) {
|
public Builder thumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -332,7 +350,7 @@ public class GetMediaMetaDataRole {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the actor.
|
||||||
*/
|
*/
|
||||||
public Builder thumb(Optional<String> thumb) {
|
public Builder thumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -343,10 +361,10 @@ public class GetMediaMetaDataRole {
|
|||||||
public GetMediaMetaDataRole build() {
|
public GetMediaMetaDataRole build() {
|
||||||
return new GetMediaMetaDataRole(
|
return new GetMediaMetaDataRole(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
tagKey,
|
|
||||||
role,
|
role,
|
||||||
|
filter,
|
||||||
|
tagKey,
|
||||||
thumb);
|
thumb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,10 +27,20 @@ public class GetMediaMetaDataStream {
|
|||||||
private long id;
|
private long id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
@JsonProperty("streamType")
|
@JsonProperty("streamType")
|
||||||
private int streamType;
|
private GetMediaMetaDataStreamType streamType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("format")
|
||||||
|
private Optional<String> format;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
@@ -48,8 +58,9 @@ public class GetMediaMetaDataStream {
|
|||||||
/**
|
/**
|
||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("index")
|
@JsonProperty("index")
|
||||||
private int index;
|
private Optional<Integer> index;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bitrate of the stream.
|
* Bitrate of the stream.
|
||||||
@@ -216,6 +227,13 @@ public class GetMediaMetaDataStream {
|
|||||||
@JsonProperty("frameRate")
|
@JsonProperty("frameRate")
|
||||||
private Optional<Float> frameRate;
|
private Optional<Float> frameRate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("key")
|
||||||
|
private Optional<String> key;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -345,10 +363,11 @@ public class GetMediaMetaDataStream {
|
|||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataStream(
|
public GetMediaMetaDataStream(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") long id,
|
||||||
@JsonProperty("streamType") int streamType,
|
@JsonProperty("streamType") GetMediaMetaDataStreamType streamType,
|
||||||
|
@JsonProperty("format") Optional<String> format,
|
||||||
@JsonProperty("default") Optional<Boolean> default_,
|
@JsonProperty("default") Optional<Boolean> default_,
|
||||||
@JsonProperty("codec") String codec,
|
@JsonProperty("codec") String codec,
|
||||||
@JsonProperty("index") int index,
|
@JsonProperty("index") Optional<Integer> index,
|
||||||
@JsonProperty("bitrate") Optional<Integer> bitrate,
|
@JsonProperty("bitrate") Optional<Integer> bitrate,
|
||||||
@JsonProperty("language") Optional<String> language,
|
@JsonProperty("language") Optional<String> language,
|
||||||
@JsonProperty("languageTag") Optional<String> languageTag,
|
@JsonProperty("languageTag") Optional<String> languageTag,
|
||||||
@@ -373,6 +392,7 @@ public class GetMediaMetaDataStream {
|
|||||||
@JsonProperty("colorSpace") Optional<String> colorSpace,
|
@JsonProperty("colorSpace") Optional<String> colorSpace,
|
||||||
@JsonProperty("colorTrc") Optional<String> colorTrc,
|
@JsonProperty("colorTrc") Optional<String> colorTrc,
|
||||||
@JsonProperty("frameRate") Optional<Float> frameRate,
|
@JsonProperty("frameRate") Optional<Float> frameRate,
|
||||||
|
@JsonProperty("key") Optional<String> key,
|
||||||
@JsonProperty("height") Optional<Integer> height,
|
@JsonProperty("height") Optional<Integer> height,
|
||||||
@JsonProperty("level") Optional<Integer> level,
|
@JsonProperty("level") Optional<Integer> level,
|
||||||
@JsonProperty("original") Optional<Boolean> original,
|
@JsonProperty("original") Optional<Boolean> original,
|
||||||
@@ -395,6 +415,7 @@ public class GetMediaMetaDataStream {
|
|||||||
@JsonProperty("title") Optional<String> title) {
|
@JsonProperty("title") Optional<String> title) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
Utils.checkNotNull(default_, "default_");
|
Utils.checkNotNull(default_, "default_");
|
||||||
Utils.checkNotNull(codec, "codec");
|
Utils.checkNotNull(codec, "codec");
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
@@ -422,6 +443,7 @@ public class GetMediaMetaDataStream {
|
|||||||
Utils.checkNotNull(colorSpace, "colorSpace");
|
Utils.checkNotNull(colorSpace, "colorSpace");
|
||||||
Utils.checkNotNull(colorTrc, "colorTrc");
|
Utils.checkNotNull(colorTrc, "colorTrc");
|
||||||
Utils.checkNotNull(frameRate, "frameRate");
|
Utils.checkNotNull(frameRate, "frameRate");
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
Utils.checkNotNull(height, "height");
|
Utils.checkNotNull(height, "height");
|
||||||
Utils.checkNotNull(level, "level");
|
Utils.checkNotNull(level, "level");
|
||||||
Utils.checkNotNull(original, "original");
|
Utils.checkNotNull(original, "original");
|
||||||
@@ -444,6 +466,7 @@ public class GetMediaMetaDataStream {
|
|||||||
Utils.checkNotNull(title, "title");
|
Utils.checkNotNull(title, "title");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
|
this.format = format;
|
||||||
this.default_ = default_;
|
this.default_ = default_;
|
||||||
this.codec = codec;
|
this.codec = codec;
|
||||||
this.index = index;
|
this.index = index;
|
||||||
@@ -471,6 +494,7 @@ public class GetMediaMetaDataStream {
|
|||||||
this.colorSpace = colorSpace;
|
this.colorSpace = colorSpace;
|
||||||
this.colorTrc = colorTrc;
|
this.colorTrc = colorTrc;
|
||||||
this.frameRate = frameRate;
|
this.frameRate = frameRate;
|
||||||
|
this.key = key;
|
||||||
this.height = height;
|
this.height = height;
|
||||||
this.level = level;
|
this.level = level;
|
||||||
this.original = original;
|
this.original = original;
|
||||||
@@ -495,12 +519,11 @@ public class GetMediaMetaDataStream {
|
|||||||
|
|
||||||
public GetMediaMetaDataStream(
|
public GetMediaMetaDataStream(
|
||||||
long id,
|
long id,
|
||||||
int streamType,
|
GetMediaMetaDataStreamType streamType,
|
||||||
String codec,
|
String codec,
|
||||||
int index,
|
|
||||||
String displayTitle,
|
String displayTitle,
|
||||||
String extendedDisplayTitle) {
|
String extendedDisplayTitle) {
|
||||||
this(id, streamType, Optional.empty(), codec, index, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), displayTitle, extendedDisplayTitle, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty());
|
this(id, streamType, Optional.empty(), Optional.empty(), codec, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), displayTitle, extendedDisplayTitle, Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -512,13 +535,24 @@ public class GetMediaMetaDataStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int streamType() {
|
public GetMediaMetaDataStreamType streamType() {
|
||||||
return streamType;
|
return streamType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> format() {
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -539,7 +573,7 @@ public class GetMediaMetaDataStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public int index() {
|
public Optional<Integer> index() {
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -732,6 +766,14 @@ public class GetMediaMetaDataStream {
|
|||||||
return frameRate;
|
return frameRate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> key() {
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -894,14 +936,35 @@ public class GetMediaMetaDataStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataStream withStreamType(int streamType) {
|
public GetMediaMetaDataStream withStreamType(GetMediaMetaDataStreamType streamType) {
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataStream withFormat(String format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = Optional.ofNullable(format);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataStream withFormat(Optional<String> format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = format;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -933,6 +996,15 @@ public class GetMediaMetaDataStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataStream withIndex(int index) {
|
public GetMediaMetaDataStream withIndex(int index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = Optional.ofNullable(index);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Index of the stream.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataStream withIndex(Optional<Integer> index) {
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
this.index = index;
|
this.index = index;
|
||||||
return this;
|
return this;
|
||||||
@@ -1364,6 +1436,24 @@ public class GetMediaMetaDataStream {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataStream withKey(String key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = Optional.ofNullable(key);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataStream withKey(Optional<String> key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = key;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -1695,6 +1785,7 @@ public class GetMediaMetaDataStream {
|
|||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.streamType, other.streamType) &&
|
Objects.deepEquals(this.streamType, other.streamType) &&
|
||||||
|
Objects.deepEquals(this.format, other.format) &&
|
||||||
Objects.deepEquals(this.default_, other.default_) &&
|
Objects.deepEquals(this.default_, other.default_) &&
|
||||||
Objects.deepEquals(this.codec, other.codec) &&
|
Objects.deepEquals(this.codec, other.codec) &&
|
||||||
Objects.deepEquals(this.index, other.index) &&
|
Objects.deepEquals(this.index, other.index) &&
|
||||||
@@ -1722,6 +1813,7 @@ public class GetMediaMetaDataStream {
|
|||||||
Objects.deepEquals(this.colorSpace, other.colorSpace) &&
|
Objects.deepEquals(this.colorSpace, other.colorSpace) &&
|
||||||
Objects.deepEquals(this.colorTrc, other.colorTrc) &&
|
Objects.deepEquals(this.colorTrc, other.colorTrc) &&
|
||||||
Objects.deepEquals(this.frameRate, other.frameRate) &&
|
Objects.deepEquals(this.frameRate, other.frameRate) &&
|
||||||
|
Objects.deepEquals(this.key, other.key) &&
|
||||||
Objects.deepEquals(this.height, other.height) &&
|
Objects.deepEquals(this.height, other.height) &&
|
||||||
Objects.deepEquals(this.level, other.level) &&
|
Objects.deepEquals(this.level, other.level) &&
|
||||||
Objects.deepEquals(this.original, other.original) &&
|
Objects.deepEquals(this.original, other.original) &&
|
||||||
@@ -1749,6 +1841,7 @@ public class GetMediaMetaDataStream {
|
|||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
streamType,
|
streamType,
|
||||||
|
format,
|
||||||
default_,
|
default_,
|
||||||
codec,
|
codec,
|
||||||
index,
|
index,
|
||||||
@@ -1776,6 +1869,7 @@ public class GetMediaMetaDataStream {
|
|||||||
colorSpace,
|
colorSpace,
|
||||||
colorTrc,
|
colorTrc,
|
||||||
frameRate,
|
frameRate,
|
||||||
|
key,
|
||||||
height,
|
height,
|
||||||
level,
|
level,
|
||||||
original,
|
original,
|
||||||
@@ -1803,6 +1897,7 @@ public class GetMediaMetaDataStream {
|
|||||||
return Utils.toString(GetMediaMetaDataStream.class,
|
return Utils.toString(GetMediaMetaDataStream.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"streamType", streamType,
|
"streamType", streamType,
|
||||||
|
"format", format,
|
||||||
"default_", default_,
|
"default_", default_,
|
||||||
"codec", codec,
|
"codec", codec,
|
||||||
"index", index,
|
"index", index,
|
||||||
@@ -1830,6 +1925,7 @@ public class GetMediaMetaDataStream {
|
|||||||
"colorSpace", colorSpace,
|
"colorSpace", colorSpace,
|
||||||
"colorTrc", colorTrc,
|
"colorTrc", colorTrc,
|
||||||
"frameRate", frameRate,
|
"frameRate", frameRate,
|
||||||
|
"key", key,
|
||||||
"height", height,
|
"height", height,
|
||||||
"level", level,
|
"level", level,
|
||||||
"original", original,
|
"original", original,
|
||||||
@@ -1856,13 +1952,15 @@ public class GetMediaMetaDataStream {
|
|||||||
|
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
private Integer streamType;
|
private GetMediaMetaDataStreamType streamType;
|
||||||
|
|
||||||
|
private Optional<String> format = Optional.empty();
|
||||||
|
|
||||||
private Optional<Boolean> default_ = Optional.empty();
|
private Optional<Boolean> default_ = Optional.empty();
|
||||||
|
|
||||||
private String codec;
|
private String codec;
|
||||||
|
|
||||||
private Integer index;
|
private Optional<Integer> index = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> bitrate = Optional.empty();
|
private Optional<Integer> bitrate = Optional.empty();
|
||||||
|
|
||||||
@@ -1912,6 +2010,8 @@ public class GetMediaMetaDataStream {
|
|||||||
|
|
||||||
private Optional<Float> frameRate = Optional.empty();
|
private Optional<Float> frameRate = Optional.empty();
|
||||||
|
|
||||||
|
private Optional<String> key = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> height = Optional.empty();
|
private Optional<Integer> height = Optional.empty();
|
||||||
|
|
||||||
private Optional<Integer> level = Optional.empty();
|
private Optional<Integer> level = Optional.empty();
|
||||||
@@ -1966,14 +2066,35 @@ public class GetMediaMetaDataStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stream type (1=video, 2=audio, 3=subtitle).
|
* Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
*/
|
*/
|
||||||
public Builder streamType(int streamType) {
|
public Builder streamType(GetMediaMetaDataStreamType streamType) {
|
||||||
Utils.checkNotNull(streamType, "streamType");
|
Utils.checkNotNull(streamType, "streamType");
|
||||||
this.streamType = streamType;
|
this.streamType = streamType;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public Builder format(String format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = Optional.ofNullable(format);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format of the stream (e.g., srt).
|
||||||
|
*/
|
||||||
|
public Builder format(Optional<String> format) {
|
||||||
|
Utils.checkNotNull(format, "format");
|
||||||
|
this.format = format;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates if this stream is default.
|
* Indicates if this stream is default.
|
||||||
*/
|
*/
|
||||||
@@ -2005,6 +2126,15 @@ public class GetMediaMetaDataStream {
|
|||||||
* Index of the stream.
|
* Index of the stream.
|
||||||
*/
|
*/
|
||||||
public Builder index(int index) {
|
public Builder index(int index) {
|
||||||
|
Utils.checkNotNull(index, "index");
|
||||||
|
this.index = Optional.ofNullable(index);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Index of the stream.
|
||||||
|
*/
|
||||||
|
public Builder index(Optional<Integer> index) {
|
||||||
Utils.checkNotNull(index, "index");
|
Utils.checkNotNull(index, "index");
|
||||||
this.index = index;
|
this.index = index;
|
||||||
return this;
|
return this;
|
||||||
@@ -2436,6 +2566,24 @@ public class GetMediaMetaDataStream {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public Builder key(String key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = Optional.ofNullable(key);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key to access this stream part.
|
||||||
|
*/
|
||||||
|
public Builder key(Optional<String> key) {
|
||||||
|
Utils.checkNotNull(key, "key");
|
||||||
|
this.key = key;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Height of the video stream.
|
* Height of the video stream.
|
||||||
*/
|
*/
|
||||||
@@ -2758,6 +2906,7 @@ public class GetMediaMetaDataStream {
|
|||||||
return new GetMediaMetaDataStream(
|
return new GetMediaMetaDataStream(
|
||||||
id,
|
id,
|
||||||
streamType,
|
streamType,
|
||||||
|
format,
|
||||||
default_,
|
default_,
|
||||||
codec,
|
codec,
|
||||||
index,
|
index,
|
||||||
@@ -2785,6 +2934,7 @@ public class GetMediaMetaDataStream {
|
|||||||
colorSpace,
|
colorSpace,
|
||||||
colorTrc,
|
colorTrc,
|
||||||
frameRate,
|
frameRate,
|
||||||
|
key,
|
||||||
height,
|
height,
|
||||||
level,
|
level,
|
||||||
original,
|
original,
|
||||||
|
|||||||
@@ -0,0 +1,192 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Integer;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* GetMediaMetaDataStreamType
|
||||||
|
*
|
||||||
|
* <p>Stream type:
|
||||||
|
* - 1 = video
|
||||||
|
* - 2 = audio
|
||||||
|
* - 3 = subtitle
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetMediaMetaDataStreamType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetMediaMetaDataStreamType._Serializer.class)
|
||||||
|
public class GetMediaMetaDataStreamType {
|
||||||
|
|
||||||
|
public static final GetMediaMetaDataStreamType Video = new GetMediaMetaDataStreamType(1);
|
||||||
|
public static final GetMediaMetaDataStreamType Audio = new GetMediaMetaDataStreamType(2);
|
||||||
|
public static final GetMediaMetaDataStreamType Subtitle = new GetMediaMetaDataStreamType(3);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Integer, GetMediaMetaDataStreamType> values = createValuesMap();
|
||||||
|
private static final Map<Integer, GetMediaMetaDataStreamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
|
private final int value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataStreamType(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetMediaMetaDataStreamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetMediaMetaDataStreamType
|
||||||
|
*/
|
||||||
|
public static GetMediaMetaDataStreamType of(int value) {
|
||||||
|
synchronized (GetMediaMetaDataStreamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetMediaMetaDataStreamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<GetMediaMetaDataStreamTypeEnum> asEnum() {
|
||||||
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetMediaMetaDataStreamType other = (GetMediaMetaDataStreamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetMediaMetaDataStreamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetMediaMetaDataStreamType[] values() {
|
||||||
|
synchronized (GetMediaMetaDataStreamType.class) {
|
||||||
|
return values.values().toArray(new GetMediaMetaDataStreamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Integer, GetMediaMetaDataStreamType> createValuesMap() {
|
||||||
|
Map<Integer, GetMediaMetaDataStreamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1, Video);
|
||||||
|
map.put(2, Audio);
|
||||||
|
map.put(3, Subtitle);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Integer, GetMediaMetaDataStreamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Integer, GetMediaMetaDataStreamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1, GetMediaMetaDataStreamTypeEnum.Video);
|
||||||
|
map.put(2, GetMediaMetaDataStreamTypeEnum.Audio);
|
||||||
|
map.put(3, GetMediaMetaDataStreamTypeEnum.Subtitle);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetMediaMetaDataStreamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetMediaMetaDataStreamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetMediaMetaDataStreamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetMediaMetaDataStreamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetMediaMetaDataStreamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetMediaMetaDataStreamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
int v = p.readValueAs(new TypeReference<Integer>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetMediaMetaDataStreamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetMediaMetaDataStreamTypeEnum {
|
||||||
|
|
||||||
|
Video(1),
|
||||||
|
Audio(2),
|
||||||
|
Subtitle(3),;
|
||||||
|
|
||||||
|
private final int value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataStreamTypeEnum(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,200 @@
|
|||||||
|
/*
|
||||||
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
||||||
|
*/
|
||||||
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* GetMediaMetaDataType
|
||||||
|
*
|
||||||
|
* <p>The type of media content
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetMediaMetaDataType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetMediaMetaDataType._Serializer.class)
|
||||||
|
public class GetMediaMetaDataType {
|
||||||
|
|
||||||
|
public static final GetMediaMetaDataType Movie = new GetMediaMetaDataType("movie");
|
||||||
|
public static final GetMediaMetaDataType TvShow = new GetMediaMetaDataType("show");
|
||||||
|
public static final GetMediaMetaDataType Season = new GetMediaMetaDataType("season");
|
||||||
|
public static final GetMediaMetaDataType Episode = new GetMediaMetaDataType("episode");
|
||||||
|
public static final GetMediaMetaDataType Artist = new GetMediaMetaDataType("artist");
|
||||||
|
public static final GetMediaMetaDataType Album = new GetMediaMetaDataType("album");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetMediaMetaDataType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetMediaMetaDataTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataType(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetMediaMetaDataType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetMediaMetaDataType
|
||||||
|
*/
|
||||||
|
public static GetMediaMetaDataType of(String value) {
|
||||||
|
synchronized (GetMediaMetaDataType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetMediaMetaDataType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<GetMediaMetaDataTypeEnum> asEnum() {
|
||||||
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetMediaMetaDataType other = (GetMediaMetaDataType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetMediaMetaDataType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetMediaMetaDataType[] values() {
|
||||||
|
synchronized (GetMediaMetaDataType.class) {
|
||||||
|
return values.values().toArray(new GetMediaMetaDataType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetMediaMetaDataType> createValuesMap() {
|
||||||
|
Map<String, GetMediaMetaDataType> map = new LinkedHashMap<>();
|
||||||
|
map.put("movie", Movie);
|
||||||
|
map.put("show", TvShow);
|
||||||
|
map.put("season", Season);
|
||||||
|
map.put("episode", Episode);
|
||||||
|
map.put("artist", Artist);
|
||||||
|
map.put("album", Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetMediaMetaDataTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetMediaMetaDataTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("movie", GetMediaMetaDataTypeEnum.Movie);
|
||||||
|
map.put("show", GetMediaMetaDataTypeEnum.TvShow);
|
||||||
|
map.put("season", GetMediaMetaDataTypeEnum.Season);
|
||||||
|
map.put("episode", GetMediaMetaDataTypeEnum.Episode);
|
||||||
|
map.put("artist", GetMediaMetaDataTypeEnum.Artist);
|
||||||
|
map.put("album", GetMediaMetaDataTypeEnum.Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetMediaMetaDataType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetMediaMetaDataType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetMediaMetaDataType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetMediaMetaDataType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetMediaMetaDataType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetMediaMetaDataType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetMediaMetaDataType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetMediaMetaDataTypeEnum {
|
||||||
|
|
||||||
|
Movie("movie"),
|
||||||
|
TvShow("show"),
|
||||||
|
Season("season"),
|
||||||
|
Episode("episode"),
|
||||||
|
Artist("artist"),
|
||||||
|
Album("album"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetMediaMetaDataTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -13,27 +13,15 @@ import java.util.Objects;
|
|||||||
|
|
||||||
public class GetMediaMetaDataUltraBlurColors {
|
public class GetMediaMetaDataUltraBlurColors {
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-left color value.
|
|
||||||
*/
|
|
||||||
@JsonProperty("topLeft")
|
@JsonProperty("topLeft")
|
||||||
private String topLeft;
|
private String topLeft;
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-right color value.
|
|
||||||
*/
|
|
||||||
@JsonProperty("topRight")
|
@JsonProperty("topRight")
|
||||||
private String topRight;
|
private String topRight;
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-right color value.
|
|
||||||
*/
|
|
||||||
@JsonProperty("bottomRight")
|
@JsonProperty("bottomRight")
|
||||||
private String bottomRight;
|
private String bottomRight;
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-left color value.
|
|
||||||
*/
|
|
||||||
@JsonProperty("bottomLeft")
|
@JsonProperty("bottomLeft")
|
||||||
private String bottomLeft;
|
private String bottomLeft;
|
||||||
|
|
||||||
@@ -53,33 +41,21 @@ public class GetMediaMetaDataUltraBlurColors {
|
|||||||
this.bottomLeft = bottomLeft;
|
this.bottomLeft = bottomLeft;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-left color value.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String topLeft() {
|
public String topLeft() {
|
||||||
return topLeft;
|
return topLeft;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-right color value.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String topRight() {
|
public String topRight() {
|
||||||
return topRight;
|
return topRight;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-right color value.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String bottomRight() {
|
public String bottomRight() {
|
||||||
return bottomRight;
|
return bottomRight;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-left color value.
|
|
||||||
*/
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String bottomLeft() {
|
public String bottomLeft() {
|
||||||
return bottomLeft;
|
return bottomLeft;
|
||||||
@@ -89,36 +65,24 @@ public class GetMediaMetaDataUltraBlurColors {
|
|||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-left color value.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataUltraBlurColors withTopLeft(String topLeft) {
|
public GetMediaMetaDataUltraBlurColors withTopLeft(String topLeft) {
|
||||||
Utils.checkNotNull(topLeft, "topLeft");
|
Utils.checkNotNull(topLeft, "topLeft");
|
||||||
this.topLeft = topLeft;
|
this.topLeft = topLeft;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-right color value.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataUltraBlurColors withTopRight(String topRight) {
|
public GetMediaMetaDataUltraBlurColors withTopRight(String topRight) {
|
||||||
Utils.checkNotNull(topRight, "topRight");
|
Utils.checkNotNull(topRight, "topRight");
|
||||||
this.topRight = topRight;
|
this.topRight = topRight;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-right color value.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataUltraBlurColors withBottomRight(String bottomRight) {
|
public GetMediaMetaDataUltraBlurColors withBottomRight(String bottomRight) {
|
||||||
Utils.checkNotNull(bottomRight, "bottomRight");
|
Utils.checkNotNull(bottomRight, "bottomRight");
|
||||||
this.bottomRight = bottomRight;
|
this.bottomRight = bottomRight;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-left color value.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataUltraBlurColors withBottomLeft(String bottomLeft) {
|
public GetMediaMetaDataUltraBlurColors withBottomLeft(String bottomLeft) {
|
||||||
Utils.checkNotNull(bottomLeft, "bottomLeft");
|
Utils.checkNotNull(bottomLeft, "bottomLeft");
|
||||||
this.bottomLeft = bottomLeft;
|
this.bottomLeft = bottomLeft;
|
||||||
@@ -174,36 +138,24 @@ public class GetMediaMetaDataUltraBlurColors {
|
|||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-left color value.
|
|
||||||
*/
|
|
||||||
public Builder topLeft(String topLeft) {
|
public Builder topLeft(String topLeft) {
|
||||||
Utils.checkNotNull(topLeft, "topLeft");
|
Utils.checkNotNull(topLeft, "topLeft");
|
||||||
this.topLeft = topLeft;
|
this.topLeft = topLeft;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The top-right color value.
|
|
||||||
*/
|
|
||||||
public Builder topRight(String topRight) {
|
public Builder topRight(String topRight) {
|
||||||
Utils.checkNotNull(topRight, "topRight");
|
Utils.checkNotNull(topRight, "topRight");
|
||||||
this.topRight = topRight;
|
this.topRight = topRight;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-right color value.
|
|
||||||
*/
|
|
||||||
public Builder bottomRight(String bottomRight) {
|
public Builder bottomRight(String bottomRight) {
|
||||||
Utils.checkNotNull(bottomRight, "bottomRight");
|
Utils.checkNotNull(bottomRight, "bottomRight");
|
||||||
this.bottomRight = bottomRight;
|
this.bottomRight = bottomRight;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The bottom-left color value.
|
|
||||||
*/
|
|
||||||
public Builder bottomLeft(String bottomLeft) {
|
public Builder bottomLeft(String bottomLeft) {
|
||||||
Utils.checkNotNull(bottomLeft, "bottomLeft");
|
Utils.checkNotNull(bottomLeft, "bottomLeft");
|
||||||
this.bottomLeft = bottomLeft;
|
this.bottomLeft = bottomLeft;
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import com.fasterxml.jackson.annotation.JsonInclude.Include;
|
|||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import dev.plexapi.sdk.utils.Utils;
|
import dev.plexapi.sdk.utils.Utils;
|
||||||
import java.lang.Long;
|
import java.lang.Integer;
|
||||||
import java.lang.Override;
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
@@ -18,91 +18,73 @@ import java.util.Optional;
|
|||||||
public class GetMediaMetaDataWriter {
|
public class GetMediaMetaDataWriter {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the writer.
|
||||||
*/
|
*/
|
||||||
@JsonProperty("id")
|
@JsonProperty("id")
|
||||||
private long id;
|
private int id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Writer
|
||||||
*/
|
|
||||||
@JsonProperty("filter")
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tag")
|
@JsonProperty("tag")
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this writer.
|
||||||
*/
|
*/
|
||||||
@JsonProperty("tagKey")
|
@JsonProperty("filter")
|
||||||
private String tagKey;
|
private String filter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
|
||||||
@JsonProperty("role")
|
|
||||||
private Optional<String> role;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
@JsonInclude(Include.NON_ABSENT)
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
@JsonProperty("thumb")
|
@JsonProperty("thumb")
|
||||||
private Optional<String> thumb;
|
private Optional<String> thumb;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
@JsonInclude(Include.NON_ABSENT)
|
||||||
|
@JsonProperty("tagKey")
|
||||||
|
private Optional<String> tagKey;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public GetMediaMetaDataWriter(
|
public GetMediaMetaDataWriter(
|
||||||
@JsonProperty("id") long id,
|
@JsonProperty("id") int id,
|
||||||
@JsonProperty("filter") String filter,
|
|
||||||
@JsonProperty("tag") String tag,
|
@JsonProperty("tag") String tag,
|
||||||
@JsonProperty("tagKey") String tagKey,
|
@JsonProperty("filter") String filter,
|
||||||
@JsonProperty("role") Optional<String> role,
|
@JsonProperty("thumb") Optional<String> thumb,
|
||||||
@JsonProperty("thumb") Optional<String> thumb) {
|
@JsonProperty("tagKey") Optional<String> tagKey) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(filter, "filter");
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.filter = filter;
|
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
this.tagKey = tagKey;
|
this.filter = filter;
|
||||||
this.role = role;
|
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
|
this.tagKey = tagKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataWriter(
|
public GetMediaMetaDataWriter(
|
||||||
long id,
|
int id,
|
||||||
String filter,
|
|
||||||
String tag,
|
String tag,
|
||||||
String tagKey) {
|
String filter) {
|
||||||
this(id, filter, tag, tagKey, Optional.empty(), Optional.empty());
|
this(id, tag, filter, Optional.empty(), Optional.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the writer.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public long id() {
|
public int id() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Writer
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public String filter() {
|
|
||||||
return filter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tag() {
|
public String tag() {
|
||||||
@@ -110,53 +92,44 @@ public class GetMediaMetaDataWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this writer.
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public String tagKey() {
|
public String filter() {
|
||||||
return tagKey;
|
return filter;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
|
||||||
@JsonIgnore
|
|
||||||
public Optional<String> role() {
|
|
||||||
return role;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
public Optional<String> thumb() {
|
public Optional<String> thumb() {
|
||||||
return thumb;
|
return thumb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
public Optional<String> tagKey() {
|
||||||
|
return tagKey;
|
||||||
|
}
|
||||||
|
|
||||||
public final static Builder builder() {
|
public final static Builder builder() {
|
||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the writer.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataWriter withId(long id) {
|
public GetMediaMetaDataWriter withId(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Writer
|
||||||
*/
|
|
||||||
public GetMediaMetaDataWriter withFilter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataWriter withTag(String tag) {
|
public GetMediaMetaDataWriter withTag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -165,34 +138,16 @@ public class GetMediaMetaDataWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this writer.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataWriter withTagKey(String tagKey) {
|
public GetMediaMetaDataWriter withFilter(String filter) {
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(filter, "filter");
|
||||||
this.tagKey = tagKey;
|
this.filter = filter;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
|
||||||
public GetMediaMetaDataWriter withRole(String role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = Optional.ofNullable(role);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
|
||||||
public GetMediaMetaDataWriter withRole(Optional<String> role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = role;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataWriter withThumb(String thumb) {
|
public GetMediaMetaDataWriter withThumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -201,7 +156,7 @@ public class GetMediaMetaDataWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
*/
|
||||||
public GetMediaMetaDataWriter withThumb(Optional<String> thumb) {
|
public GetMediaMetaDataWriter withThumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -209,6 +164,24 @@ public class GetMediaMetaDataWriter {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataWriter withTagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public GetMediaMetaDataWriter withTagKey(Optional<String> tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = tagKey;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(java.lang.Object o) {
|
public boolean equals(java.lang.Object o) {
|
||||||
@@ -221,73 +194,59 @@ public class GetMediaMetaDataWriter {
|
|||||||
GetMediaMetaDataWriter other = (GetMediaMetaDataWriter) o;
|
GetMediaMetaDataWriter other = (GetMediaMetaDataWriter) o;
|
||||||
return
|
return
|
||||||
Objects.deepEquals(this.id, other.id) &&
|
Objects.deepEquals(this.id, other.id) &&
|
||||||
Objects.deepEquals(this.filter, other.filter) &&
|
|
||||||
Objects.deepEquals(this.tag, other.tag) &&
|
Objects.deepEquals(this.tag, other.tag) &&
|
||||||
Objects.deepEquals(this.tagKey, other.tagKey) &&
|
Objects.deepEquals(this.filter, other.filter) &&
|
||||||
Objects.deepEquals(this.role, other.role) &&
|
Objects.deepEquals(this.thumb, other.thumb) &&
|
||||||
Objects.deepEquals(this.thumb, other.thumb);
|
Objects.deepEquals(this.tagKey, other.tagKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hash(
|
return Objects.hash(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
tagKey,
|
filter,
|
||||||
role,
|
thumb,
|
||||||
thumb);
|
tagKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return Utils.toString(GetMediaMetaDataWriter.class,
|
return Utils.toString(GetMediaMetaDataWriter.class,
|
||||||
"id", id,
|
"id", id,
|
||||||
"filter", filter,
|
|
||||||
"tag", tag,
|
"tag", tag,
|
||||||
"tagKey", tagKey,
|
"filter", filter,
|
||||||
"role", role,
|
"thumb", thumb,
|
||||||
"thumb", thumb);
|
"tagKey", tagKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static class Builder {
|
public final static class Builder {
|
||||||
|
|
||||||
private Long id;
|
private Integer id;
|
||||||
|
|
||||||
private String filter;
|
|
||||||
|
|
||||||
private String tag;
|
private String tag;
|
||||||
|
|
||||||
private String tagKey;
|
private String filter;
|
||||||
|
|
||||||
private Optional<String> role = Optional.empty();
|
|
||||||
|
|
||||||
private Optional<String> thumb = Optional.empty();
|
private Optional<String> thumb = Optional.empty();
|
||||||
|
|
||||||
|
private Optional<String> tagKey = Optional.empty();
|
||||||
|
|
||||||
private Builder() {
|
private Builder() {
|
||||||
// force use of static builder() method
|
// force use of static builder() method
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The unique role identifier.
|
* Unique identifier for the writer.
|
||||||
*/
|
*/
|
||||||
public Builder id(long id) {
|
public Builder id(int id) {
|
||||||
Utils.checkNotNull(id, "id");
|
Utils.checkNotNull(id, "id");
|
||||||
this.id = id;
|
this.id = id;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The filter string for the role.
|
* The role of Writer
|
||||||
*/
|
|
||||||
public Builder filter(String filter) {
|
|
||||||
Utils.checkNotNull(filter, "filter");
|
|
||||||
this.filter = filter;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The actor's name.
|
|
||||||
*/
|
*/
|
||||||
public Builder tag(String tag) {
|
public Builder tag(String tag) {
|
||||||
Utils.checkNotNull(tag, "tag");
|
Utils.checkNotNull(tag, "tag");
|
||||||
@@ -296,34 +255,16 @@ public class GetMediaMetaDataWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A key associated with the actor tag.
|
* The filter string used to query this writer.
|
||||||
*/
|
*/
|
||||||
public Builder tagKey(String tagKey) {
|
public Builder filter(String filter) {
|
||||||
Utils.checkNotNull(tagKey, "tagKey");
|
Utils.checkNotNull(filter, "filter");
|
||||||
this.tagKey = tagKey;
|
this.filter = filter;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The character name or role.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
|
||||||
public Builder role(String role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = Optional.ofNullable(role);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character name or role.
|
|
||||||
*/
|
|
||||||
public Builder role(Optional<String> role) {
|
|
||||||
Utils.checkNotNull(role, "role");
|
|
||||||
this.role = role;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* URL for the role thumbnail image.
|
|
||||||
*/
|
*/
|
||||||
public Builder thumb(String thumb) {
|
public Builder thumb(String thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
@@ -332,22 +273,39 @@ public class GetMediaMetaDataWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* URL for the role thumbnail image.
|
* The URL of the thumbnail image for the writer.
|
||||||
*/
|
*/
|
||||||
public Builder thumb(Optional<String> thumb) {
|
public Builder thumb(Optional<String> thumb) {
|
||||||
Utils.checkNotNull(thumb, "thumb");
|
Utils.checkNotNull(thumb, "thumb");
|
||||||
this.thumb = thumb;
|
this.thumb = thumb;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public Builder tagKey(String tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = Optional.ofNullable(tagKey);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A unique key associated with the writers tag, used for internal identification.
|
||||||
|
*/
|
||||||
|
public Builder tagKey(Optional<String> tagKey) {
|
||||||
|
Utils.checkNotNull(tagKey, "tagKey");
|
||||||
|
this.tagKey = tagKey;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public GetMediaMetaDataWriter build() {
|
public GetMediaMetaDataWriter build() {
|
||||||
return new GetMediaMetaDataWriter(
|
return new GetMediaMetaDataWriter(
|
||||||
id,
|
id,
|
||||||
filter,
|
|
||||||
tag,
|
tag,
|
||||||
tagKey,
|
filter,
|
||||||
role,
|
thumb,
|
||||||
thumb);
|
tagKey);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,10 +3,45 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Long;
|
||||||
|
import java.lang.Override;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetPlaylistContentsQueryParamType
|
* GetPlaylistContentsQueryParamType
|
||||||
*
|
*
|
||||||
@@ -17,33 +52,159 @@ import java.util.Optional;
|
|||||||
* 4 = episode
|
* 4 = episode
|
||||||
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
* E.g. A movie library will not return anything with type 3 as there are no seasons for movie libraries
|
||||||
*/
|
*/
|
||||||
public enum GetPlaylistContentsQueryParamType {
|
@JsonDeserialize(using = GetPlaylistContentsQueryParamType._Deserializer.class)
|
||||||
Movie(1L),
|
@JsonSerialize(using = GetPlaylistContentsQueryParamType._Serializer.class)
|
||||||
TvShow(2L),
|
public class GetPlaylistContentsQueryParamType {
|
||||||
Season(3L),
|
|
||||||
Episode(4L),
|
public static final GetPlaylistContentsQueryParamType Movie = new GetPlaylistContentsQueryParamType(1L);
|
||||||
Audio(8L),
|
public static final GetPlaylistContentsQueryParamType TvShow = new GetPlaylistContentsQueryParamType(2L);
|
||||||
Album(9L),
|
public static final GetPlaylistContentsQueryParamType Season = new GetPlaylistContentsQueryParamType(3L);
|
||||||
Track(10L);
|
public static final GetPlaylistContentsQueryParamType Episode = new GetPlaylistContentsQueryParamType(4L);
|
||||||
|
public static final GetPlaylistContentsQueryParamType Audio = new GetPlaylistContentsQueryParamType(8L);
|
||||||
|
public static final GetPlaylistContentsQueryParamType Album = new GetPlaylistContentsQueryParamType(9L);
|
||||||
|
public static final GetPlaylistContentsQueryParamType Track = new GetPlaylistContentsQueryParamType(10L);
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<Long, GetPlaylistContentsQueryParamType> values = createValuesMap();
|
||||||
|
private static final Map<Long, GetPlaylistContentsQueryParamTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final long value;
|
private final long value;
|
||||||
|
|
||||||
private GetPlaylistContentsQueryParamType(long value) {
|
private GetPlaylistContentsQueryParamType(long value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetPlaylistContentsQueryParamType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetPlaylistContentsQueryParamType
|
||||||
|
*/
|
||||||
|
public static GetPlaylistContentsQueryParamType of(long value) {
|
||||||
|
synchronized (GetPlaylistContentsQueryParamType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetPlaylistContentsQueryParamType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public long value() {
|
public long value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetPlaylistContentsQueryParamType> fromValue(long value) {
|
public Optional<GetPlaylistContentsQueryParamTypeEnum> asEnum() {
|
||||||
for (GetPlaylistContentsQueryParamType o: GetPlaylistContentsQueryParamType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetPlaylistContentsQueryParamType other = (GetPlaylistContentsQueryParamType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetPlaylistContentsQueryParamType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetPlaylistContentsQueryParamType[] values() {
|
||||||
|
synchronized (GetPlaylistContentsQueryParamType.class) {
|
||||||
|
return values.values().toArray(new GetPlaylistContentsQueryParamType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetPlaylistContentsQueryParamType> createValuesMap() {
|
||||||
|
Map<Long, GetPlaylistContentsQueryParamType> map = new LinkedHashMap<>();
|
||||||
|
map.put(1L, Movie);
|
||||||
|
map.put(2L, TvShow);
|
||||||
|
map.put(3L, Season);
|
||||||
|
map.put(4L, Episode);
|
||||||
|
map.put(8L, Audio);
|
||||||
|
map.put(9L, Album);
|
||||||
|
map.put(10L, Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Long, GetPlaylistContentsQueryParamTypeEnum> createEnumsMap() {
|
||||||
|
Map<Long, GetPlaylistContentsQueryParamTypeEnum> map = new HashMap<>();
|
||||||
|
map.put(1L, GetPlaylistContentsQueryParamTypeEnum.Movie);
|
||||||
|
map.put(2L, GetPlaylistContentsQueryParamTypeEnum.TvShow);
|
||||||
|
map.put(3L, GetPlaylistContentsQueryParamTypeEnum.Season);
|
||||||
|
map.put(4L, GetPlaylistContentsQueryParamTypeEnum.Episode);
|
||||||
|
map.put(8L, GetPlaylistContentsQueryParamTypeEnum.Audio);
|
||||||
|
map.put(9L, GetPlaylistContentsQueryParamTypeEnum.Album);
|
||||||
|
map.put(10L, GetPlaylistContentsQueryParamTypeEnum.Track);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetPlaylistContentsQueryParamType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetPlaylistContentsQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetPlaylistContentsQueryParamType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetPlaylistContentsQueryParamType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetPlaylistContentsQueryParamType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetPlaylistContentsQueryParamType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
long v = p.readValueAs(new TypeReference<Long>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetPlaylistContentsQueryParamType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetPlaylistContentsQueryParamTypeEnum {
|
||||||
|
|
||||||
|
Movie(1L),
|
||||||
|
TvShow(2L),
|
||||||
|
Season(3L),
|
||||||
|
Episode(4L),
|
||||||
|
Audio(8L),
|
||||||
|
Album(9L),
|
||||||
|
Track(10L),;
|
||||||
|
|
||||||
|
private final long value;
|
||||||
|
|
||||||
|
private GetPlaylistContentsQueryParamTypeEnum(long value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,35 +3,185 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public enum GetRecentlyAddedHubsResponseType {
|
/**
|
||||||
COVER_POSTER("coverPoster"),
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
BACKGROUND("background"),
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
SNAPSHOT("snapshot"),
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
CLEAR_LOGO("clearLogo");
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@JsonDeserialize(using = GetRecentlyAddedHubsResponseType._Deserializer.class)
|
||||||
|
@JsonSerialize(using = GetRecentlyAddedHubsResponseType._Serializer.class)
|
||||||
|
public class GetRecentlyAddedHubsResponseType {
|
||||||
|
|
||||||
|
public static final GetRecentlyAddedHubsResponseType COVER_POSTER = new GetRecentlyAddedHubsResponseType("coverPoster");
|
||||||
|
public static final GetRecentlyAddedHubsResponseType BACKGROUND = new GetRecentlyAddedHubsResponseType("background");
|
||||||
|
public static final GetRecentlyAddedHubsResponseType SNAPSHOT = new GetRecentlyAddedHubsResponseType("snapshot");
|
||||||
|
public static final GetRecentlyAddedHubsResponseType CLEAR_LOGO = new GetRecentlyAddedHubsResponseType("clearLogo");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsResponseType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsResponseTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetRecentlyAddedHubsResponseType(String value) {
|
private GetRecentlyAddedHubsResponseType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetRecentlyAddedHubsResponseType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetRecentlyAddedHubsResponseType
|
||||||
|
*/
|
||||||
|
public static GetRecentlyAddedHubsResponseType of(String value) {
|
||||||
|
synchronized (GetRecentlyAddedHubsResponseType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetRecentlyAddedHubsResponseType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetRecentlyAddedHubsResponseType> fromValue(String value) {
|
public Optional<GetRecentlyAddedHubsResponseTypeEnum> asEnum() {
|
||||||
for (GetRecentlyAddedHubsResponseType o: GetRecentlyAddedHubsResponseType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetRecentlyAddedHubsResponseType other = (GetRecentlyAddedHubsResponseType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetRecentlyAddedHubsResponseType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetRecentlyAddedHubsResponseType[] values() {
|
||||||
|
synchronized (GetRecentlyAddedHubsResponseType.class) {
|
||||||
|
return values.values().toArray(new GetRecentlyAddedHubsResponseType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsResponseType> createValuesMap() {
|
||||||
|
Map<String, GetRecentlyAddedHubsResponseType> map = new LinkedHashMap<>();
|
||||||
|
map.put("coverPoster", COVER_POSTER);
|
||||||
|
map.put("background", BACKGROUND);
|
||||||
|
map.put("snapshot", SNAPSHOT);
|
||||||
|
map.put("clearLogo", CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsResponseTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetRecentlyAddedHubsResponseTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("coverPoster", GetRecentlyAddedHubsResponseTypeEnum.COVER_POSTER);
|
||||||
|
map.put("background", GetRecentlyAddedHubsResponseTypeEnum.BACKGROUND);
|
||||||
|
map.put("snapshot", GetRecentlyAddedHubsResponseTypeEnum.SNAPSHOT);
|
||||||
|
map.put("clearLogo", GetRecentlyAddedHubsResponseTypeEnum.CLEAR_LOGO);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetRecentlyAddedHubsResponseType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetRecentlyAddedHubsResponseType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetRecentlyAddedHubsResponseType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetRecentlyAddedHubsResponseType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetRecentlyAddedHubsResponseType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetRecentlyAddedHubsResponseType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetRecentlyAddedHubsResponseType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetRecentlyAddedHubsResponseTypeEnum {
|
||||||
|
|
||||||
|
COVER_POSTER("coverPoster"),
|
||||||
|
BACKGROUND("background"),
|
||||||
|
SNAPSHOT("snapshot"),
|
||||||
|
CLEAR_LOGO("clearLogo"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetRecentlyAddedHubsResponseTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,42 +3,198 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetRecentlyAddedHubsType
|
* GetRecentlyAddedHubsType
|
||||||
*
|
*
|
||||||
* <p>The type of media content
|
* <p>The type of media content
|
||||||
*/
|
*/
|
||||||
public enum GetRecentlyAddedHubsType {
|
@JsonDeserialize(using = GetRecentlyAddedHubsType._Deserializer.class)
|
||||||
Movie("movie"),
|
@JsonSerialize(using = GetRecentlyAddedHubsType._Serializer.class)
|
||||||
TvShow("show"),
|
public class GetRecentlyAddedHubsType {
|
||||||
Season("season"),
|
|
||||||
Episode("episode"),
|
public static final GetRecentlyAddedHubsType Movie = new GetRecentlyAddedHubsType("movie");
|
||||||
Artist("artist"),
|
public static final GetRecentlyAddedHubsType TvShow = new GetRecentlyAddedHubsType("show");
|
||||||
Album("album");
|
public static final GetRecentlyAddedHubsType Season = new GetRecentlyAddedHubsType("season");
|
||||||
|
public static final GetRecentlyAddedHubsType Episode = new GetRecentlyAddedHubsType("episode");
|
||||||
|
public static final GetRecentlyAddedHubsType Artist = new GetRecentlyAddedHubsType("artist");
|
||||||
|
public static final GetRecentlyAddedHubsType Album = new GetRecentlyAddedHubsType("album");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsType> values = createValuesMap();
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsTypeEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetRecentlyAddedHubsType(String value) {
|
private GetRecentlyAddedHubsType(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetRecentlyAddedHubsType with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetRecentlyAddedHubsType
|
||||||
|
*/
|
||||||
|
public static GetRecentlyAddedHubsType of(String value) {
|
||||||
|
synchronized (GetRecentlyAddedHubsType.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetRecentlyAddedHubsType(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetRecentlyAddedHubsType> fromValue(String value) {
|
public Optional<GetRecentlyAddedHubsTypeEnum> asEnum() {
|
||||||
for (GetRecentlyAddedHubsType o: GetRecentlyAddedHubsType.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetRecentlyAddedHubsType other = (GetRecentlyAddedHubsType) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetRecentlyAddedHubsType [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetRecentlyAddedHubsType[] values() {
|
||||||
|
synchronized (GetRecentlyAddedHubsType.class) {
|
||||||
|
return values.values().toArray(new GetRecentlyAddedHubsType[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsType> createValuesMap() {
|
||||||
|
Map<String, GetRecentlyAddedHubsType> map = new LinkedHashMap<>();
|
||||||
|
map.put("movie", Movie);
|
||||||
|
map.put("show", TvShow);
|
||||||
|
map.put("season", Season);
|
||||||
|
map.put("episode", Episode);
|
||||||
|
map.put("artist", Artist);
|
||||||
|
map.put("album", Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetRecentlyAddedHubsTypeEnum> createEnumsMap() {
|
||||||
|
Map<String, GetRecentlyAddedHubsTypeEnum> map = new HashMap<>();
|
||||||
|
map.put("movie", GetRecentlyAddedHubsTypeEnum.Movie);
|
||||||
|
map.put("show", GetRecentlyAddedHubsTypeEnum.TvShow);
|
||||||
|
map.put("season", GetRecentlyAddedHubsTypeEnum.Season);
|
||||||
|
map.put("episode", GetRecentlyAddedHubsTypeEnum.Episode);
|
||||||
|
map.put("artist", GetRecentlyAddedHubsTypeEnum.Artist);
|
||||||
|
map.put("album", GetRecentlyAddedHubsTypeEnum.Album);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetRecentlyAddedHubsType> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetRecentlyAddedHubsType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetRecentlyAddedHubsType value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetRecentlyAddedHubsType> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetRecentlyAddedHubsType.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetRecentlyAddedHubsType deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetRecentlyAddedHubsType.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetRecentlyAddedHubsTypeEnum {
|
||||||
|
|
||||||
|
Movie("movie"),
|
||||||
|
TvShow("show"),
|
||||||
|
Season("season"),
|
||||||
|
Episode("episode"),
|
||||||
|
Artist("artist"),
|
||||||
|
Album("album"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetRecentlyAddedHubsTypeEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,38 +3,182 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetSearchAllLibrariesEnableCreditsMarkerGeneration
|
* GetSearchAllLibrariesEnableCreditsMarkerGeneration
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates if credits markers detection is enabled. (-1 = Library default, 0 = Disabled).
|
* <p>Setting that indicates if credits markers detection is enabled. (-1 = Library default, 0 = Disabled).
|
||||||
*/
|
*/
|
||||||
public enum GetSearchAllLibrariesEnableCreditsMarkerGeneration {
|
@JsonDeserialize(using = GetSearchAllLibrariesEnableCreditsMarkerGeneration._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = GetSearchAllLibrariesEnableCreditsMarkerGeneration._Serializer.class)
|
||||||
Disabled("0");
|
public class GetSearchAllLibrariesEnableCreditsMarkerGeneration {
|
||||||
|
|
||||||
|
public static final GetSearchAllLibrariesEnableCreditsMarkerGeneration LibraryDefault = new GetSearchAllLibrariesEnableCreditsMarkerGeneration("-1");
|
||||||
|
public static final GetSearchAllLibrariesEnableCreditsMarkerGeneration Disabled = new GetSearchAllLibrariesEnableCreditsMarkerGeneration("0");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEnableCreditsMarkerGeneration> values = createValuesMap();
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetSearchAllLibrariesEnableCreditsMarkerGeneration(String value) {
|
private GetSearchAllLibrariesEnableCreditsMarkerGeneration(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetSearchAllLibrariesEnableCreditsMarkerGeneration with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetSearchAllLibrariesEnableCreditsMarkerGeneration
|
||||||
|
*/
|
||||||
|
public static GetSearchAllLibrariesEnableCreditsMarkerGeneration of(String value) {
|
||||||
|
synchronized (GetSearchAllLibrariesEnableCreditsMarkerGeneration.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetSearchAllLibrariesEnableCreditsMarkerGeneration(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetSearchAllLibrariesEnableCreditsMarkerGeneration> fromValue(String value) {
|
public Optional<GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum> asEnum() {
|
||||||
for (GetSearchAllLibrariesEnableCreditsMarkerGeneration o: GetSearchAllLibrariesEnableCreditsMarkerGeneration.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetSearchAllLibrariesEnableCreditsMarkerGeneration other = (GetSearchAllLibrariesEnableCreditsMarkerGeneration) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetSearchAllLibrariesEnableCreditsMarkerGeneration [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetSearchAllLibrariesEnableCreditsMarkerGeneration[] values() {
|
||||||
|
synchronized (GetSearchAllLibrariesEnableCreditsMarkerGeneration.class) {
|
||||||
|
return values.values().toArray(new GetSearchAllLibrariesEnableCreditsMarkerGeneration[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEnableCreditsMarkerGeneration> createValuesMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesEnableCreditsMarkerGeneration> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", Disabled);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum> createEnumsMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum.LibraryDefault);
|
||||||
|
map.put("0", GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum.Disabled);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetSearchAllLibrariesEnableCreditsMarkerGeneration> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetSearchAllLibrariesEnableCreditsMarkerGeneration.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetSearchAllLibrariesEnableCreditsMarkerGeneration value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetSearchAllLibrariesEnableCreditsMarkerGeneration> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetSearchAllLibrariesEnableCreditsMarkerGeneration.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetSearchAllLibrariesEnableCreditsMarkerGeneration deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetSearchAllLibrariesEnableCreditsMarkerGeneration.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
Disabled("0"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetSearchAllLibrariesEnableCreditsMarkerGenerationEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetSearchAllLibrariesEpisodeSort
|
* GetSearchAllLibrariesEpisodeSort
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates how episodes are sorted for the show. (-1 = Library default, 0 = Oldest first, 1 = Newest first).
|
* <p>Setting that indicates how episodes are sorted for the show. (-1 = Library default, 0 = Oldest first, 1 = Newest first).
|
||||||
*/
|
*/
|
||||||
public enum GetSearchAllLibrariesEpisodeSort {
|
@JsonDeserialize(using = GetSearchAllLibrariesEpisodeSort._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = GetSearchAllLibrariesEpisodeSort._Serializer.class)
|
||||||
OldestFirst("0"),
|
public class GetSearchAllLibrariesEpisodeSort {
|
||||||
NewestFirst("1");
|
|
||||||
|
public static final GetSearchAllLibrariesEpisodeSort LibraryDefault = new GetSearchAllLibrariesEpisodeSort("-1");
|
||||||
|
public static final GetSearchAllLibrariesEpisodeSort OldestFirst = new GetSearchAllLibrariesEpisodeSort("0");
|
||||||
|
public static final GetSearchAllLibrariesEpisodeSort NewestFirst = new GetSearchAllLibrariesEpisodeSort("1");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEpisodeSort> values = createValuesMap();
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEpisodeSortEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetSearchAllLibrariesEpisodeSort(String value) {
|
private GetSearchAllLibrariesEpisodeSort(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetSearchAllLibrariesEpisodeSort with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetSearchAllLibrariesEpisodeSort
|
||||||
|
*/
|
||||||
|
public static GetSearchAllLibrariesEpisodeSort of(String value) {
|
||||||
|
synchronized (GetSearchAllLibrariesEpisodeSort.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetSearchAllLibrariesEpisodeSort(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetSearchAllLibrariesEpisodeSort> fromValue(String value) {
|
public Optional<GetSearchAllLibrariesEpisodeSortEnum> asEnum() {
|
||||||
for (GetSearchAllLibrariesEpisodeSort o: GetSearchAllLibrariesEpisodeSort.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetSearchAllLibrariesEpisodeSort other = (GetSearchAllLibrariesEpisodeSort) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetSearchAllLibrariesEpisodeSort [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetSearchAllLibrariesEpisodeSort[] values() {
|
||||||
|
synchronized (GetSearchAllLibrariesEpisodeSort.class) {
|
||||||
|
return values.values().toArray(new GetSearchAllLibrariesEpisodeSort[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEpisodeSort> createValuesMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesEpisodeSort> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", OldestFirst);
|
||||||
|
map.put("1", NewestFirst);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesEpisodeSortEnum> createEnumsMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesEpisodeSortEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", GetSearchAllLibrariesEpisodeSortEnum.LibraryDefault);
|
||||||
|
map.put("0", GetSearchAllLibrariesEpisodeSortEnum.OldestFirst);
|
||||||
|
map.put("1", GetSearchAllLibrariesEpisodeSortEnum.NewestFirst);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetSearchAllLibrariesEpisodeSort> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetSearchAllLibrariesEpisodeSort.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetSearchAllLibrariesEpisodeSort value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetSearchAllLibrariesEpisodeSort> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetSearchAllLibrariesEpisodeSort.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetSearchAllLibrariesEpisodeSort deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetSearchAllLibrariesEpisodeSort.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetSearchAllLibrariesEpisodeSortEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
OldestFirst("0"),
|
||||||
|
NewestFirst("1"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetSearchAllLibrariesEpisodeSortEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,39 +3,186 @@
|
|||||||
*/
|
*/
|
||||||
package dev.plexapi.sdk.models.operations;
|
package dev.plexapi.sdk.models.operations;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue;
|
import com.fasterxml.jackson.core.JacksonException;
|
||||||
|
import com.fasterxml.jackson.core.JsonGenerator;
|
||||||
|
import com.fasterxml.jackson.core.JsonParser;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
import com.fasterxml.jackson.databind.DeserializationContext;
|
||||||
|
import com.fasterxml.jackson.databind.SerializerProvider;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.Override;
|
||||||
import java.lang.String;
|
import java.lang.String;
|
||||||
|
import java.lang.SuppressWarnings;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Wrapper class for an "open" enum. "Open" enums are those that are expected
|
||||||
|
* to evolve (particularly with the addition of enum members over time). If an
|
||||||
|
* open enum is used then the appearance of unexpected enum values (say in a
|
||||||
|
* response from an updated an API) will not bring about a runtime error thus
|
||||||
|
* ensuring that non-updated client versions can continue to work without error.
|
||||||
|
*
|
||||||
|
* <p>Note that instances are immutable and are singletons (an internal thread-safe
|
||||||
|
* cache is maintained to ensure that). As a consequence instances created with the
|
||||||
|
* same value will satisfy reference equality (via {@code ==}).
|
||||||
|
*
|
||||||
|
* <p>This class is intended to emulate an enum (in terms of common usage and with
|
||||||
|
* reference equality) but with the ability to carry unknown values. Unfortunately
|
||||||
|
* Java does not permit the use of an instance in a switch expression but you can
|
||||||
|
* use the {@code asEnum()} method (after dealing with the `Optional` appropriately).
|
||||||
|
*
|
||||||
|
*/
|
||||||
/**
|
/**
|
||||||
* GetSearchAllLibrariesFlattenSeasons
|
* GetSearchAllLibrariesFlattenSeasons
|
||||||
*
|
*
|
||||||
* <p>Setting that indicates if seasons are set to hidden for the show. (-1 = Library default, 0 = Hide, 1 = Show).
|
* <p>Setting that indicates if seasons are set to hidden for the show. (-1 = Library default, 0 = Hide, 1 = Show).
|
||||||
*/
|
*/
|
||||||
public enum GetSearchAllLibrariesFlattenSeasons {
|
@JsonDeserialize(using = GetSearchAllLibrariesFlattenSeasons._Deserializer.class)
|
||||||
LibraryDefault("-1"),
|
@JsonSerialize(using = GetSearchAllLibrariesFlattenSeasons._Serializer.class)
|
||||||
Hide("0"),
|
public class GetSearchAllLibrariesFlattenSeasons {
|
||||||
Show("1");
|
|
||||||
|
public static final GetSearchAllLibrariesFlattenSeasons LibraryDefault = new GetSearchAllLibrariesFlattenSeasons("-1");
|
||||||
|
public static final GetSearchAllLibrariesFlattenSeasons Hide = new GetSearchAllLibrariesFlattenSeasons("0");
|
||||||
|
public static final GetSearchAllLibrariesFlattenSeasons Show = new GetSearchAllLibrariesFlattenSeasons("1");
|
||||||
|
|
||||||
|
// This map will grow whenever a Color gets created with a new
|
||||||
|
// unrecognized value (a potential memory leak if the user is not
|
||||||
|
// careful). Keep this field lower case to avoid clashing with
|
||||||
|
// generated member names which will always be upper cased (Java
|
||||||
|
// convention)
|
||||||
|
private static final Map<String, GetSearchAllLibrariesFlattenSeasons> values = createValuesMap();
|
||||||
|
private static final Map<String, GetSearchAllLibrariesFlattenSeasonsEnum> enums = createEnumsMap();
|
||||||
|
|
||||||
@JsonValue
|
|
||||||
private final String value;
|
private final String value;
|
||||||
|
|
||||||
private GetSearchAllLibrariesFlattenSeasons(String value) {
|
private GetSearchAllLibrariesFlattenSeasons(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a GetSearchAllLibrariesFlattenSeasons with the given value. For a specific value the
|
||||||
|
* returned object will always be a singleton so reference equality
|
||||||
|
* is satisfied when the values are the same.
|
||||||
|
*
|
||||||
|
* @param value value to be wrapped as GetSearchAllLibrariesFlattenSeasons
|
||||||
|
*/
|
||||||
|
public static GetSearchAllLibrariesFlattenSeasons of(String value) {
|
||||||
|
synchronized (GetSearchAllLibrariesFlattenSeasons.class) {
|
||||||
|
return values.computeIfAbsent(value, v -> new GetSearchAllLibrariesFlattenSeasons(v));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String value() {
|
public String value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Optional<GetSearchAllLibrariesFlattenSeasons> fromValue(String value) {
|
public Optional<GetSearchAllLibrariesFlattenSeasonsEnum> asEnum() {
|
||||||
for (GetSearchAllLibrariesFlattenSeasons o: GetSearchAllLibrariesFlattenSeasons.values()) {
|
return Optional.ofNullable(enums.getOrDefault(value, null));
|
||||||
if (Objects.deepEquals(o.value, value)) {
|
}
|
||||||
return Optional.of(o);
|
|
||||||
}
|
public boolean isKnown() {
|
||||||
|
return asEnum().isPresent();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(java.lang.Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
GetSearchAllLibrariesFlattenSeasons other = (GetSearchAllLibrariesFlattenSeasons) obj;
|
||||||
|
return Objects.equals(value, other.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GetSearchAllLibrariesFlattenSeasons [value=" + value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
// return an array just like an enum
|
||||||
|
public static GetSearchAllLibrariesFlattenSeasons[] values() {
|
||||||
|
synchronized (GetSearchAllLibrariesFlattenSeasons.class) {
|
||||||
|
return values.values().toArray(new GetSearchAllLibrariesFlattenSeasons[] {});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesFlattenSeasons> createValuesMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesFlattenSeasons> map = new LinkedHashMap<>();
|
||||||
|
map.put("-1", LibraryDefault);
|
||||||
|
map.put("0", Hide);
|
||||||
|
map.put("1", Show);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<String, GetSearchAllLibrariesFlattenSeasonsEnum> createEnumsMap() {
|
||||||
|
Map<String, GetSearchAllLibrariesFlattenSeasonsEnum> map = new HashMap<>();
|
||||||
|
map.put("-1", GetSearchAllLibrariesFlattenSeasonsEnum.LibraryDefault);
|
||||||
|
map.put("0", GetSearchAllLibrariesFlattenSeasonsEnum.Hide);
|
||||||
|
map.put("1", GetSearchAllLibrariesFlattenSeasonsEnum.Show);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Serializer extends StdSerializer<GetSearchAllLibrariesFlattenSeasons> {
|
||||||
|
|
||||||
|
protected _Serializer() {
|
||||||
|
super(GetSearchAllLibrariesFlattenSeasons.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void serialize(GetSearchAllLibrariesFlattenSeasons value, JsonGenerator g, SerializerProvider provider)
|
||||||
|
throws IOException, JsonProcessingException {
|
||||||
|
g.writeObject(value.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public static final class _Deserializer extends StdDeserializer<GetSearchAllLibrariesFlattenSeasons> {
|
||||||
|
|
||||||
|
protected _Deserializer() {
|
||||||
|
super(GetSearchAllLibrariesFlattenSeasons.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public GetSearchAllLibrariesFlattenSeasons deserialize(JsonParser p, DeserializationContext ctxt)
|
||||||
|
throws IOException, JacksonException {
|
||||||
|
String v = p.readValueAs(new TypeReference<String>() {});
|
||||||
|
// use the factory method to ensure we get singletons
|
||||||
|
return GetSearchAllLibrariesFlattenSeasons.of(v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum GetSearchAllLibrariesFlattenSeasonsEnum {
|
||||||
|
|
||||||
|
LibraryDefault("-1"),
|
||||||
|
Hide("0"),
|
||||||
|
Show("1"),;
|
||||||
|
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private GetSearchAllLibrariesFlattenSeasonsEnum(String value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value() {
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user