@space-cow-media/spellbook-client
Version:
An Open Api generated client for the Commander Spellbook backend REST API.
158 lines (128 loc) • 5.26 kB
text/typescript
/* tslint:disable */
/* eslint-disable */
/**
* Commander Spellbook API
* API for Commander Spellbook, the combo database engine for Magic: The Gathering
*
* The version of the OpenAPI document: 4.8.19
*
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
import * as runtime from '../runtime';
import type {
PaginatedVariantList,
Variant,
VariantsQueryValidationError,
} from '../models/index';
import {
PaginatedVariantListFromJSON,
PaginatedVariantListToJSON,
VariantFromJSON,
VariantToJSON,
VariantsQueryValidationErrorFromJSON,
VariantsQueryValidationErrorToJSON,
} from '../models/index';
export interface VariantsListRequest {
groupByCombo?: boolean;
limit?: number;
offset?: number;
ordering?: string;
q?: string;
variant?: string;
}
export interface VariantsRetrieveRequest {
id: string;
}
/**
*
*/
export class VariantsApi extends runtime.BaseAPI {
/**
*/
async variantsListRaw(requestParameters: VariantsListRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<PaginatedVariantList>> {
const queryParameters: any = {};
if (requestParameters['groupByCombo'] != null) {
queryParameters['groupByCombo'] = requestParameters['groupByCombo'];
}
if (requestParameters['limit'] != null) {
queryParameters['limit'] = requestParameters['limit'];
}
if (requestParameters['offset'] != null) {
queryParameters['offset'] = requestParameters['offset'];
}
if (requestParameters['ordering'] != null) {
queryParameters['ordering'] = requestParameters['ordering'];
}
if (requestParameters['q'] != null) {
queryParameters['q'] = requestParameters['q'];
}
if (requestParameters['variant'] != null) {
queryParameters['variant'] = requestParameters['variant'];
}
const headerParameters: runtime.HTTPHeaders = {};
if (this.configuration && (this.configuration.username !== undefined || this.configuration.password !== undefined)) {
headerParameters["Authorization"] = "Basic " + btoa(this.configuration.username + ":" + this.configuration.password);
}
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("jwtAuth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
let urlPath = `/variants/`;
const response = await this.request({
path: urlPath,
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => PaginatedVariantListFromJSON(jsonValue));
}
/**
*/
async variantsList(requestParameters: VariantsListRequest = {}, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<PaginatedVariantList> {
const response = await this.variantsListRaw(requestParameters, initOverrides);
return await response.value();
}
/**
*/
async variantsRetrieveRaw(requestParameters: VariantsRetrieveRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<Variant>> {
if (requestParameters['id'] == null) {
throw new runtime.RequiredError(
'id',
'Required parameter "id" was null or undefined when calling variantsRetrieve().'
);
}
const queryParameters: any = {};
const headerParameters: runtime.HTTPHeaders = {};
if (this.configuration && (this.configuration.username !== undefined || this.configuration.password !== undefined)) {
headerParameters["Authorization"] = "Basic " + btoa(this.configuration.username + ":" + this.configuration.password);
}
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("jwtAuth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
let urlPath = `/variants/{id}/`;
urlPath = urlPath.replace(`{${"id"}}`, encodeURIComponent(String(requestParameters['id'])));
const response = await this.request({
path: urlPath,
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => VariantFromJSON(jsonValue));
}
/**
*/
async variantsRetrieve(requestParameters: VariantsRetrieveRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<Variant> {
const response = await this.variantsRetrieveRaw(requestParameters, initOverrides);
return await response.value();
}
}