declare module "table-reservations-v1-custom-reservations-approval" { type BusinessError = { __tag: 'BusinessError'; httpCode: string; errorDescription: string; applicationCode: string; messageSchema: string; data: T; }; interface GetTimeSlotsRequiringApprovalRequest { /** Party size. */ partySize?: number; /** Reservation location. */ reservationLocation?: ReservationLocation; /** Start dates. */ startDates?: Date[]; } interface ReservationLocation { /** ID. */ _id?: string; } interface GetTimeSlotsRequiringApprovalResponse { /** Start dates requiring approval. */ startDatesRequiringApproval?: Date[]; } interface CustomReservationsApprovalConfig { /** URI where the SPI Implementer is deployed */ uriConfig?: SpiBaseUri; name?: string; } interface SpiBaseUri { /** URI that will be used by the host to call the implementer. The path-suffix defined on the method will be appended to it */ baseUri?: string; /** override method mappings per method */ alternativeUris?: AlternativeUri[]; } interface AlternativeUri { /** name of the method as it appears in the proto */ methodName?: string; /** absolute uri that will be used by the host to call that method. The path-suffix mapped from the method http option will NOT be appended to this URI. For TPAs. it must be https */ absoluteUri?: string; } /** * this message is not directly used by any service, * it exists to describe the expected parameters that SHOULD be provided to invoked Velo methods as part of open-platform. * e.g. SPIs, event-handlers, etc.. * NOTE: this context object MUST be provided as the last argument in each Velo method signature. * * Example: * ```typescript * export function wixStores_onOrderCanceled(event: OrderCanceledEvent, context: Context) { * ... * } * ``` */ interface Context { /** A unique identifier for each request. Can be used for logging / troubleshooting */ requestId?: string | null; /** 3 capital letters string representing a currency according to ISO-4217 */ currency?: string | null; /** The identification type and identity data */ identity?: IdentificationData; /** A string representing a language and region in the format of "xx-XX". First 2 letters represent the language code according to ISO 639-1. This is followed by a dash "-", and then a by 2 capital letters representing the region according to ISO 3166-2 */ languages?: string[]; /** App instance ID of SPI in context */ instanceId?: string | null; } enum IdentityType { UNKNOWN = "UNKNOWN", ANONYMOUS_VISITOR = "ANONYMOUS_VISITOR", MEMBER = "MEMBER", WIX_USER = "WIX_USER", APP = "APP" } interface IdentificationData extends IdentificationDataIdOneOf { /** ID of a site visitor that has not logged in to the site. */ anonymousVisitorId?: string; /** ID of a site visitor that has logged in to the site. */ memberId?: string; /** ID of a Wix user (site owner, contributor, etc.). */ wixUserId?: string; /** ID of an app. */ appId?: string; /** @readonly */ identityType?: IdentityType; } /** @oneof */ interface IdentificationDataIdOneOf { /** ID of a site visitor that has not logged in to the site. */ anonymousVisitorId?: string; /** ID of a site visitor that has logged in to the site. */ memberId?: string; /** ID of a Wix user (site owner, contributor, etc.). */ wixUserId?: string; /** ID of an app. */ appId?: string; } interface GetTimeSlotsRequiringApprovalOptions { /** Party size. */ partySize?: number; /** Reservation location. */ reservationLocation?: ReservationLocation; /** Start dates. */ startDates?: Date[]; } export { AlternativeUri, BusinessError, Context, CustomReservationsApprovalConfig, GetTimeSlotsRequiringApprovalOptions, GetTimeSlotsRequiringApprovalRequest, GetTimeSlotsRequiringApprovalResponse, IdentificationData, IdentificationDataIdOneOf, IdentityType, ReservationLocation, SpiBaseUri }; }