Edits history of script submission #20124 for ' Replace Permissions for User (segment)'

  • bun
    One script reply has been approved by the moderators
    Ap­pro­ved
    //native
    type Segment = {
      token: string;
      baseUrl: string;
    };
    /**
     * Replace Permissions for User
     * Updates the list of access permissions for a user.
    
    
    
    • When called, this endpoint may generate the `Policy Deleted` event in the audit trail.
          
    
    
    The rate limit for this endpoint is 60 requests per minute, which is lower than the default due to access pattern restrictions. Once reached, this endpoint will respond with the 429 HTTP status code with headers indicating the limit parameters. See Rate Limiting for more information.
     */
    export async function main(
      auth: Segment,
      userId: string,
      body: {
        permissions: {
          roleId: string;
          resources: {
            id: string;
            type: "FUNCTION" | "SOURCE" | "SPACE" | "WAREHOUSE" | "WORKSPACE";
            labels?: { key: string; value: string; description?: string }[];
          }[];
        }[];
      },
    ) {
      const url = new URL(
        `${auth.baseUrl}/users/${userId}/permissions`,
      );
    
      const response = await fetch(url, {
        method: "PUT",
        headers: {
          "Content-Type": "application/json",
          Authorization: "Bearer " + auth.token,
        },
        body: JSON.stringify(body),
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    

    Submitted by hugo697 235 days ago