/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. */ import * as z from "zod"; import { remap as remap$ } from "../../lib/primitives.js"; import { safeParse } from "../../lib/schemas.js"; import { Result as SafeParseResult } from "../../types/fp.js"; import { SDKValidationError } from "./sdkvalidationerror.js"; /** * Contains parameter or domain specific information related to the error and why it occurred. */ export type NotFoundResponseDetail = string | { [k: string]: any }; /** * The specified resource was not found */ export type NotFoundResponseData = { /** * HTTP status code */ statusCode?: number | undefined; /** * Contains an explanation of the status_code as defined in HTTP/1.1 standard (RFC 7231) */ error?: string | undefined; /** * The type of error returned */ typeName?: string | undefined; /** * A human-readable message providing more details about the error. */ message?: string | undefined; /** * Contains parameter or domain specific information related to the error and why it occurred. */ detail?: string | { [k: string]: any } | undefined; /** * Link to documentation of error type */ ref?: string | undefined; }; /** * The specified resource was not found */ export class NotFoundResponse extends Error { /** * HTTP status code */ statusCode?: number | undefined; /** * Contains an explanation of the status_code as defined in HTTP/1.1 standard (RFC 7231) */ error?: string | undefined; /** * The type of error returned */ typeName?: string | undefined; /** * Contains parameter or domain specific information related to the error and why it occurred. */ detail?: string | { [k: string]: any } | undefined; /** * Link to documentation of error type */ ref?: string | undefined; /** The original data that was passed to this error instance. */ data$: NotFoundResponseData; constructor(err: NotFoundResponseData) { const message = err.message || "API error occurred"; super(message); this.data$ = err; if (err.statusCode != null) this.statusCode = err.statusCode; if (err.error != null) this.error = err.error; if (err.typeName != null) this.typeName = err.typeName; if (err.detail != null) this.detail = err.detail; if (err.ref != null) this.ref = err.ref; this.name = "NotFoundResponse"; } } /** @internal */ export const NotFoundResponseDetail$inboundSchema: z.ZodType< NotFoundResponseDetail, z.ZodTypeDef, unknown > = z.union([z.string(), z.record(z.any())]); /** @internal */ export type NotFoundResponseDetail$Outbound = string | { [k: string]: any }; /** @internal */ export const NotFoundResponseDetail$outboundSchema: z.ZodType< NotFoundResponseDetail$Outbound, z.ZodTypeDef, NotFoundResponseDetail > = z.union([z.string(), z.record(z.any())]); /** * @internal * @deprecated This namespace will be removed in future versions. Use schemas and types that are exported directly from this module. */ export namespace NotFoundResponseDetail$ { /** @deprecated use `NotFoundResponseDetail$inboundSchema` instead. */ export const inboundSchema = NotFoundResponseDetail$inboundSchema; /** @deprecated use `NotFoundResponseDetail$outboundSchema` instead. */ export const outboundSchema = NotFoundResponseDetail$outboundSchema; /** @deprecated use `NotFoundResponseDetail$Outbound` instead. */ export type Outbound = NotFoundResponseDetail$Outbound; } export function notFoundResponseDetailToJSON( notFoundResponseDetail: NotFoundResponseDetail, ): string { return JSON.stringify( NotFoundResponseDetail$outboundSchema.parse(notFoundResponseDetail), ); } export function notFoundResponseDetailFromJSON( jsonString: string, ): SafeParseResult { return safeParse( jsonString, (x) => NotFoundResponseDetail$inboundSchema.parse(JSON.parse(x)), `Failed to parse 'NotFoundResponseDetail' from JSON`, ); } /** @internal */ export const NotFoundResponse$inboundSchema: z.ZodType< NotFoundResponse, z.ZodTypeDef, unknown > = z.object({ status_code: z.number().optional(), error: z.string().optional(), type_name: z.string().optional(), message: z.string().optional(), detail: z.union([z.string(), z.record(z.any())]).optional(), ref: z.string().optional(), }) .transform((v) => { const remapped = remap$(v, { "status_code": "statusCode", "type_name": "typeName", }); return new NotFoundResponse(remapped); }); /** @internal */ export type NotFoundResponse$Outbound = { status_code?: number | undefined; error?: string | undefined; type_name?: string | undefined; message?: string | undefined; detail?: string | { [k: string]: any } | undefined; ref?: string | undefined; }; /** @internal */ export const NotFoundResponse$outboundSchema: z.ZodType< NotFoundResponse$Outbound, z.ZodTypeDef, NotFoundResponse > = z.instanceof(NotFoundResponse) .transform(v => v.data$) .pipe( z.object({ statusCode: z.number().optional(), error: z.string().optional(), typeName: z.string().optional(), message: z.string().optional(), detail: z.union([z.string(), z.record(z.any())]).optional(), ref: z.string().optional(), }).transform((v) => { return remap$(v, { statusCode: "status_code", typeName: "type_name", }); }), ); /** * @internal * @deprecated This namespace will be removed in future versions. Use schemas and types that are exported directly from this module. */ export namespace NotFoundResponse$ { /** @deprecated use `NotFoundResponse$inboundSchema` instead. */ export const inboundSchema = NotFoundResponse$inboundSchema; /** @deprecated use `NotFoundResponse$outboundSchema` instead. */ export const outboundSchema = NotFoundResponse$outboundSchema; /** @deprecated use `NotFoundResponse$Outbound` instead. */ export type Outbound = NotFoundResponse$Outbound; }