azure-cli
Version:
Microsoft Azure Cross Platform Command Line tool
481 lines (253 loc) • 28.5 kB
JavaScript
/*** Generated by streamline 0.10.17 (callbacks) - DO NOT EDIT ***/ "use strict"; var __rt=require('streamline/lib/callbacks/runtime').runtime(__filename, false),__func=__rt.__func,__cb=__rt.__cb,__catch=__rt.__catch,__tryCatch=__rt.__tryCatch; var __ = require("underscore");
var util = require("util");
var groupUtils = require("../group/groupUtils");
var permissionsUtils = require("../role/permissionsUtils");
var rbacClients = require("../role/rbacClients");
var profile = require("../../../util/profile");
var resourceUtils = require("./resourceUtils");
var tagUtils = require("../tag/tagUtils");
var utils = require("../../../util/utils");
var jsonlint = require("jsonlint");
var $ = utils.getLocaleString;
exports.init = function(cli) {
var log = cli.output;
var resource = cli.category("resource").description($("Commands to manage your resources"));
resource.command("create [resource-group] [name] [resource-type] [api-version]").description($("Creates a resource in a resource group")).usage("[options] <resource-group> <name> <resource-type> <location> <api-version>").option("-g --resource-group <resource-group>", $("the resource group name")).option("-n --name <name>", $("the resource name")).option("-r --resource-type <resource-type>", $("the resource type")).option("-o --api-version <api-version>", $("the API version of the resource provider")).option("--parent <parent>", $("the name of the parent resource (if needed), in path/path/path format")).option("-p --properties <properties>", $("a JSON-formatted string containing properties")).option("--sku <sku>", $("a JSON-formatted string containing sku properties")).option("-l --location <location>", $("the location where we will create the resource")).option("--plan <plan>", $("a JSON-formatted string containing plan properties")).option("--isFullObject", $("Indicates that the property object includes other options such as location, tags, sku, and/or plan.")).option("-t --tags <tags>", $(("Tags to set to the resource group. Can be mutliple. " + "In the format of 'name=value'. Name is required and value is optional. For example, -t tag1=value1;tag2"))).option("--subscription <subscription>", $("the subscription identifier")).execute(function __1(resourceGroup, name, resourceType, apiVersion, options, _) { var values; var __frame = { name: "__1", line: 53 }; return __func(_, this, arguments, __1, 5, __frame, function __$__1() {
values = getValuesForCommand(resourceGroup, name, resourceType, apiVersion, options);
return resource.createResource(values.resourceGroup, values.resourceName, values.resourceType, values.apiVersion, options.properties, values.options, __cb(_, __frame, 2, 15, function __$__1() { _(); }, true)); }); });
resource.command("set [resource-group] [name] [resource-type] [properties] [api-version]").usage("[options] <resource-group> <name> <resource-type> <properties> <api-version>").description($("Updates a resource in a resource group without any templates or parameters")).option("-g --resource-group <resource-group>", $("the resource group name")).option("-n --name <name>", $("the resource name")).option("-r --resource-type <resource-type>", $("the resource type")).option("-p --properties <properties>", $("a JSON-formatted string containing properties")).option("-o --api-version <api-version>", $("the API version of the resource provider")).option("-i --resource-id <resource-id>", $("the resource id")).option("--sku <sku>", $("a JSON-formatted string containing sku properties")).option("--plan <plan>", $("a JSON-formatted string containing plan properties")).option("--isFullObject", $("Indicates that the property object includes other options such as location, tags, sku, and/or plan.")).option("--parent <parent>", $("the name of the parent resource (if needed), in path/path/path format")).option("-t --tags <tags>", $(("Tags to set to the resource. Can be multiple. " + "In the format of 'name=value'. Name is required and value is optional. For example, -t tag1=value1;tag2"))).option("--no-tags", $("remove all existing tags")).option("--subscription <subscription>", $("the subscription identifier")).execute(function __2(resourceGroup, name, resourceType, properties, apiVersion, options, _) { var values; var __frame = { name: "__2", line: 75 }; return __func(_, this, arguments, __2, 6, __frame, function __$__2() {
values = getValuesForCommand(resourceGroup, name, resourceType, apiVersion, options);
return resource.createResource(values.resourceGroup, values.resourceName, values.resourceType, values.apiVersion, options.properties, values.options, __cb(_, __frame, 2, 15, function __$__2() { _(); }, true)); }); });
resource.createResource = function resource_createResource__3(resourceGroup, name, resourceType, apiVersion, propertiesParam, options, _) { var subscription, client, requestProperties, identity, resourceGroupObj, properties, tags, resourceLocation, message, doneMessage, newResource; var __frame = { name: "resource_createResource__3", line: 80 }; return __func(_, this, arguments, resource_createResource__3, 6, __frame, function __$resource_createResource__3() {
subscription = profile.current.getSubscription(options.subscription);
client = utils.createResourceClient(subscription);
requestProperties = { };
identity = {
resourceName: name,
resourceProviderNamespace: resourceUtils.getProviderName(resourceType),
resourceProviderApiVersion: apiVersion,
resourceType: resourceUtils.getResourceTypeName(resourceType),
parentResourcePath: (__.isString(options.parent) ? options.parent : "") };
return groupUtils.getGroup(client, resourceGroup, __cb(_, __frame, 12, 38, function ___(__0, __2) { resourceGroupObj = __2;
if (!resourceGroupObj) {
return _(new Error((("Resource group '" + resourceGroup) + "' could not be found."))); } ;
resourceGroupObj = (resourceGroupObj || { });
properties = { };
if (propertiesParam) {
properties = parsed(propertiesParam, "properties"); } ;
if (!options.isFullObject) {
tags = { };
tags = tagUtils.buildTagsParameter(tags, options);
resourceLocation = (options.location || resourceGroupObj.location);
if (!resourceLocation) {
cli.missingArgument("location"); } ;
if (options.sku) {
requestProperties.sku = parsed(options.sku, "sku"); } ;
if (options.plan) {
requestProperties.plan = parsed(options.plan, "plan"); } ;
requestProperties.location = resourceLocation;
requestProperties.tags = tags;
requestProperties.properties = properties; }
else {
requestProperties = properties; } ;
message = util.format($("Creating resource %s"), name);
doneMessage = util.format($("Created resource %s"), name);
if (resourceGroupObj) {
message = util.format($("Updating resource %s"), name);
doneMessage = util.format($("Resource %s is updated"), name); } ;
return cli.interaction.withProgress(util.format($("Creating resource %s"), name), function __1(log, _) { var __frame = { name: "__1", line: 128 }; return __func(_, this, arguments, __1, 1, __frame, function __$__1() {
return client.resources.createOrUpdate(resourceGroup, identity.resourceProviderNamespace, identity.parentResourcePath, identity.resourceType, identity.resourceName, apiVersion, requestProperties, __cb(_, __frame, 1, 39, function ___(__0, __1) { newResource = __1; _(); }, true)); }); }, __cb(_, __frame, 47, 20, function __$resource_createResource__3() {
log.info(doneMessage); return (function __$resource_createResource__3(__then) {
if (!newResource.id) {
return client.resources.get(resourceGroup, identity.resourceProviderNamespace, identity.parentResourcePath, identity.resourceType, identity.resourceName, apiVersion, __cb(_, __frame, 62, 39, function ___(__0, __3) { newResource = __3; __then(); }, true)); } else { __then(); } ; })(function __$resource_createResource__3() {
showResource(newResource); _(); }); }, true)); }, true)); }); };
resource.command("list [resource-group]").description($("Lists the resources")).option("-g --resource-group <resource-group>", $("the resource group name")).option("-r --resource-type <resource-type>", $("the resource type")).option("--details", $("show details such as permissions, etc.")).option("-t --tags <tags>", $((("Tag to use to filter to the resource group. Can only take 1 tag. " + "In the format of \"name=value\". Name is required and value is optional. ") + "For example, -t tag1 or -t tag1=value1."))).option("--subscription <subscription>", $("the subscription identifier")).execute(function __4(resourceGroup, options, _) { var subscription, client, progress, resources, parameters, tagsInfo, filterString, authzClient, i, resourceInformation; var __frame = { name: "__4", line: 162 }; return __func(_, this, arguments, __4, 2, __frame, function __$__4() {
subscription = profile.current.getSubscription(options.subscription);
client = utils.createResourceClient(subscription);
progress = cli.interaction.progress(util.format($("Listing resources"))); return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$__4() {
parameters = { };
if (options) {
if (options.resourceType) {
parameters.filter = (("resourceType eq '" + options.resourceType) + "'"); } ;
if (options.tags) {
tagsInfo = { };
filterString = (parameters.filter || "");
tagUtils.populateQueryFilterWithTagInfo(options.tags, tagsInfo);
if (parameters.filter) {
if (tagsInfo.tagName) {
filterString += ((" and tagname eq '" + tagsInfo.tagName) + "'"); } ;
if (tagsInfo.tagValue) {
filterString += ((" and tagvalue eq '" + tagsInfo.tagValue) + "'"); } ; }
else {
if (tagsInfo.tagName) {
filterString += (("tagname eq '" + tagsInfo.tagName) + "'"); } ;
if (tagsInfo.tagValue) {
filterString += ((" and tagvalue eq '" + tagsInfo.tagValue) + "'"); } ; } ;
parameters.filter = filterString; } ; } ; return (function __$__4(__then) {
if (resourceGroup) {
return client.resourceGroups.listResources(resourceGroup, parameters, __cb(_, __frame, 36, 44, function ___(__0, __1) { resources = __1; __then(); }, true)); } else {
return client.resources.list(parameters, __cb(_, __frame, 38, 39, function ___(__0, __2) { resources = __2; __then(); }, true)); } ; })(function __$__4() { _(null, null, true); }); }); })(function ___(__e, __r, __cont) { (function ___(__then) { __tryCatch(_, function __$__4() {
progress.end(); __then(); }); })(function ___() { __tryCatch(_, function ___() { if (__cont) { __then(); } else { _(__e, __r); }; }); }); }); })(function ___() { __tryCatch(_, function __$__4() { return (function __$__4(__then) {
if (options.details) {
authzClient = rbacClients.getAuthzClient(subscription);
i = 0; var __7 = false; return (function ___(__break) { var __more; var __loop = __cb(_, __frame, 0, 0, function __$__4() { __more = false; if (__7) { i++; } else { __7 = true; } ; var __6 = (i < resources.length); if (__6) {
resourceInformation = resourceUtils.getResourceInformation(resources[i].id);
return authzClient.permissions.listForResource(resourceInformation.resourceGroup, {
resourceName: resourceInformation.resourceName,
resourceType: resourceUtils.getResourceTypeName(resourceInformation.resourceType),
resourceProviderNamespace: resourceUtils.getProviderName(resourceInformation.resourceType),
parentResourcePath: (resourceInformation.parentResource ? resourceInformation.parentResource : "") }, __cb(_, __frame, 48, 61, function ___(__0, __3) { resources[i].permissions = __3.permissions; while (__more) { __loop(); }; __more = true; }, true)); } else { __break(); } ; }); do { __loop(); } while (__more); __more = true; })(__then); } else { __then(); } ; })(function __$__4() {
if ((resources.length === 0)) {
log.info($("No matched resources were found.")); }
else {
log.table(resources, function(row, item) {
var resourceInformation = resourceUtils.getResourceInformation(item.id);
row.cell($("Id"), item.id);
row.cell($("Name"), (resourceInformation.resourceName || item.name));
row.cell($("Resource Group"), (resourceInformation.resourceGroup || ""));
row.cell($("Type"), (resourceInformation.resourceType || item.type));
row.cell($("Parent"), (resourceInformation.parentResource ? resourceInformation.parentResource : ""));
row.cell($("Location"), item.location);
row.cell($("Tags"), tagUtils.getTagsInfo(item.tags));
if (item.permissions) {
var permissionDetails = permissionsUtils.getPermissionDetails(item.permissions);
row.cell($("Actions"), permissionDetails.actions);
row.cell($("NotActions"), permissionDetails.notActions); } ; }); } ; _(); }); }); }); }); });
resource.command("show [resource-group] [name] [resource-type] [api-version]").description($("Gets one resource within a resource group or subscription")).usage("[options] <resource-group> <name> <resource-type> <api-version>").option("-g --resource-group <resource-group>", $("the resource group name")).option("-n --name <name>", $("the resource name")).option("-r --resource-type <resource-type>", $("the resource type")).option("-i --resource-id <resource-id>", $("the resource id")).option("-o --api-version <api-version>", $("the API version of the resource provider")).option("--parent <parent>", $("the name of the parent resource (if needed), in path/path/path format")).option("--subscription <subscription>", $("the subscription identifier")).execute(function __5(resourceGroup, name, resourceType, apiVersion, options, _) { var values, subscription, client, authzClient, progress, resource, identity; var __frame = { name: "__5", line: 251 }; return __func(_, this, arguments, __5, 5, __frame, function __$__5() {
values = getValuesForCommand(resourceGroup, name, resourceType, apiVersion, options);
subscription = profile.current.getSubscription(options.subscription);
client = utils.createResourceClient(subscription);
authzClient = rbacClients.getAuthzClient(subscription);
progress = cli.interaction.progress(util.format($("Getting resource %s"), values.resourceName)); return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$__5() {
identity = {
resourceName: values.resourceName,
resourceProviderNamespace: resourceUtils.getProviderName(values.resourceType),
resourceProviderApiVersion: values.apiVersion,
resourceType: resourceUtils.getResourceTypeName(values.resourceType),
parentResourcePath: (__.isString(options.parent) ? options.parent : "") };
return client.resources.get(values.resourceGroup, identity.resourceProviderNamespace, identity.parentResourcePath, identity.resourceType, values.resourceName, values.apiVersion, __cb(_, __frame, 16, 36, function ___(__0, __1) { resource = __1;
return authzClient.permissions.listForResource(values.resourceGroup, identity, __cb(_, __frame, 22, 55, function ___(__0, __2) { resource.permissions = __2.permissions; _(null, null, true); }, true)); }, true)); }); })(function ___(__e, __r, __cont) { (function ___(__then) { __tryCatch(_, function __$__5() {
progress.end(); __then(); }); })(function ___() { __tryCatch(_, function ___() { if (__cont) { __then(); } else { _(__e, __r); }; }); }); }); })(function ___() { __tryCatch(_, function __$__5() {
cli.interaction.formatOutput(resource, function(resource) {
showResource(resource, true); }); _(); }); }); }); });
resource.command("delete [resource-group] [name] [resource-type] [api-version]").description($("Deletes a resource in a resource group")).usage("[options] <resource-group> <name> <resource-type> <api-version>").option("-g --resource-group <resource-group>", $("the resource group name")).option("-n --name <name>", $("the resource name")).option("-r --resource-type <resource-type>", $("the resource type")).option("-i --resource-id <resource-id>", $("the resource id")).option("-o --api-version <api-version>", $("the API version of the resource provider")).option("--parent <parent>", $("the name of the parent resource (if needed), in path/path/path format")).option("-q, --quiet", $("quiet mode (do not ask for delete confirmation)")).option("--subscription <subscription>", $("the subscription identifier")).execute(function __6(resourceGroup, name, resourceType, apiVersion, options, _) { var values, subscription, client, progress; var __frame = { name: "__6", line: 293 }; return __func(_, this, arguments, __6, 5, __frame, function __$__6() {
values = getValuesForCommand(resourceGroup, name, resourceType, apiVersion, options); return (function __$__6(_) {
var __1 = !options.quiet; if (!__1) { return _(null, __1); } ; return cli.interaction.confirm(util.format($("Delete resource %s? [y/n] "), values.resourceName), __cb(_, __frame, 2, 45, function ___(__0, __3) { var __2 = !__3; return _(null, __2); }, true)); })(__cb(_, __frame, -292, 17, function ___(__0, __2) { return (function __$__6(__then) { if (__2) { return _(null); } else { __then(); } ; })(function __$__6() {
subscription = profile.current.getSubscription(options.subscription);
client = utils.createResourceClient(subscription);
progress = cli.interaction.progress(util.format($("Deleting resource %s"), values.resourceName));
return deleteResource(values.resourceType, values.resourceGroup, values.apiVersion, values.resourceName, values.options, client, progress, __cb(_, __frame, 8, 6, function __$__6() { _(); }, true)); }); }, true)); }); });
resource.command("move [ids] [destination-group] [api-version]").description($("Moves resources from one resource group to another")).usage("[options] <ids> <destination-group> <api-version>").option("-i --ids <ids>", $("the comma-delimitied resource ids to be moved")).option("-d --destination-group <destination-group>", $("the destination resource group name")).option("--destination-subscriptionId <destination-subscriptionId>", $("the destination subscription identifier")).option("-o --api-version <api-version>", $("the API version of the resource provider")).option("-q, --quiet", $("quiet mode (do not ask for move confirmation)")).option("--subscription <subscription>", $("the subscription identifier")).execute(function __7(ids, destinationGroup, apiVersion, options, _) { var resources, sourceGroup, subscription, client, progress, destinationSubId, parameters; var __frame = { name: "__7", line: 313 }; return __func(_, this, arguments, __7, 4, __frame, function __$__7() {
if (!ids) {
return _(null, cli.missingArgument("ids")); } else {
if (!destinationGroup) {
return _(null, cli.missingArgument("destinationGroup")); } else {
if (!apiVersion) {
apiVersion = false; } ; } ; } ;
resources = (ids ? ids.split(",") : []);
sourceGroup = resourceUtils.getSourceResourceGroupForMove(resources); return (function __$__7(_) {
var __1 = !options.quiet; if (!__1) { return _(null, __1); } ; return cli.interaction.confirm(util.format($("Move selected resources in %s to %s? [y/n] "), sourceGroup, destinationGroup), __cb(_, __frame, 11, 45, function ___(__0, __3) { var __2 = !__3; return _(null, __2); }, true)); })(__cb(_, __frame, -312, 17, function ___(__0, __2) { return (function __$__7(__then) { if (__2) { return _(null); } else { __then(); } ; })(function __$__7() {
subscription = profile.current.getSubscription(options.subscription);
client = utils.createResourceClient(subscription);
apiVersion = validateApiVersion(apiVersion);
client.apiVersion = (apiVersion ? apiVersion : client.apiVersion);
progress = cli.interaction.progress(util.format($("Moving selected resources to %s"), destinationGroup)); return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$__7() { return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$__7() {
destinationSubId = subscription.id;
if (options.destinationSubscriptionId) {
destinationSubId = options.destinationSubscriptionId; } ;
parameters = {
targetResourceGroup: ((("/subscriptions/" + destinationSubId) + "/resourceGroups/") + destinationGroup),
resources: resources };
return client.resources.moveResources(sourceGroup, parameters, __cb(_, __frame, 29, 25, __then, true)); }); })(function ___(e, __result) { __catch(function __$__7() { if (e) {
if (e.details) {
e.details.forEach(function(detail) {
if (detail.Message) {
log.error(detail.Message); } ; }); } ;
return _((e)); } else { _(null, __result); } ; }, _); }); })(function ___() { __tryCatch(_, function __$__7() { _(null, null, true); }); }); }); })(function ___(__e, __r, __cont) { (function ___(__then) { __tryCatch(_, function __$__7() {
progress.end(); __then(); }); })(function ___() { __tryCatch(_, function ___() { if (__cont) { __then(); } else { _(__e, __r); }; }); }); }); })(function ___() { __tryCatch(_, function __$__7() { _(); }); }); }); }, true)); }); });
function getValuesForCommand(resourceGroup, name, resourceType, apiVersion, options) {
var values = { };
if (((((resourceGroup || name) || resourceType)) && options.resourceId)) {
throw new Error("Cannot use both resource parameters {resourceGroup, name, resourceType} and {resource id} in the same operation. Please provide one of the two."); } ;
if (!options.resourceId) {
checkMissingParameters(resourceGroup, name, resourceType, apiVersion);
values.resourceGroup = resourceGroup;
values.resourceName = name;
values.resourceType = resourceType; }
else {
var valuesFromId = extractAllValues(options.resourceId);
values.resourceGroup = valuesFromId["resourceGroup"];
values.resourceType = valuesFromId["providerList"];
values.resourceName = valuesFromId["resourceName"]; } ;
values.apiVersion = apiVersion;
values.options = options;
checkMissingParameters(values.resourceGroup, values.resourceName, values.resourceType, values.apiVersion);
return values; };
function parsed(obj, type) {
try {
return jsonlint.parse(obj);
} catch (e) {
throw new Error(((("Error when parsing the input value for " + type) + ": ") + e)); }; };
function deleteResource(resourceType, resourceGroup, apiVersion, name, options, client, progress, _) { var identity; var __frame = { name: "deleteResource", line: 390 }; return __func(_, this, arguments, deleteResource, 7, __frame, function __$deleteResource() { return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$deleteResource() { return (function ___(__then) { (function ___(_) { __tryCatch(_, function __$deleteResource() {
identity = {
resourceName: name,
resourceProviderNamespace: resourceUtils.getProviderName(resourceType),
resourceProviderApiVersion: apiVersion,
resourceType: resourceUtils.getResourceTypeName(resourceType),
parentResourcePath: (__.isString(options.parent) ? options.parent : "") };
return client.resources.deleteMethod(resourceGroup, identity.resourceProviderNamespace, identity.parentResourcePath, identity.resourceType, identity.resourceName, apiVersion, __cb(_, __frame, 11, 23, __then, true)); }); })(function ___(e, __result) { __catch(function __$deleteResource() { if (e) {
return _(null, e); } else { _(null, __result); } ; }, _); }); })(function ___() { __tryCatch(_, function __$deleteResource() { _(null, null, true); }); }); }); })(function ___(__e, __r, __cont) { (function ___(__then) { __tryCatch(_, function __$deleteResource() {
progress.end(); __then(); }); })(function ___() { __tryCatch(_, function ___() { if (__cont) { __then(); } else { _(__e, __r); }; }); }); }); })(function ___() { __tryCatch(_, function __$deleteResource() { _(); }); }); }); };
function extractAllValues(resourceId) {
var values = { };
var segments = resourceId.split("/");
var firstValue = segments[0];
segments = segments.slice(segments.indexOf(firstValue), segments.length).filter(function(element) {
return (element !== ""); });
if ((segments.indexOf("providers") === -1)) {
return cli.missingArgument("providers"); } ;
var providerList = segments.slice((segments.indexOf("providers") + 1), (segments.length - 1));
if ((firstValue === "subscriptions")) {
values["subscription"] = segments[(segments.indexOf("subscriptions") + 1)]; } ;
values["resourceGroup"] = ((segments.indexOf("resourceGroups") >= 0) ? segments[(segments.indexOf("resourceGroups") + 1)] : false);
if ((segments.length > 4)) {
values["providerList"] = providerList.join("/");
values["provider"] = providerList[0];
values["resourceType"] = providerList.slice(1, providerList.length).join("/");
values["resourceName"] = segments[(segments.length - 1)]; } ;
checkMissingParameters(values["resourceGroup"], values["resourceName"], values["resourceType"], true);
return values; };
function checkMissingParameters(resourceGroup, resourceName, resourceType, apiVersion) {
if (!resourceGroup) {
return cli.missingArgument("resourceGroup"); }
else if (!resourceName) {
return cli.missingArgument("resourceName"); }
else if (!resourceType) {
return cli.missingArgument("resourceType"); }
else if (!apiVersion) {
return cli.missingArgument("apiVersion"); } ; };
function validateApiVersion(dateString) {
var dateFormat = /^(19|20)\d\d([- \/.])(0[1-9]|1[012])\2(0[1-9]|[12][0-9]|3[01])/;
if (dateFormat.exec(dateString)) {
return dateString; }
else {
log.warn("Incorrect Format. Please enter in the following format (YYYY-MM-DD). Defaulting to Resource Client api version.");
return false; } ; };
function showResource(resource, showDetail) {
cli.interaction.formatOutput(resource, function(resource) {
var resourceInformation = resourceUtils.getResourceInformation(resource.id);
log.data($("Id: "), resource.id);
log.data($("Name: "), (resourceInformation.resourceName || resource.name));
log.data($("Type: "), (resourceInformation.resourceType || resource.type));
log.data($("Parent: "), (resourceInformation.parentResource || ""));
log.data($("Location: "), resource.location);
log.data($("Tags: "), tagUtils.getTagsInfo(resource.tags));
log.data("");
if (showDetail) {
log.data($("Properties:"));
cli.interaction.logEachData($("Property"), resource.properties);
log.data("");
var permissionDetails = permissionsUtils.getPermissionDetails(resource.permissions);
log.data($("Permissions:"));
log.data(($(" Actions: ") + permissionDetails.actions));
log.data(($(" NotActions: ") + permissionDetails.notActions)); } ; }); };};