UNPKG

@google-cloud/iam

Version:
911 lines (841 loc) 1.75 MB
// Copyright 2025 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. /*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/ (function(global, factory) { /* global define, require, module */ /* AMD */ if (typeof define === 'function' && define.amd) define(["protobufjs/minimal"], factory); /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports) module.exports = factory(require("google-gax/build/src/protobuf").protobufMinimal); })(this, function($protobuf) { "use strict"; // Common aliases var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util; // Exported root namespace var $root = $protobuf.roots._google_cloud_iam_protos || ($protobuf.roots._google_cloud_iam_protos = {}); $root.google = (function() { /** * Namespace google. * @exports google * @namespace */ var google = {}; google.iam = (function() { /** * Namespace iam. * @memberof google * @namespace */ var iam = {}; iam.v2 = (function() { /** * Namespace v2. * @memberof google.iam * @namespace */ var v2 = {}; v2.DenyRule = (function() { /** * Properties of a DenyRule. * @memberof google.iam.v2 * @interface IDenyRule * @property {Array.<string>|null} [deniedPrincipals] DenyRule deniedPrincipals * @property {Array.<string>|null} [exceptionPrincipals] DenyRule exceptionPrincipals * @property {Array.<string>|null} [deniedPermissions] DenyRule deniedPermissions * @property {Array.<string>|null} [exceptionPermissions] DenyRule exceptionPermissions * @property {google.type.IExpr|null} [denialCondition] DenyRule denialCondition */ /** * Constructs a new DenyRule. * @memberof google.iam.v2 * @classdesc Represents a DenyRule. * @implements IDenyRule * @constructor * @param {google.iam.v2.IDenyRule=} [properties] Properties to set */ function DenyRule(properties) { this.deniedPrincipals = []; this.exceptionPrincipals = []; this.deniedPermissions = []; this.exceptionPermissions = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) this[keys[i]] = properties[keys[i]]; } /** * DenyRule deniedPrincipals. * @member {Array.<string>} deniedPrincipals * @memberof google.iam.v2.DenyRule * @instance */ DenyRule.prototype.deniedPrincipals = $util.emptyArray; /** * DenyRule exceptionPrincipals. * @member {Array.<string>} exceptionPrincipals * @memberof google.iam.v2.DenyRule * @instance */ DenyRule.prototype.exceptionPrincipals = $util.emptyArray; /** * DenyRule deniedPermissions. * @member {Array.<string>} deniedPermissions * @memberof google.iam.v2.DenyRule * @instance */ DenyRule.prototype.deniedPermissions = $util.emptyArray; /** * DenyRule exceptionPermissions. * @member {Array.<string>} exceptionPermissions * @memberof google.iam.v2.DenyRule * @instance */ DenyRule.prototype.exceptionPermissions = $util.emptyArray; /** * DenyRule denialCondition. * @member {google.type.IExpr|null|undefined} denialCondition * @memberof google.iam.v2.DenyRule * @instance */ DenyRule.prototype.denialCondition = null; /** * Creates a new DenyRule instance using the specified properties. * @function create * @memberof google.iam.v2.DenyRule * @static * @param {google.iam.v2.IDenyRule=} [properties] Properties to set * @returns {google.iam.v2.DenyRule} DenyRule instance */ DenyRule.create = function create(properties) { return new DenyRule(properties); }; /** * Encodes the specified DenyRule message. Does not implicitly {@link google.iam.v2.DenyRule.verify|verify} messages. * @function encode * @memberof google.iam.v2.DenyRule * @static * @param {google.iam.v2.IDenyRule} message DenyRule message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ DenyRule.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); if (message.deniedPrincipals != null && message.deniedPrincipals.length) for (var i = 0; i < message.deniedPrincipals.length; ++i) writer.uint32(/* id 1, wireType 2 =*/10).string(message.deniedPrincipals[i]); if (message.exceptionPrincipals != null && message.exceptionPrincipals.length) for (var i = 0; i < message.exceptionPrincipals.length; ++i) writer.uint32(/* id 2, wireType 2 =*/18).string(message.exceptionPrincipals[i]); if (message.deniedPermissions != null && message.deniedPermissions.length) for (var i = 0; i < message.deniedPermissions.length; ++i) writer.uint32(/* id 3, wireType 2 =*/26).string(message.deniedPermissions[i]); if (message.exceptionPermissions != null && message.exceptionPermissions.length) for (var i = 0; i < message.exceptionPermissions.length; ++i) writer.uint32(/* id 4, wireType 2 =*/34).string(message.exceptionPermissions[i]); if (message.denialCondition != null && Object.hasOwnProperty.call(message, "denialCondition")) $root.google.type.Expr.encode(message.denialCondition, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); return writer; }; /** * Encodes the specified DenyRule message, length delimited. Does not implicitly {@link google.iam.v2.DenyRule.verify|verify} messages. * @function encodeDelimited * @memberof google.iam.v2.DenyRule * @static * @param {google.iam.v2.IDenyRule} message DenyRule message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ DenyRule.encodeDelimited = function encodeDelimited(message, writer) { return this.encode(message, writer).ldelim(); }; /** * Decodes a DenyRule message from the specified reader or buffer. * @function decode * @memberof google.iam.v2.DenyRule * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand * @returns {google.iam.v2.DenyRule} DenyRule * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ DenyRule.decode = function decode(reader, length, error) { if (!(reader instanceof $Reader)) reader = $Reader.create(reader); var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.iam.v2.DenyRule(); while (reader.pos < end) { var tag = reader.uint32(); if (tag === error) break; switch (tag >>> 3) { case 1: { if (!(message.deniedPrincipals && message.deniedPrincipals.length)) message.deniedPrincipals = []; message.deniedPrincipals.push(reader.string()); break; } case 2: { if (!(message.exceptionPrincipals && message.exceptionPrincipals.length)) message.exceptionPrincipals = []; message.exceptionPrincipals.push(reader.string()); break; } case 3: { if (!(message.deniedPermissions && message.deniedPermissions.length)) message.deniedPermissions = []; message.deniedPermissions.push(reader.string()); break; } case 4: { if (!(message.exceptionPermissions && message.exceptionPermissions.length)) message.exceptionPermissions = []; message.exceptionPermissions.push(reader.string()); break; } case 5: { message.denialCondition = $root.google.type.Expr.decode(reader, reader.uint32()); break; } default: reader.skipType(tag & 7); break; } } return message; }; /** * Decodes a DenyRule message from the specified reader or buffer, length delimited. * @function decodeDelimited * @memberof google.iam.v2.DenyRule * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @returns {google.iam.v2.DenyRule} DenyRule * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ DenyRule.decodeDelimited = function decodeDelimited(reader) { if (!(reader instanceof $Reader)) reader = new $Reader(reader); return this.decode(reader, reader.uint32()); }; /** * Verifies a DenyRule message. * @function verify * @memberof google.iam.v2.DenyRule * @static * @param {Object.<string,*>} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ DenyRule.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; if (message.deniedPrincipals != null && message.hasOwnProperty("deniedPrincipals")) { if (!Array.isArray(message.deniedPrincipals)) return "deniedPrincipals: array expected"; for (var i = 0; i < message.deniedPrincipals.length; ++i) if (!$util.isString(message.deniedPrincipals[i])) return "deniedPrincipals: string[] expected"; } if (message.exceptionPrincipals != null && message.hasOwnProperty("exceptionPrincipals")) { if (!Array.isArray(message.exceptionPrincipals)) return "exceptionPrincipals: array expected"; for (var i = 0; i < message.exceptionPrincipals.length; ++i) if (!$util.isString(message.exceptionPrincipals[i])) return "exceptionPrincipals: string[] expected"; } if (message.deniedPermissions != null && message.hasOwnProperty("deniedPermissions")) { if (!Array.isArray(message.deniedPermissions)) return "deniedPermissions: array expected"; for (var i = 0; i < message.deniedPermissions.length; ++i) if (!$util.isString(message.deniedPermissions[i])) return "deniedPermissions: string[] expected"; } if (message.exceptionPermissions != null && message.hasOwnProperty("exceptionPermissions")) { if (!Array.isArray(message.exceptionPermissions)) return "exceptionPermissions: array expected"; for (var i = 0; i < message.exceptionPermissions.length; ++i) if (!$util.isString(message.exceptionPermissions[i])) return "exceptionPermissions: string[] expected"; } if (message.denialCondition != null && message.hasOwnProperty("denialCondition")) { var error = $root.google.type.Expr.verify(message.denialCondition); if (error) return "denialCondition." + error; } return null; }; /** * Creates a DenyRule message from a plain object. Also converts values to their respective internal types. * @function fromObject * @memberof google.iam.v2.DenyRule * @static * @param {Object.<string,*>} object Plain object * @returns {google.iam.v2.DenyRule} DenyRule */ DenyRule.fromObject = function fromObject(object) { if (object instanceof $root.google.iam.v2.DenyRule) return object; var message = new $root.google.iam.v2.DenyRule(); if (object.deniedPrincipals) { if (!Array.isArray(object.deniedPrincipals)) throw TypeError(".google.iam.v2.DenyRule.deniedPrincipals: array expected"); message.deniedPrincipals = []; for (var i = 0; i < object.deniedPrincipals.length; ++i) message.deniedPrincipals[i] = String(object.deniedPrincipals[i]); } if (object.exceptionPrincipals) { if (!Array.isArray(object.exceptionPrincipals)) throw TypeError(".google.iam.v2.DenyRule.exceptionPrincipals: array expected"); message.exceptionPrincipals = []; for (var i = 0; i < object.exceptionPrincipals.length; ++i) message.exceptionPrincipals[i] = String(object.exceptionPrincipals[i]); } if (object.deniedPermissions) { if (!Array.isArray(object.deniedPermissions)) throw TypeError(".google.iam.v2.DenyRule.deniedPermissions: array expected"); message.deniedPermissions = []; for (var i = 0; i < object.deniedPermissions.length; ++i) message.deniedPermissions[i] = String(object.deniedPermissions[i]); } if (object.exceptionPermissions) { if (!Array.isArray(object.exceptionPermissions)) throw TypeError(".google.iam.v2.DenyRule.exceptionPermissions: array expected"); message.exceptionPermissions = []; for (var i = 0; i < object.exceptionPermissions.length; ++i) message.exceptionPermissions[i] = String(object.exceptionPermissions[i]); } if (object.denialCondition != null) { if (typeof object.denialCondition !== "object") throw TypeError(".google.iam.v2.DenyRule.denialCondition: object expected"); message.denialCondition = $root.google.type.Expr.fromObject(object.denialCondition); } return message; }; /** * Creates a plain object from a DenyRule message. Also converts values to other types if specified. * @function toObject * @memberof google.iam.v2.DenyRule * @static * @param {google.iam.v2.DenyRule} message DenyRule * @param {$protobuf.IConversionOptions} [options] Conversion options * @returns {Object.<string,*>} Plain object */ DenyRule.toObject = function toObject(message, options) { if (!options) options = {}; var object = {}; if (options.arrays || options.defaults) { object.deniedPrincipals = []; object.exceptionPrincipals = []; object.deniedPermissions = []; object.exceptionPermissions = []; } if (options.defaults) object.denialCondition = null; if (message.deniedPrincipals && message.deniedPrincipals.length) { object.deniedPrincipals = []; for (var j = 0; j < message.deniedPrincipals.length; ++j) object.deniedPrincipals[j] = message.deniedPrincipals[j]; } if (message.exceptionPrincipals && message.exceptionPrincipals.length) { object.exceptionPrincipals = []; for (var j = 0; j < message.exceptionPrincipals.length; ++j) object.exceptionPrincipals[j] = message.exceptionPrincipals[j]; } if (message.deniedPermissions && message.deniedPermissions.length) { object.deniedPermissions = []; for (var j = 0; j < message.deniedPermissions.length; ++j) object.deniedPermissions[j] = message.deniedPermissions[j]; } if (message.exceptionPermissions && message.exceptionPermissions.length) { object.exceptionPermissions = []; for (var j = 0; j < message.exceptionPermissions.length; ++j) object.exceptionPermissions[j] = message.exceptionPermissions[j]; } if (message.denialCondition != null && message.hasOwnProperty("denialCondition")) object.denialCondition = $root.google.type.Expr.toObject(message.denialCondition, options); return object; }; /** * Converts this DenyRule to JSON. * @function toJSON * @memberof google.iam.v2.DenyRule * @instance * @returns {Object.<string,*>} JSON object */ DenyRule.prototype.toJSON = function toJSON() { return this.constructor.toObject(this, $protobuf.util.toJSONOptions); }; /** * Gets the default type url for DenyRule * @function getTypeUrl * @memberof google.iam.v2.DenyRule * @static * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") * @returns {string} The default type url */ DenyRule.getTypeUrl = function getTypeUrl(typeUrlPrefix) { if (typeUrlPrefix === undefined) { typeUrlPrefix = "type.googleapis.com"; } return typeUrlPrefix + "/google.iam.v2.DenyRule"; }; return DenyRule; })(); v2.Policies = (function() { /** * Constructs a new Policies service. * @memberof google.iam.v2 * @classdesc Represents a Policies * @extends $protobuf.rpc.Service * @constructor * @param {$protobuf.RPCImpl} rpcImpl RPC implementation * @param {boolean} [requestDelimited=false] Whether requests are length-delimited * @param {boolean} [responseDelimited=false] Whether responses are length-delimited */ function Policies(rpcImpl, requestDelimited, responseDelimited) { $protobuf.rpc.Service.call(this, rpcImpl, requestDelimited, responseDelimited); } (Policies.prototype = Object.create($protobuf.rpc.Service.prototype)).constructor = Policies; /** * Creates new Policies service using the specified rpc implementation. * @function create * @memberof google.iam.v2.Policies * @static * @param {$protobuf.RPCImpl} rpcImpl RPC implementation * @param {boolean} [requestDelimited=false] Whether requests are length-delimited * @param {boolean} [responseDelimited=false] Whether responses are length-delimited * @returns {Policies} RPC service. Useful where requests and/or responses are streamed. */ Policies.create = function create(rpcImpl, requestDelimited, responseDelimited) { return new this(rpcImpl, requestDelimited, responseDelimited); }; /** * Callback as used by {@link google.iam.v2.Policies|listPolicies}. * @memberof google.iam.v2.Policies * @typedef ListPoliciesCallback * @type {function} * @param {Error|null} error Error, if any * @param {google.iam.v2.ListPoliciesResponse} [response] ListPoliciesResponse */ /** * Calls ListPolicies. * @function listPolicies * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IListPoliciesRequest} request ListPoliciesRequest message or plain object * @param {google.iam.v2.Policies.ListPoliciesCallback} callback Node-style callback called with the error, if any, and ListPoliciesResponse * @returns {undefined} * @variation 1 */ Object.defineProperty(Policies.prototype.listPolicies = function listPolicies(request, callback) { return this.rpcCall(listPolicies, $root.google.iam.v2.ListPoliciesRequest, $root.google.iam.v2.ListPoliciesResponse, request, callback); }, "name", { value: "ListPolicies" }); /** * Calls ListPolicies. * @function listPolicies * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IListPoliciesRequest} request ListPoliciesRequest message or plain object * @returns {Promise<google.iam.v2.ListPoliciesResponse>} Promise * @variation 2 */ /** * Callback as used by {@link google.iam.v2.Policies|getPolicy}. * @memberof google.iam.v2.Policies * @typedef GetPolicyCallback * @type {function} * @param {Error|null} error Error, if any * @param {google.iam.v2.Policy} [response] Policy */ /** * Calls GetPolicy. * @function getPolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IGetPolicyRequest} request GetPolicyRequest message or plain object * @param {google.iam.v2.Policies.GetPolicyCallback} callback Node-style callback called with the error, if any, and Policy * @returns {undefined} * @variation 1 */ Object.defineProperty(Policies.prototype.getPolicy = function getPolicy(request, callback) { return this.rpcCall(getPolicy, $root.google.iam.v2.GetPolicyRequest, $root.google.iam.v2.Policy, request, callback); }, "name", { value: "GetPolicy" }); /** * Calls GetPolicy. * @function getPolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IGetPolicyRequest} request GetPolicyRequest message or plain object * @returns {Promise<google.iam.v2.Policy>} Promise * @variation 2 */ /** * Callback as used by {@link google.iam.v2.Policies|createPolicy}. * @memberof google.iam.v2.Policies * @typedef CreatePolicyCallback * @type {function} * @param {Error|null} error Error, if any * @param {google.longrunning.Operation} [response] Operation */ /** * Calls CreatePolicy. * @function createPolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.ICreatePolicyRequest} request CreatePolicyRequest message or plain object * @param {google.iam.v2.Policies.CreatePolicyCallback} callback Node-style callback called with the error, if any, and Operation * @returns {undefined} * @variation 1 */ Object.defineProperty(Policies.prototype.createPolicy = function createPolicy(request, callback) { return this.rpcCall(createPolicy, $root.google.iam.v2.CreatePolicyRequest, $root.google.longrunning.Operation, request, callback); }, "name", { value: "CreatePolicy" }); /** * Calls CreatePolicy. * @function createPolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.ICreatePolicyRequest} request CreatePolicyRequest message or plain object * @returns {Promise<google.longrunning.Operation>} Promise * @variation 2 */ /** * Callback as used by {@link google.iam.v2.Policies|updatePolicy}. * @memberof google.iam.v2.Policies * @typedef UpdatePolicyCallback * @type {function} * @param {Error|null} error Error, if any * @param {google.longrunning.Operation} [response] Operation */ /** * Calls UpdatePolicy. * @function updatePolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IUpdatePolicyRequest} request UpdatePolicyRequest message or plain object * @param {google.iam.v2.Policies.UpdatePolicyCallback} callback Node-style callback called with the error, if any, and Operation * @returns {undefined} * @variation 1 */ Object.defineProperty(Policies.prototype.updatePolicy = function updatePolicy(request, callback) { return this.rpcCall(updatePolicy, $root.google.iam.v2.UpdatePolicyRequest, $root.google.longrunning.Operation, request, callback); }, "name", { value: "UpdatePolicy" }); /** * Calls UpdatePolicy. * @function updatePolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IUpdatePolicyRequest} request UpdatePolicyRequest message or plain object * @returns {Promise<google.longrunning.Operation>} Promise * @variation 2 */ /** * Callback as used by {@link google.iam.v2.Policies|deletePolicy}. * @memberof google.iam.v2.Policies * @typedef DeletePolicyCallback * @type {function} * @param {Error|null} error Error, if any * @param {google.longrunning.Operation} [response] Operation */ /** * Calls DeletePolicy. * @function deletePolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IDeletePolicyRequest} request DeletePolicyRequest message or plain object * @param {google.iam.v2.Policies.DeletePolicyCallback} callback Node-style callback called with the error, if any, and Operation * @returns {undefined} * @variation 1 */ Object.defineProperty(Policies.prototype.deletePolicy = function deletePolicy(request, callback) { return this.rpcCall(deletePolicy, $root.google.iam.v2.DeletePolicyRequest, $root.google.longrunning.Operation, request, callback); }, "name", { value: "DeletePolicy" }); /** * Calls DeletePolicy. * @function deletePolicy * @memberof google.iam.v2.Policies * @instance * @param {google.iam.v2.IDeletePolicyRequest} request DeletePolicyRequest message or plain object * @returns {Promise<google.longrunning.Operation>} Promise * @variation 2 */ return Policies; })(); v2.Policy = (function() { /** * Properties of a Policy. * @memberof google.iam.v2 * @interface IPolicy * @property {string|null} [name] Policy name * @property {string|null} [uid] Policy uid * @property {string|null} [kind] Policy kind * @property {string|null} [displayName] Policy displayName * @property {Object.<string,string>|null} [annotations] Policy annotations * @property {string|null} [etag] Policy etag * @property {google.protobuf.ITimestamp|null} [createTime] Policy createTime * @property {google.protobuf.ITimestamp|null} [updateTime] Policy updateTime * @property {google.protobuf.ITimestamp|null} [deleteTime] Policy deleteTime * @property {Array.<google.iam.v2.IPolicyRule>|null} [rules] Policy rules * @property {string|null} [managingAuthority] Policy managingAuthority */ /** * Constructs a new Policy. * @memberof google.iam.v2 * @classdesc Represents a Policy. * @implements IPolicy * @constructor * @param {google.iam.v2.IPolicy=} [properties] Properties to set */ function Policy(properties) { this.annotations = {}; this.rules = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) this[keys[i]] = properties[keys[i]]; } /** * Policy name. * @member {string} name * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.name = ""; /** * Policy uid. * @member {string} uid * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.uid = ""; /** * Policy kind. * @member {string} kind * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.kind = ""; /** * Policy displayName. * @member {string} displayName * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.displayName = ""; /** * Policy annotations. * @member {Object.<string,string>} annotations * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.annotations = $util.emptyObject; /** * Policy etag. * @member {string} etag * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.etag = ""; /** * Policy createTime. * @member {google.protobuf.ITimestamp|null|undefined} createTime * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.createTime = null; /** * Policy updateTime. * @member {google.protobuf.ITimestamp|null|undefined} updateTime * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.updateTime = null; /** * Policy deleteTime. * @member {google.protobuf.ITimestamp|null|undefined} deleteTime * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.deleteTime = null; /** * Policy rules. * @member {Array.<google.iam.v2.IPolicyRule>} rules * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.rules = $util.emptyArray; /** * Policy managingAuthority. * @member {string} managingAuthority * @memberof google.iam.v2.Policy * @instance */ Policy.prototype.managingAuthority = ""; /** * Creates a new Policy instance using the specified properties. * @function create * @memberof google.iam.v2.Policy * @static * @param {google.iam.v2.IPolicy=} [properties] Properties to set * @returns {google.iam.v2.Policy} Policy instance */ Policy.create = function create(properties) { return new Policy(properties); }; /** * Encodes the specified Policy message. Does not implicitly {@link google.iam.v2.Policy.verify|verify} messages. * @function encode * @memberof google.iam.v2.Policy * @static * @param {google.iam.v2.IPolicy} message Policy message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ Policy.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); if (message.name != null && Object.hasOwnProperty.call(message, "name")) writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); if (message.uid != null && Object.hasOwnProperty.call(message, "uid")) writer.uint32(/* id 2, wireType 2 =*/18).string(message.uid); if (message.kind != null && Object.hasOwnProperty.call(message, "kind")) writer.uint32(/* id 3, wireType 2 =*/26).string(message.kind); if (message.displayName != null && Object.hasOwnProperty.call(message, "displayName")) writer.uint32(/* id 4, wireType 2 =*/34).string(message.displayName); if (message.annotations != null && Object.hasOwnProperty.call(message, "annotations")) for (var keys = Object.keys(message.annotations), i = 0; i < keys.length; ++i) writer.uint32(/* id 5, wireType 2 =*/42).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.annotations[keys[i]]).ldelim(); if (message.etag != null && Object.hasOwnProperty.call(message, "etag")) writer.uint32(/* id 6, wireType 2 =*/50).string(message.etag); if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); if (message.deleteTime != null && Object.hasOwnProperty.call(message, "deleteTime")) $root.google.protobuf.Timestamp.encode(message.deleteTime, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); if (message.rules != null && message.rules.length) for (var i = 0; i < message.rules.length; ++i) $root.google.iam.v2.PolicyRule.encode(message.rules[i], writer.uint32(/* id 10, wireType 2 =*/82).fork()).ldelim(); if (message.managingAuthority != null && Object.hasOwnProperty.call(message, "managingAuthority")) writer.uint32(/* id 11, wireType 2 =*/90).string(message.managingAuthority); return writer; }; /** * Encodes the specified Policy message, length delimited. Does not implicitly {@link google.iam.v2.Policy.verify|verify} messages. * @function encodeDelimited * @memberof google.iam.v2.Policy * @static * @param {google.iam.v2.IPolicy} message Policy message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ Policy.encodeDelimited = function encodeDelimited(message, writer) { return this.encode(message, writer).ldelim(); }; /** * Decodes a Policy message from the specified reader or buffer. * @function decode * @memberof google.iam.v2.Policy * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand * @returns {google.iam.v2.Policy} Policy * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ Policy.decode = function decode(reader, length, error) { if (!(reader instanceof $Reader)) reader = $Reader.create(reader); var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.iam.v2.Policy(), key, value; while (reader.pos < end) { var tag = reader.uint32(); if (tag === error) break; switch (tag >>> 3) { case 1: { message.name = reader.string(); break; } case 2: { message.uid = reader.string(); break; } case 3: { message.kind = reader.string(); break; } case 4: { message.displayName = reader.string(); break; } case 5: { if (message.annotations === $util.emptyObject) message.annotations = {}; var end2 = reader.uint32() + reader.pos; key = ""; value = ""; while (reader.pos < end2) { var tag2 = reader.uint32(); switch (tag2 >>> 3) { case 1: key = reader.string(); break; case 2: value = reader.string(); break; default: reader.skipType(tag2 & 7); break; } } message.annotations[key] = value; break; } case 6: { message.etag = reader.string(); break; } case 7: { message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); break; } case 8: { message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); break; } case 9: { message.deleteTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); break; } case 10: { if (!(message.rules && message.rules.length)) message.rules = []; message.rules.push($root.google.iam.v2.PolicyRule.decode(reader, reader.uint32())); break; } case 11: { message.managingAuthority = reader.string(); break; } default: reader.skipType(tag & 7); break; } } return message; }; /** * Decodes a Policy message from the specified reader or buffer, length delimited. * @function decod