UNPKG

@respeecher/respeecher-js

Version:

[![fern shield](https://img.shields.io/badge/%F0%9F%8C%BF-Built%20with%20Fern-brightgreen)](https://buildwithfern.com?utm_source=github&utm_medium=github&utm_campaign=readme&utm_source=https%3A%2F%2Fgithub.com%2Frespeecher%2Frespeecher-js) [![npm shield](

165 lines (164 loc) 9.69 kB
/** * This file was auto-generated by Fern from our API Definition. */ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; import * as environments from "../../../../environments.mjs"; import * as core from "../../../../core/index.mjs"; import { mergeHeaders, mergeOnlyDefinedHeaders } from "../../../../core/headers.mjs"; import * as serializers from "../../../../serialization/index.mjs"; import urlJoin from "url-join"; import * as errors from "../../../../errors/index.mjs"; import * as qs from "qs"; import { TtsSocket } from "./Socket.mjs"; export class Tts { constructor(_options = {}) { this._options = _options; } /** * The easiest way to generate text-to-speech audio. Not suitable for latency-sensitive applications. */ bytes(request, requestOptions) { return core.HttpResponsePromise.fromPromise(this.__bytes(request, requestOptions)); } __bytes(request, requestOptions) { return __awaiter(this, void 0, void 0, function* () { var _a, _b, _c; const _response = yield core.fetcher({ url: urlJoin((_a = (yield core.Supplier.get(this._options.baseUrl))) !== null && _a !== void 0 ? _a : ((_b = (yield core.Supplier.get(this._options.environment))) !== null && _b !== void 0 ? _b : environments.RespeecherEnvironment.PublicEnRt).base, "/tts/bytes"), method: "POST", headers: mergeHeaders((_c = this._options) === null || _c === void 0 ? void 0 : _c.headers, mergeOnlyDefinedHeaders(Object.assign({}, (yield this._getCustomAuthorizationHeaders()))), requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers), contentType: "application/json", requestType: "json", body: serializers.tts.BytesGenerationRequest.jsonOrThrow(request, { unrecognizedObjectKeys: "strip", omitUndefined: true, }), responseType: "streaming", timeoutMs: (requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.timeoutInSeconds) != null ? requestOptions.timeoutInSeconds * 1000 : 60000, maxRetries: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.maxRetries, abortSignal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal, }); if (_response.ok) { return { data: _response.body, rawResponse: _response.rawResponse }; } if (_response.error.reason === "status-code") { throw new errors.RespeecherError({ statusCode: _response.error.statusCode, body: _response.error.body, rawResponse: _response.rawResponse, }); } switch (_response.error.reason) { case "non-json": throw new errors.RespeecherError({ statusCode: _response.error.statusCode, body: _response.error.rawBody, rawResponse: _response.rawResponse, }); case "timeout": throw new errors.RespeecherTimeoutError("Timeout exceeded when calling POST /tts/bytes."); case "unknown": throw new errors.RespeecherError({ message: _response.error.errorMessage, rawResponse: _response.rawResponse, }); } }); } /** * Stream text-to-speech audio as JSONL (JSON lines) objects over HTTP. A less performant alternative to WebSockets, without text input streaming. */ sse(request, requestOptions) { return core.HttpResponsePromise.fromPromise(this.__sse(request, requestOptions)); } __sse(request, requestOptions) { return __awaiter(this, void 0, void 0, function* () { var _a, _b, _c; const _response = yield core.fetcher({ url: urlJoin((_a = (yield core.Supplier.get(this._options.baseUrl))) !== null && _a !== void 0 ? _a : ((_b = (yield core.Supplier.get(this._options.environment))) !== null && _b !== void 0 ? _b : environments.RespeecherEnvironment.PublicEnRt).base, "/tts/sse"), method: "POST", headers: mergeHeaders((_c = this._options) === null || _c === void 0 ? void 0 : _c.headers, mergeOnlyDefinedHeaders(Object.assign({}, (yield this._getCustomAuthorizationHeaders()))), requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers), contentType: "application/json", requestType: "json", body: serializers.tts.StreamingGenerationRequest.jsonOrThrow(request, { unrecognizedObjectKeys: "strip", omitUndefined: true, }), responseType: "sse", timeoutMs: (requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.timeoutInSeconds) != null ? requestOptions.timeoutInSeconds * 1000 : 60000, maxRetries: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.maxRetries, abortSignal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal, }); if (_response.ok) { return { data: new core.Stream({ stream: _response.body, parse: (data) => __awaiter(this, void 0, void 0, function* () { return serializers.tts.ServerSentEvent.parseOrThrow(data, { unrecognizedObjectKeys: "passthrough", allowUnrecognizedUnionMembers: true, allowUnrecognizedEnumValues: true, skipValidation: true, breadcrumbsPrefix: ["response"], }); }), signal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal, eventShape: { type: "json", messageTerminator: "\n", }, }), rawResponse: _response.rawResponse, }; } if (_response.error.reason === "status-code") { throw new errors.RespeecherError({ statusCode: _response.error.statusCode, body: _response.error.body, rawResponse: _response.rawResponse, }); } switch (_response.error.reason) { case "non-json": throw new errors.RespeecherError({ statusCode: _response.error.statusCode, body: _response.error.rawBody, rawResponse: _response.rawResponse, }); case "timeout": throw new errors.RespeecherTimeoutError("Timeout exceeded when calling POST /tts/sse."); case "unknown": throw new errors.RespeecherError({ message: _response.error.errorMessage, rawResponse: _response.rawResponse, }); } }); } connect() { return __awaiter(this, arguments, void 0, function* (args = {}) { var _a, _b, _c, _d; const queryParams = {}; let websocketHeaders = {}; websocketHeaders = Object.assign(Object.assign({}, websocketHeaders), (yield this._getCustomAuthorizationHeaders())); websocketHeaders = Object.assign(Object.assign({}, websocketHeaders), args["headers"]); const socket = new core.ReconnectingWebSocket(`${(_a = (yield core.Supplier.get(this._options["baseUrl"]))) !== null && _a !== void 0 ? _a : ((_b = (yield core.Supplier.get(this._options["environment"]))) !== null && _b !== void 0 ? _b : environments.RespeecherEnvironment.PublicEnRt).ws}/tts/websocket?${qs.stringify(queryParams, { arrayFormat: "repeat" })}`, [], { debug: (_c = args["debug"]) !== null && _c !== void 0 ? _c : false, maxRetries: (_d = args["reconnectAttempts"]) !== null && _d !== void 0 ? _d : 30 }, websocketHeaders); return new TtsSocket({ socket }); }); } _getCustomAuthorizationHeaders() { return __awaiter(this, void 0, void 0, function* () { var _a; const apiKeyValue = (_a = (yield core.Supplier.get(this._options.apiKey))) !== null && _a !== void 0 ? _a : process === null || process === void 0 ? void 0 : process.env["RESPEECHER_API_KEY"]; return { "X-API-Key": apiKeyValue }; }); } }