@google-cloud/iam
Version:
Identity and Access Management client for Node.js
911 lines (841 loc) • 1.75 MB
JavaScript
// 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