@mikle7/litty-api-client
Version:
TypeScript client for Litty API with clean, semantic type definitions
241 lines (240 loc) • 11.9 kB
JavaScript
;
/* tslint:disable */
/* eslint-disable */
/**
* Litty API
* Complete API documentation for the Litty platform. ## Authentication Most endpoints require authentication via Supabase JWT tokens. Include the token in the Authorization header: `Bearer <token>` ## API Structure - **Contests**: Create and manage contests, entries, and settlements - **Markets**: Manage prediction markets within contests - **Transactions**: Handle financial transactions for contest entries and rewards - **Wallet**: Manage user wallet balances (cashable, points, tickets) - **Users**: User management and profiles - **Leaderboards**: Competition rankings and scoring - **Uploads**: File upload management - **Shows**: TV show and episode management (admin only) ## Response Formats All endpoints return JSON responses with consistent error handling. Error responses include `statusCode`, `message`, and `error` fields.
*
* The version of the OpenAPI document: 1.0
*
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.GetTransactionsByStatusStatusEnum = exports.TransactionsApi = void 0;
const runtime = __importStar(require("../runtime"));
const index_1 = require("../models/index");
/**
*
*/
class TransactionsApi extends runtime.BaseAPI {
/**
* Retrieve detailed information about a specific transaction including its status, amounts, and metadata.
* Get transaction by ID
*/
async getTransactionRaw(requestParameters, initOverrides) {
if (requestParameters['id'] == null) {
throw new runtime.RequiredError('id', 'Required parameter "id" was null or undefined when calling getTransaction().');
}
const queryParameters = {};
const headerParameters = {};
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("JWT-auth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
const response = await this.request({
path: `/transactions/{id}`.replace(`{${"id"}}`, encodeURIComponent(String(requestParameters['id']))),
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => (0, index_1.TransactionResponseDtoFromJSON)(jsonValue));
}
/**
* Retrieve detailed information about a specific transaction including its status, amounts, and metadata.
* Get transaction by ID
*/
async getTransaction(requestParameters, initOverrides) {
const response = await this.getTransactionRaw(requestParameters, initOverrides);
return await response.value();
}
/**
* Retrieve a paginated list of transactions filtered by status, ordered by creation date (newest first).
* Get transactions by status
*/
async getTransactionsByStatusRaw(requestParameters, initOverrides) {
if (requestParameters['status'] == null) {
throw new runtime.RequiredError('status', 'Required parameter "status" was null or undefined when calling getTransactionsByStatus().');
}
const queryParameters = {};
if (requestParameters['limit'] != null) {
queryParameters['limit'] = requestParameters['limit'];
}
if (requestParameters['offset'] != null) {
queryParameters['offset'] = requestParameters['offset'];
}
const headerParameters = {};
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("JWT-auth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
const response = await this.request({
path: `/transactions/status/{status}`.replace(`{${"status"}}`, encodeURIComponent(String(requestParameters['status']))),
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => (0, index_1.GetUserTransactions200ResponseFromJSON)(jsonValue));
}
/**
* Retrieve a paginated list of transactions filtered by status, ordered by creation date (newest first).
* Get transactions by status
*/
async getTransactionsByStatus(requestParameters, initOverrides) {
const response = await this.getTransactionsByStatusRaw(requestParameters, initOverrides);
return await response.value();
}
/**
* Retrieve a paginated list of transactions for a specific user, ordered by creation date (newest first).
* Get transactions for a user
*/
async getUserTransactionsRaw(requestParameters, initOverrides) {
if (requestParameters['userId'] == null) {
throw new runtime.RequiredError('userId', 'Required parameter "userId" was null or undefined when calling getUserTransactions().');
}
const queryParameters = {};
if (requestParameters['limit'] != null) {
queryParameters['limit'] = requestParameters['limit'];
}
if (requestParameters['offset'] != null) {
queryParameters['offset'] = requestParameters['offset'];
}
const headerParameters = {};
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("JWT-auth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
const response = await this.request({
path: `/transactions/user/{userId}`.replace(`{${"userId"}}`, encodeURIComponent(String(requestParameters['userId']))),
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => (0, index_1.GetUserTransactions200ResponseFromJSON)(jsonValue));
}
/**
* Retrieve a paginated list of transactions for a specific user, ordered by creation date (newest first).
* Get transactions for a user
*/
async getUserTransactions(requestParameters, initOverrides) {
const response = await this.getUserTransactionsRaw(requestParameters, initOverrides);
return await response.value();
}
/**
* Retrieve a paginated list of transactions for a specific wallet, ordered by creation date (newest first).
* Get transactions for a wallet
*/
async getWalletTransactionsRaw(requestParameters, initOverrides) {
if (requestParameters['walletId'] == null) {
throw new runtime.RequiredError('walletId', 'Required parameter "walletId" was null or undefined when calling getWalletTransactions().');
}
const queryParameters = {};
if (requestParameters['limit'] != null) {
queryParameters['limit'] = requestParameters['limit'];
}
if (requestParameters['offset'] != null) {
queryParameters['offset'] = requestParameters['offset'];
}
const headerParameters = {};
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("JWT-auth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
const response = await this.request({
path: `/transactions/wallet/{walletId}`.replace(`{${"walletId"}}`, encodeURIComponent(String(requestParameters['walletId']))),
method: 'GET',
headers: headerParameters,
query: queryParameters,
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => (0, index_1.GetUserTransactions200ResponseFromJSON)(jsonValue));
}
/**
* Retrieve a paginated list of transactions for a specific wallet, ordered by creation date (newest first).
* Get transactions for a wallet
*/
async getWalletTransactions(requestParameters, initOverrides) {
const response = await this.getWalletTransactionsRaw(requestParameters, initOverrides);
return await response.value();
}
/**
* Create a new transaction that will be validated and processed. This triggers the transaction workflow which may update wallet balances if approved.
* Initiate a new transaction
*/
async initiateTransactionRaw(requestParameters, initOverrides) {
if (requestParameters['createTransactionDto'] == null) {
throw new runtime.RequiredError('createTransactionDto', 'Required parameter "createTransactionDto" was null or undefined when calling initiateTransaction().');
}
const queryParameters = {};
const headerParameters = {};
headerParameters['Content-Type'] = 'application/json';
if (this.configuration && this.configuration.accessToken) {
const token = this.configuration.accessToken;
const tokenString = await token("JWT-auth", []);
if (tokenString) {
headerParameters["Authorization"] = `Bearer ${tokenString}`;
}
}
const response = await this.request({
path: `/transactions`,
method: 'POST',
headers: headerParameters,
query: queryParameters,
body: (0, index_1.CreateTransactionDtoToJSON)(requestParameters['createTransactionDto']),
}, initOverrides);
return new runtime.JSONApiResponse(response, (jsonValue) => (0, index_1.InitiateTransaction201ResponseFromJSON)(jsonValue));
}
/**
* Create a new transaction that will be validated and processed. This triggers the transaction workflow which may update wallet balances if approved.
* Initiate a new transaction
*/
async initiateTransaction(requestParameters, initOverrides) {
const response = await this.initiateTransactionRaw(requestParameters, initOverrides);
return await response.value();
}
}
exports.TransactionsApi = TransactionsApi;
/**
* @export
*/
exports.GetTransactionsByStatusStatusEnum = {
Pending: 'pending',
Completed: 'completed',
Failed: 'failed'
};