/*
 * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
 */

import * as z from "zod/v3";
import * as components from "../components/index.js";
import { UnkeyError } from "./unkeyerror.js";

/**
 * Error response when the request is syntactically valid but cannot be processed due to semantic constraints or resource limitations. This occurs when:
 *
 * @remarks
 * - A query exceeds execution time limits
 * - A query uses more memory than allowed
 * - A query scans too many rows
 * - A query result exceeds size limits
 *
 * The request syntax is correct, but the operation cannot be completed due to business rules or resource constraints. Review the error details for specific limitations and adjust your request accordingly.
 */
export type UnprocessableEntityErrorResponseData = {
  /**
   * Metadata object included in every API response. This provides context about the request and is essential for debugging, audit trails, and support inquiries. The `requestId` is particularly important when troubleshooting issues with the Unkey support team.
   */
  meta: components.Meta;
  /**
   * Base error structure following Problem Details for HTTP APIs (RFC 7807). This provides a standardized way to carry machine-readable details of errors in HTTP response content.
   */
  error: components.BaseError;
};

/**
 * Error response when the request is syntactically valid but cannot be processed due to semantic constraints or resource limitations. This occurs when:
 *
 * @remarks
 * - A query exceeds execution time limits
 * - A query uses more memory than allowed
 * - A query scans too many rows
 * - A query result exceeds size limits
 *
 * The request syntax is correct, but the operation cannot be completed due to business rules or resource constraints. Review the error details for specific limitations and adjust your request accordingly.
 */
export class UnprocessableEntityErrorResponse extends UnkeyError {
  /**
   * Metadata object included in every API response. This provides context about the request and is essential for debugging, audit trails, and support inquiries. The `requestId` is particularly important when troubleshooting issues with the Unkey support team.
   */
  meta: components.Meta;
  /**
   * Base error structure following Problem Details for HTTP APIs (RFC 7807). This provides a standardized way to carry machine-readable details of errors in HTTP response content.
   */
  error: components.BaseError;

  /** The original data that was passed to this error instance. */
  data$: UnprocessableEntityErrorResponseData;

  constructor(
    err: UnprocessableEntityErrorResponseData,
    httpMeta: { response: Response; request: Request; body: string },
  ) {
    const message = "message" in err && typeof err.message === "string"
      ? err.message
      : `API error occurred: ${JSON.stringify(err)}`;
    super(message, httpMeta);
    this.data$ = err;
    this.meta = err.meta;
    this.error = err.error;

    this.name = "UnprocessableEntityErrorResponse";
  }
}

/** @internal */
export const UnprocessableEntityErrorResponse$inboundSchema: z.ZodType<
  UnprocessableEntityErrorResponse,
  z.ZodTypeDef,
  unknown
> = z.object({
  meta: components.Meta$inboundSchema,
  error: components.BaseError$inboundSchema,
  request$: z.instanceof(Request),
  response$: z.instanceof(Response),
  body$: z.string(),
})
  .transform((v) => {
    return new UnprocessableEntityErrorResponse(v, {
      request: v.request$,
      response: v.response$,
      body: v.body$,
    });
  });
