/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. */ import * as z from "zod/v3"; import { remap as remap$ } from "../../lib/primitives.js"; import { safeParse } from "../../lib/schemas.js"; import { ClosedEnum } from "../../types/enums.js"; import { Result as SafeParseResult } from "../../types/fp.js"; import { HTTPMetadata, HTTPMetadata$inboundSchema, } from "../components/httpmetadata.js"; import { Location, Location$inboundSchema } from "../components/location.js"; import { SDKValidationError } from "../errors/sdkvalidationerror.js"; /** * Determines the date-based API version associated with your API call. If none is provided, your application's [minimum API version](https://docs.gusto.com/embedded-payroll/docs/api-versioning#minimum-api-version) is used. */ export const PutV1LocationsLocationIdHeaderXGustoAPIVersion = { TwoThousandAndTwentyFiveMinus06Minus15: "2025-06-15", } as const; /** * Determines the date-based API version associated with your API call. If none is provided, your application's [minimum API version](https://docs.gusto.com/embedded-payroll/docs/api-versioning#minimum-api-version) is used. */ export type PutV1LocationsLocationIdHeaderXGustoAPIVersion = ClosedEnum< typeof PutV1LocationsLocationIdHeaderXGustoAPIVersion >; export type PutV1LocationsLocationIdRequestBody = { /** * The current version of the object. See the [versioning guide](https://docs.gusto.com/embedded-payroll/docs/idempotency) for information on how to use this field. */ version: string; phoneNumber?: string | undefined; street1?: string | undefined; street2?: string | null | undefined; city?: string | undefined; state?: string | undefined; zip?: string | undefined; country?: string | undefined; /** * For a company location, specify if this location is the company's mailing address. A company has a single mailing address, so this designation will override any previous selection. */ mailingAddress?: boolean | undefined; /** * For a company location, specify if this location is the company's filing address. A company has a single filing address, so this designation will override any previous selection. */ filingAddress?: boolean | undefined; }; export type PutV1LocationsLocationIdRequest = { /** * Determines the date-based API version associated with your API call. If none is provided, your application's [minimum API version](https://docs.gusto.com/embedded-payroll/docs/api-versioning#minimum-api-version) is used. */ xGustoAPIVersion?: PutV1LocationsLocationIdHeaderXGustoAPIVersion | undefined; /** * The UUID of the location */ locationId: string; requestBody: PutV1LocationsLocationIdRequestBody; }; export type PutV1LocationsLocationIdResponse = { httpMeta: HTTPMetadata; /** * successful */ location?: Location | undefined; }; /** @internal */ export const PutV1LocationsLocationIdHeaderXGustoAPIVersion$outboundSchema: z.ZodNativeEnum = z .nativeEnum(PutV1LocationsLocationIdHeaderXGustoAPIVersion); /** @internal */ export type PutV1LocationsLocationIdRequestBody$Outbound = { version: string; phone_number?: string | undefined; street_1?: string | undefined; street_2?: string | null | undefined; city?: string | undefined; state?: string | undefined; zip?: string | undefined; country?: string | undefined; mailing_address?: boolean | undefined; filing_address?: boolean | undefined; }; /** @internal */ export const PutV1LocationsLocationIdRequestBody$outboundSchema: z.ZodType< PutV1LocationsLocationIdRequestBody$Outbound, z.ZodTypeDef, PutV1LocationsLocationIdRequestBody > = z.object({ version: z.string(), phoneNumber: z.string().optional(), street1: z.string().optional(), street2: z.nullable(z.string()).optional(), city: z.string().optional(), state: z.string().optional(), zip: z.string().optional(), country: z.string().optional(), mailingAddress: z.boolean().optional(), filingAddress: z.boolean().optional(), }).transform((v) => { return remap$(v, { phoneNumber: "phone_number", street1: "street_1", street2: "street_2", mailingAddress: "mailing_address", filingAddress: "filing_address", }); }); export function putV1LocationsLocationIdRequestBodyToJSON( putV1LocationsLocationIdRequestBody: PutV1LocationsLocationIdRequestBody, ): string { return JSON.stringify( PutV1LocationsLocationIdRequestBody$outboundSchema.parse( putV1LocationsLocationIdRequestBody, ), ); } /** @internal */ export type PutV1LocationsLocationIdRequest$Outbound = { "X-Gusto-API-Version": string; location_id: string; RequestBody: PutV1LocationsLocationIdRequestBody$Outbound; }; /** @internal */ export const PutV1LocationsLocationIdRequest$outboundSchema: z.ZodType< PutV1LocationsLocationIdRequest$Outbound, z.ZodTypeDef, PutV1LocationsLocationIdRequest > = z.object({ xGustoAPIVersion: PutV1LocationsLocationIdHeaderXGustoAPIVersion$outboundSchema.default( "2025-06-15", ), locationId: z.string(), requestBody: z.lazy(() => PutV1LocationsLocationIdRequestBody$outboundSchema), }).transform((v) => { return remap$(v, { xGustoAPIVersion: "X-Gusto-API-Version", locationId: "location_id", requestBody: "RequestBody", }); }); export function putV1LocationsLocationIdRequestToJSON( putV1LocationsLocationIdRequest: PutV1LocationsLocationIdRequest, ): string { return JSON.stringify( PutV1LocationsLocationIdRequest$outboundSchema.parse( putV1LocationsLocationIdRequest, ), ); } /** @internal */ export const PutV1LocationsLocationIdResponse$inboundSchema: z.ZodType< PutV1LocationsLocationIdResponse, z.ZodTypeDef, unknown > = z.object({ HttpMeta: HTTPMetadata$inboundSchema, Location: Location$inboundSchema.optional(), }).transform((v) => { return remap$(v, { "HttpMeta": "httpMeta", "Location": "location", }); }); export function putV1LocationsLocationIdResponseFromJSON( jsonString: string, ): SafeParseResult { return safeParse( jsonString, (x) => PutV1LocationsLocationIdResponse$inboundSchema.parse(JSON.parse(x)), `Failed to parse 'PutV1LocationsLocationIdResponse' from JSON`, ); }