UNPKG

@azure/storage-file-datalake

Version:
143 lines 4.69 kB
// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. /** * This is a helper class to construct a string representing the permissions granted by a ServiceSAS to a container. * Setting a value to true means that any SAS which uses these permissions will grant permissions for that operation. * Once all the values are set, this should be serialized with toString and set as the permissions field on a * {@link DataLakeSASSignatureValues} object. It is possible to construct the permissions string without this class, but * the order of the permissions is particular and this class guarantees correctness. */ export class FileSystemSASPermissions { /** * Creates an {@link FileSystemSASPermissions} from the specified permissions string. This method will throw an * Error if it encounters a character that does not correspond to a valid permission. * * @param permissions - */ static parse(permissions) { const containerSASPermissions = new FileSystemSASPermissions(); for (const char of permissions) { switch (char) { case "r": containerSASPermissions.read = true; break; case "a": containerSASPermissions.add = true; break; case "c": containerSASPermissions.create = true; break; case "w": containerSASPermissions.write = true; break; case "d": containerSASPermissions.delete = true; break; case "l": containerSASPermissions.list = true; break; case "m": containerSASPermissions.move = true; break; case "e": containerSASPermissions.execute = true; break; case "o": containerSASPermissions.manageOwnership = true; break; case "p": containerSASPermissions.manageAccessControl = true; break; default: throw new RangeError(`Invalid permission ${char}`); } } return containerSASPermissions; } /** * Specifies Read access granted. */ read = false; /** * Specifies Add access granted. */ add = false; /** * Specifies Create access granted. */ create = false; /** * Specifies Write access granted. */ write = false; /** * Specifies Delete access granted. */ delete = false; /** * Specifies List access granted. */ list = false; /** * Specifies Move access granted. */ move = false; /** * Specifies Execute access granted. */ execute = false; /** * Specifies Ownership access granted, which allows the caller to set owner, owning group, * or act as the owner when renaming or deleting a blob (file or directory) within a folder * that has the sticky bit set. */ manageOwnership = false; /** * Specifies Permission access granted, which allows the caller to set permissions and * POSIX ACLs on blobs (files and directories). */ manageAccessControl = false; /** * Converts the given permissions to a string. Using this method will guarantee the permissions are in an * order accepted by the service. * * The order of the characters should be as specified here to ensure correctness. * @see https://learn.microsoft.com/rest/api/storageservices/constructing-a-service-sas * */ toString() { const permissions = []; if (this.read) { permissions.push("r"); } if (this.add) { permissions.push("a"); } if (this.create) { permissions.push("c"); } if (this.write) { permissions.push("w"); } if (this.delete) { permissions.push("d"); } if (this.list) { permissions.push("l"); } if (this.move) { permissions.push("m"); } if (this.execute) { permissions.push("e"); } if (this.manageOwnership) { permissions.push("o"); } if (this.manageAccessControl) { permissions.push("p"); } return permissions.join(""); } } //# sourceMappingURL=FileSystemSASPermissions.js.map