/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. * @generated-id: 8da8d63c57d8 */ import * as z from "zod/v3"; import { safeParse } from "../../lib/schemas.js"; import { Result as SafeParseResult } from "../../types/fp.js"; import { SDKValidationError } from "../errors/sdkvalidationerror.js"; import { PermissionsGroupIntersectionDefinition, PermissionsGroupIntersectionDefinition$inboundSchema, PermissionsGroupIntersectionDefinition$Outbound, PermissionsGroupIntersectionDefinition$outboundSchema, } from "./permissionsgroupintersectiondefinition.js"; import { UserReferenceDefinition, UserReferenceDefinition$inboundSchema, UserReferenceDefinition$Outbound, UserReferenceDefinition$outboundSchema, } from "./userreferencedefinition.js"; /** * describes the access control details of the document */ export type DocumentPermissionsDefinition = { /** * List of users who can view the document */ allowedUsers?: Array | undefined; /** * List of groups that can view the document */ allowedGroups?: Array | undefined; /** * List of allowed group intersections. This describes a permissions constraint of the form ((GroupA AND GroupB AND GroupC) OR (GroupX AND GroupY) OR ... */ allowedGroupIntersections?: | Array | undefined; /** * If true, then any Glean user can view the document */ allowAnonymousAccess?: boolean | undefined; /** * If true, then any user who has an account in the datasource can view the document. */ allowAllDatasourceUsersAccess?: boolean | undefined; }; /** @internal */ export const DocumentPermissionsDefinition$inboundSchema: z.ZodType< DocumentPermissionsDefinition, z.ZodTypeDef, unknown > = z.object({ allowedUsers: z.array(UserReferenceDefinition$inboundSchema).optional(), allowedGroups: z.array(z.string()).optional(), allowedGroupIntersections: z.array( PermissionsGroupIntersectionDefinition$inboundSchema, ).optional(), allowAnonymousAccess: z.boolean().optional(), allowAllDatasourceUsersAccess: z.boolean().optional(), }); /** @internal */ export type DocumentPermissionsDefinition$Outbound = { allowedUsers?: Array | undefined; allowedGroups?: Array | undefined; allowedGroupIntersections?: | Array | undefined; allowAnonymousAccess?: boolean | undefined; allowAllDatasourceUsersAccess?: boolean | undefined; }; /** @internal */ export const DocumentPermissionsDefinition$outboundSchema: z.ZodType< DocumentPermissionsDefinition$Outbound, z.ZodTypeDef, DocumentPermissionsDefinition > = z.object({ allowedUsers: z.array(UserReferenceDefinition$outboundSchema).optional(), allowedGroups: z.array(z.string()).optional(), allowedGroupIntersections: z.array( PermissionsGroupIntersectionDefinition$outboundSchema, ).optional(), allowAnonymousAccess: z.boolean().optional(), allowAllDatasourceUsersAccess: z.boolean().optional(), }); export function documentPermissionsDefinitionToJSON( documentPermissionsDefinition: DocumentPermissionsDefinition, ): string { return JSON.stringify( DocumentPermissionsDefinition$outboundSchema.parse( documentPermissionsDefinition, ), ); } export function documentPermissionsDefinitionFromJSON( jsonString: string, ): SafeParseResult { return safeParse( jsonString, (x) => DocumentPermissionsDefinition$inboundSchema.parse(JSON.parse(x)), `Failed to parse 'DocumentPermissionsDefinition' from JSON`, ); }