@pnp/cli-microsoft365 6.2.0-beta.01dcbcb → 6.2.0-beta.725ebd5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -58,6 +58,9 @@ class AadAppRoleAssignmentAddCommand extends GraphCommand_1.default {
58
58
  };
59
59
  try {
60
60
  const servicePrincipalResult = yield request_1.default.get(getServicePrinciplesRequestOptions);
61
+ if (servicePrincipalResult.value.length === 0) {
62
+ return Promise.reject(`The specified service principal doesn't exist`);
63
+ }
61
64
  if (servicePrincipalResult.value.length > 1) {
62
65
  throw 'More than one service principal found. Please use the appId or appObjectId option to make sure the right service principal is specified.';
63
66
  }
@@ -22,6 +22,7 @@ const validation_1 = require("../../../../utils/validation");
22
22
  const AadUserGetCommand = require("../../../aad/commands/user/user-get");
23
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
24
24
  const commands_1 = require("../../commands");
25
+ const SpoGroupMemberListCommand = require("./group-member-list");
25
26
  class SpoGroupMemberRemoveCommand extends SpoCommand_1.default {
26
27
  get name() {
27
28
  return commands_1.default.GROUP_MEMBER_REMOVE;
@@ -58,54 +59,89 @@ class SpoGroupMemberRemoveCommand extends SpoCommand_1.default {
58
59
  }
59
60
  commandAction(logger, args) {
60
61
  return __awaiter(this, void 0, void 0, function* () {
61
- const removeUserfromSPGroup = () => __awaiter(this, void 0, void 0, function* () {
62
- if (this.verbose) {
63
- logger.logToStderr(`Removing User ${args.options.userName || args.options.email || args.options.userId} from Group: ${args.options.groupId ? args.options.groupId : args.options.groupName}`);
64
- }
65
- let requestUrl = `${args.options.webUrl}/_api/web/sitegroups/${args.options.groupId
66
- ? `GetById('${args.options.groupId}')`
67
- : `GetByName('${formatting_1.formatting.encodeQueryParameter(args.options.groupName)}')`}`;
68
- if (args.options.userId) {
69
- requestUrl += `/users/removeById(${args.options.userId})`;
70
- }
71
- else {
72
- const userName = yield this.getUserName(logger, args);
73
- const loginName = `i:0#.f|membership|${userName}`;
74
- requestUrl += `/users/removeByLoginName(@LoginName)?@LoginName='${formatting_1.formatting.encodeQueryParameter(loginName)}'`;
75
- }
76
- const requestOptions = {
77
- url: requestUrl,
78
- headers: {
79
- 'accept': 'application/json;odata=nometadata'
80
- },
81
- responseType: 'json'
82
- };
83
- try {
84
- yield request_1.default.post(requestOptions);
85
- }
86
- catch (err) {
87
- this.handleRejectedODataJsonPromise(err);
88
- }
89
- });
90
62
  if (args.options.confirm) {
91
63
  if (this.debug) {
92
64
  logger.logToStderr('Confirmation bypassed by entering confirm option. Removing the user from SharePoint Group...');
93
65
  }
94
- yield removeUserfromSPGroup();
66
+ yield this.removeUserfromSPGroup(logger, args);
95
67
  }
96
68
  else {
97
69
  const result = yield Cli_1.Cli.prompt({
98
70
  type: 'confirm',
99
71
  name: 'continue',
100
72
  default: false,
101
- message: `Are you sure you want to remove user ${args.options.userName || args.options.userId || args.options.email} from the SharePoint group?`
73
+ message: `Are you sure you want to remove user ${args.options.userName || args.options.userId || args.options.email || args.options.aadGroupId || args.options.aadGroupName} from the SharePoint group?`
102
74
  });
103
75
  if (result.continue) {
104
- yield removeUserfromSPGroup();
76
+ yield this.removeUserfromSPGroup(logger, args);
105
77
  }
106
78
  }
107
79
  });
108
80
  }
81
+ removeUserfromSPGroup(logger, args) {
82
+ return __awaiter(this, void 0, void 0, function* () {
83
+ if (this.verbose) {
84
+ logger.logToStderr(`Removing User ${args.options.userName || args.options.email || args.options.userId || args.options.aadGroupId || args.options.aadGroupName} from Group: ${args.options.groupId || args.options.groupName}`);
85
+ }
86
+ let requestUrl = `${args.options.webUrl}/_api/web/sitegroups/${args.options.groupId
87
+ ? `GetById('${args.options.groupId}')`
88
+ : `GetByName('${formatting_1.formatting.encodeQueryParameter(args.options.groupName)}')`}`;
89
+ if (args.options.userId) {
90
+ requestUrl += `/users/removeById(${args.options.userId})`;
91
+ }
92
+ else if (args.options.userName || args.options.email) {
93
+ const userName = yield this.getUserName(logger, args);
94
+ const loginName = `i:0#.f|membership|${userName}`;
95
+ requestUrl += `/users/removeByLoginName(@LoginName)?@LoginName='${formatting_1.formatting.encodeQueryParameter(loginName)}'`;
96
+ }
97
+ else {
98
+ const aadGroupId = yield this.getGroupId(args);
99
+ requestUrl += `/users/RemoveById(${aadGroupId})`;
100
+ }
101
+ const requestOptions = {
102
+ url: requestUrl,
103
+ headers: {
104
+ 'accept': 'application/json;odata=nometadata'
105
+ },
106
+ responseType: 'json'
107
+ };
108
+ try {
109
+ yield request_1.default.post(requestOptions);
110
+ }
111
+ catch (err) {
112
+ this.handleRejectedODataJsonPromise(err);
113
+ }
114
+ });
115
+ }
116
+ getGroupId(args) {
117
+ return __awaiter(this, void 0, void 0, function* () {
118
+ const options = {
119
+ webUrl: args.options.webUrl,
120
+ output: 'json',
121
+ debug: this.debug,
122
+ verbose: this.verbose
123
+ };
124
+ if (args.options.groupId) {
125
+ options.groupId = args.options.groupId;
126
+ }
127
+ else {
128
+ options.groupName = args.options.groupName;
129
+ }
130
+ const output = yield Cli_1.Cli.executeCommandWithOutput(SpoGroupMemberListCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
131
+ const getGroupMemberListOutput = JSON.parse(output.stdout);
132
+ let foundgroups;
133
+ if (args.options.aadGroupId) {
134
+ foundgroups = getGroupMemberListOutput.filter((x) => { return x.LoginName.indexOf(args.options.aadGroupId) > -1 && (x.LoginName.indexOf("c:0o.c|federateddirectoryclaimprovider|") === 0 || x.LoginName.indexOf("c:0t.c|tenant|") === 0); });
135
+ }
136
+ else {
137
+ foundgroups = getGroupMemberListOutput.filter((x) => { return x.Title === args.options.aadGroupName && (x.LoginName.indexOf("c:0o.c|federateddirectoryclaimprovider|") === 0 || x.LoginName.indexOf("c:0t.c|tenant|") === 0); });
138
+ }
139
+ if (foundgroups.length === 0) {
140
+ throw `The Azure AD group ${args.options.aadGroupId || args.options.aadGroupName} is not found in SharePoint group ${args.options.groupId || args.options.groupName}`;
141
+ }
142
+ return foundgroups[0].Id;
143
+ });
144
+ }
109
145
  }
110
146
  _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCommand_initTelemetry = function _SpoGroupMemberRemoveCommand_initTelemetry() {
111
147
  this.telemetry.push((args) => {
@@ -115,6 +151,8 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
115
151
  userName: (!(!args.options.userName)).toString(),
116
152
  email: (!(!args.options.email)).toString(),
117
153
  userId: (!(!args.options.userId)).toString(),
154
+ aadGroupId: (!(!args.options.groupId)).toString(),
155
+ aadGroupName: (!(!args.options.groupName)).toString(),
118
156
  confirm: (!(!args.options.confirm)).toString()
119
157
  });
120
158
  });
@@ -131,6 +169,10 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
131
169
  option: '--email [email]'
132
170
  }, {
133
171
  option: '--userId [userId]'
172
+ }, {
173
+ option: '--aadGroupId [aadGroupId]'
174
+ }, {
175
+ option: '--aadGroupName [aadGroupName]'
134
176
  }, {
135
177
  option: '--confirm'
136
178
  });
@@ -148,10 +190,13 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
148
190
  if (args.options.email && !validation_1.validation.isValidUserPrincipalName(args.options.email)) {
149
191
  return `${args.options.email} is not a valid email`;
150
192
  }
193
+ if (args.options.aadGroupId && !validation_1.validation.isValidGuid(args.options.aadGroupId)) {
194
+ return `${args.options.aadGroupId} is not a valid GUID`;
195
+ }
151
196
  return validation_1.validation.isValidSharePointUrl(args.options.webUrl);
152
197
  }));
153
198
  }, _SpoGroupMemberRemoveCommand_initOptionSets = function _SpoGroupMemberRemoveCommand_initOptionSets() {
154
- this.optionSets.push({ options: ['groupName', 'groupId'] }, { options: ['userName', 'email', 'userId'] });
199
+ this.optionSets.push({ options: ['groupName', 'groupId'] }, { options: ['userName', 'email', 'userId', 'aadGroupId', 'aadGroupName'] });
155
200
  };
156
201
  module.exports = new SpoGroupMemberRemoveCommand();
157
202
  //# sourceMappingURL=group-member-remove.js.map
@@ -42,6 +42,10 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
42
42
  commandAction(logger, args) {
43
43
  return __awaiter(this, void 0, void 0, function* () {
44
44
  this.showDeprecationWarning(logger, commands_1.default.LIST_LABEL_SET, commands_1.default.LIST_RETENTIONLABEL_ENSURE);
45
+ if (args.options.label) {
46
+ args.options.name = args.options.label;
47
+ this.warn(logger, `Option 'label' is deprecated. Please use 'name' instead`);
48
+ }
45
49
  if (args.options.blockDelete) {
46
50
  this.warn(logger, `Option 'blockDelete' is deprecated.`);
47
51
  }
@@ -81,7 +85,7 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
81
85
  },
82
86
  data: {
83
87
  listUrl: listAbsoluteUrl,
84
- complianceTagValue: args.options.label,
88
+ complianceTagValue: args.options.name,
85
89
  blockDelete: args.options.blockDelete || false,
86
90
  blockEdit: args.options.blockEdit || false,
87
91
  syncToItems: args.options.syncToItems || false
@@ -99,6 +103,8 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
99
103
  _SpoListRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoListRetentionLabelEnsureCommand_initTelemetry = function _SpoListRetentionLabelEnsureCommand_initTelemetry() {
100
104
  this.telemetry.push((args) => {
101
105
  Object.assign(this.telemetryProperties, {
106
+ name: (!(!args.options.name)).toString(),
107
+ label: (!(!args.options.label)).toString(),
102
108
  listId: (!(!args.options.listId)).toString(),
103
109
  listTitle: (!(!args.options.listTitle)).toString(),
104
110
  listUrl: (!(!args.options.listUrl)).toString(),
@@ -111,7 +117,9 @@ _SpoListRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoListRetention
111
117
  this.options.unshift({
112
118
  option: '-u, --webUrl <webUrl>'
113
119
  }, {
114
- option: '--label <label>'
120
+ option: '--name [name]'
121
+ }, {
122
+ option: '--label [label]'
115
123
  }, {
116
124
  option: '-t, --listTitle [listTitle]'
117
125
  }, {
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=ListItemRetentionLabel.js.map
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=SiteRetentionLabel.js.map
@@ -0,0 +1,161 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
13
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
14
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
+ };
16
+ var _SpoListItemRetentionLabelEnsureCommand_instances, _SpoListItemRetentionLabelEnsureCommand_initTelemetry, _SpoListItemRetentionLabelEnsureCommand_initOptions, _SpoListItemRetentionLabelEnsureCommand_initValidators, _SpoListItemRetentionLabelEnsureCommand_initOptionSets;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const request_1 = require("../../../../request");
19
+ const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
+ const validation_1 = require("../../../../utils/validation");
22
+ const SpoCommand_1 = require("../../../base/SpoCommand");
23
+ const commands_1 = require("../../commands");
24
+ const SpoWebRetentionLabelListCommand = require("../web/web-retentionlabel-list");
25
+ const Cli_1 = require("../../../../cli/Cli");
26
+ class SpoListItemRetentionLabelEnsureCommand extends SpoCommand_1.default {
27
+ get name() {
28
+ return commands_1.default.LISTITEM_RETENTIONLABEL_ENSURE;
29
+ }
30
+ get description() {
31
+ return 'Apply a retention label to a list item';
32
+ }
33
+ constructor() {
34
+ super();
35
+ _SpoListItemRetentionLabelEnsureCommand_instances.add(this);
36
+ __classPrivateFieldGet(this, _SpoListItemRetentionLabelEnsureCommand_instances, "m", _SpoListItemRetentionLabelEnsureCommand_initTelemetry).call(this);
37
+ __classPrivateFieldGet(this, _SpoListItemRetentionLabelEnsureCommand_instances, "m", _SpoListItemRetentionLabelEnsureCommand_initOptions).call(this);
38
+ __classPrivateFieldGet(this, _SpoListItemRetentionLabelEnsureCommand_instances, "m", _SpoListItemRetentionLabelEnsureCommand_initValidators).call(this);
39
+ __classPrivateFieldGet(this, _SpoListItemRetentionLabelEnsureCommand_instances, "m", _SpoListItemRetentionLabelEnsureCommand_initOptionSets).call(this);
40
+ }
41
+ commandAction(logger, args) {
42
+ return __awaiter(this, void 0, void 0, function* () {
43
+ try {
44
+ const labelInformation = yield this.getLabelInformation(args.options, logger);
45
+ yield this.applyLabel(args.options, labelInformation, logger);
46
+ }
47
+ catch (err) {
48
+ this.handleRejectedODataJsonPromise(err);
49
+ }
50
+ });
51
+ }
52
+ getLabelInformation(options, logger) {
53
+ return __awaiter(this, void 0, void 0, function* () {
54
+ const cmdOptions = {
55
+ webUrl: options.webUrl,
56
+ output: 'json',
57
+ debug: options.debug,
58
+ verbose: options.verbose
59
+ };
60
+ const output = yield Cli_1.Cli.executeCommandWithOutput(SpoWebRetentionLabelListCommand, { options: Object.assign(Object.assign({}, cmdOptions), { _: [] }) });
61
+ if (this.verbose) {
62
+ logger.logToStderr(output.stderr);
63
+ }
64
+ const labels = JSON.parse(output.stdout);
65
+ const label = labels.find(l => l.TagName === options.name || l.TagId === options.id);
66
+ if (this.verbose && label !== undefined) {
67
+ logger.logToStderr(`Retention label found in the list of available labels: '${label.TagName}' / '${label.TagId}'...`);
68
+ }
69
+ if (label === undefined) {
70
+ throw new Error(`The specified retention label does not exist`);
71
+ }
72
+ return {
73
+ complianceTag: label.TagName,
74
+ isTagPolicyHold: label.BlockDelete,
75
+ isTagPolicyRecord: label.BlockEdit,
76
+ isEventBasedTag: label.IsEventTag,
77
+ isTagSuperLock: label.SuperLock,
78
+ isUnlockedAsDefault: label.UnlockedAsDefault
79
+ };
80
+ });
81
+ }
82
+ applyLabel(options, labelInformation, logger) {
83
+ return __awaiter(this, void 0, void 0, function* () {
84
+ if (this.verbose) {
85
+ logger.logToStderr(`Applying retention label to item in list '${options.listId || options.listTitle || options.listUrl}' in site at ${options.webUrl}...`);
86
+ }
87
+ let requestUrl = `${options.webUrl}/_api/web`;
88
+ if (options.listId) {
89
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(options.listId)}')/items(${options.listItemId})/SetComplianceTag()`;
90
+ }
91
+ else if (options.listTitle) {
92
+ requestUrl += `/lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(options.listTitle)}')/items(${options.listItemId})/SetComplianceTag()`;
93
+ }
94
+ else if (options.listUrl) {
95
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(options.webUrl, options.listUrl);
96
+ requestUrl += `/GetList(@listUrl)/items(${options.listItemId})/SetComplianceTag()?@listUrl='${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}'`;
97
+ }
98
+ const requestOptions = {
99
+ url: requestUrl,
100
+ headers: {
101
+ 'accept': 'application/json;odata=nometadata'
102
+ },
103
+ data: labelInformation,
104
+ responseType: 'json'
105
+ };
106
+ yield request_1.default.post(requestOptions);
107
+ });
108
+ }
109
+ }
110
+ _SpoListItemRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoListItemRetentionLabelEnsureCommand_initTelemetry = function _SpoListItemRetentionLabelEnsureCommand_initTelemetry() {
111
+ this.telemetry.push((args) => {
112
+ Object.assign(this.telemetryProperties, {
113
+ listId: typeof args.options.listId !== 'undefined',
114
+ listTitle: typeof args.options.listTitle !== 'undefined',
115
+ listUrl: typeof args.options.listUrl !== 'undefined',
116
+ name: typeof args.options.name !== 'undefined',
117
+ id: typeof args.options.id !== 'undefined'
118
+ });
119
+ });
120
+ }, _SpoListItemRetentionLabelEnsureCommand_initOptions = function _SpoListItemRetentionLabelEnsureCommand_initOptions() {
121
+ this.options.unshift({
122
+ option: '-u, --webUrl <webUrl>'
123
+ }, {
124
+ option: '--listItemId <listItemId>'
125
+ }, {
126
+ option: '--listId [listId]'
127
+ }, {
128
+ option: '--listTitle [listTitle]'
129
+ }, {
130
+ option: '--listUrl [listUrl]'
131
+ }, {
132
+ option: '-n, --name [name]'
133
+ }, {
134
+ option: '-i, --id [id]'
135
+ });
136
+ }, _SpoListItemRetentionLabelEnsureCommand_initValidators = function _SpoListItemRetentionLabelEnsureCommand_initValidators() {
137
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
138
+ const id = parseInt(args.options.listItemId);
139
+ if (isNaN(id)) {
140
+ return `${args.options.listItemId} is not a valid list item ID`;
141
+ }
142
+ const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
143
+ if (isValidSharePointUrl !== true) {
144
+ return isValidSharePointUrl;
145
+ }
146
+ if (args.options.listId &&
147
+ !validation_1.validation.isValidGuid(args.options.listId)) {
148
+ return `${args.options.listId} is not a valid GUID`;
149
+ }
150
+ if (args.options.id &&
151
+ !validation_1.validation.isValidGuid(args.options.id)) {
152
+ return `${args.options.id} is not a valid GUID`;
153
+ }
154
+ return true;
155
+ }));
156
+ }, _SpoListItemRetentionLabelEnsureCommand_initOptionSets = function _SpoListItemRetentionLabelEnsureCommand_initOptionSets() {
157
+ this.optionSets.push({ options: ['listId', 'listTitle', 'listUrl'] });
158
+ this.optionSets.push({ options: ['name', 'id'] });
159
+ };
160
+ module.exports = new SpoListItemRetentionLabelEnsureCommand();
161
+ //# sourceMappingURL=listitem-retentionlabel-ensure.js.map
@@ -148,6 +148,7 @@ exports.default = {
148
148
  LISTITEM_RECORD_UNDECLARE: `${prefix} listitem record undeclare`,
149
149
  LISTITEM_RECORD_UNLOCK: `${prefix} listitem record unlock`,
150
150
  LISTITEM_REMOVE: `${prefix} listitem remove`,
151
+ LISTITEM_RETENTIONLABEL_ENSURE: `${prefix} listitem retentionlabel ensure`,
151
152
  LISTITEM_RETENTIONLABEL_REMOVE: `${prefix} listitem retentionlabel remove`,
152
153
  LISTITEM_ROLEASSIGNMENT_ADD: `${prefix} listitem roleassignment add`,
153
154
  LISTITEM_ROLEASSIGNMENT_REMOVE: `${prefix} listitem roleassignment remove`,
@@ -15,9 +15,12 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
15
15
  };
16
16
  var _TeamsChatListCommand_instances, _TeamsChatListCommand_initTelemetry, _TeamsChatListCommand_initOptions, _TeamsChatListCommand_initValidators;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
+ const Auth_1 = require("../../../../Auth");
19
+ const accessToken_1 = require("../../../../utils/accessToken");
18
20
  const odata_1 = require("../../../../utils/odata");
19
21
  const GraphCommand_1 = require("../../../base/GraphCommand");
20
22
  const commands_1 = require("../../commands");
23
+ const validation_1 = require("../../../../utils/validation");
21
24
  class TeamsChatListCommand extends GraphCommand_1.default {
22
25
  get name() {
23
26
  return commands_1.default.CHAT_LIST;
@@ -31,16 +34,26 @@ class TeamsChatListCommand extends GraphCommand_1.default {
31
34
  constructor() {
32
35
  super();
33
36
  _TeamsChatListCommand_instances.add(this);
37
+ this.supportedTypes = ['oneOnOne', 'group', 'meeting'];
34
38
  __classPrivateFieldGet(this, _TeamsChatListCommand_instances, "m", _TeamsChatListCommand_initTelemetry).call(this);
35
39
  __classPrivateFieldGet(this, _TeamsChatListCommand_instances, "m", _TeamsChatListCommand_initOptions).call(this);
36
40
  __classPrivateFieldGet(this, _TeamsChatListCommand_instances, "m", _TeamsChatListCommand_initValidators).call(this);
37
41
  }
38
42
  commandAction(logger, args) {
39
43
  return __awaiter(this, void 0, void 0, function* () {
40
- const filter = args.options.type !== undefined ? `?$filter=chatType eq '${args.options.type}'` : '';
41
- const endpoint = `${this.resource}/v1.0/chats${filter}`;
44
+ const isAppOnlyAuth = accessToken_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken);
45
+ if (isAppOnlyAuth && !args.options.userId && !args.options.userName) {
46
+ throw `The option 'userId' or 'userName' is required when obtaining chats using app only permissions`;
47
+ }
48
+ else if (!isAppOnlyAuth && (args.options.userId || args.options.userName)) {
49
+ throw `The options 'userId' or 'userName' cannot be used when obtaining chats using delegated permissions`;
50
+ }
51
+ let requestUrl = `${this.resource}/v1.0/${!isAppOnlyAuth ? 'me' : `users/${args.options.userId || args.options.userName}`}/chats`;
52
+ if (args.options.type) {
53
+ requestUrl += `?$filter=chatType eq '${args.options.type}'`;
54
+ }
42
55
  try {
43
- const items = yield odata_1.odata.getAllItems(endpoint);
56
+ const items = yield odata_1.odata.getAllItems(requestUrl);
44
57
  logger.log(items);
45
58
  }
46
59
  catch (err) {
@@ -58,13 +71,22 @@ _TeamsChatListCommand_instances = new WeakSet(), _TeamsChatListCommand_initTelem
58
71
  }, _TeamsChatListCommand_initOptions = function _TeamsChatListCommand_initOptions() {
59
72
  this.options.unshift({
60
73
  option: '-t, --type [type]',
61
- autocomplete: ['oneOnOne', 'group', 'meeting']
74
+ autocomplete: this.supportedTypes
75
+ }, {
76
+ option: '--userId [userId]'
77
+ }, {
78
+ option: '--userName [userName]'
62
79
  });
63
80
  }, _TeamsChatListCommand_initValidators = function _TeamsChatListCommand_initValidators() {
64
81
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
65
- const supportedTypes = ['oneOnOne', 'group', 'meeting'];
66
- if (args.options.type !== undefined && supportedTypes.indexOf(args.options.type) === -1) {
67
- return `${args.options.type} is not a valid chatType. Accepted values are ${supportedTypes.join(', ')}`;
82
+ if (args.options.type !== undefined && this.supportedTypes.indexOf(args.options.type) === -1) {
83
+ return `${args.options.type} is not a valid chatType. Accepted values are ${this.supportedTypes.join(', ')}`;
84
+ }
85
+ if (args.options.userId && args.options.userName) {
86
+ return `You can only specify either 'userId' or 'userName'`;
87
+ }
88
+ if (args.options.userId && !validation_1.validation.isValidGuid(args.options.userId)) {
89
+ return `${args.options.userId} is not a valid GUID`;
68
90
  }
69
91
  return true;
70
92
  }));
@@ -72,9 +72,9 @@ m365 spo file sharinglink list --webUrl https://contoso.sharepoint.com/sites/dem
72
72
  }
73
73
  ],
74
74
  "link": {
75
- "scope": "anonymous",
75
+ "scope": "organization",
76
76
  "type": "view",
77
- "webUrl": "https://contoso.sharepoint.com/:b:/s/demo/EY50lub3559MtRKfj2hrZqoBWnHOpGIcgi4gzw9XiWYJ-A",
77
+ "webUrl": "https://contoso.sharepoint.com/:w:/s/demo/EY50lub3559MtRKfj2hrZqoBWnHOpGIcgi4gzw9XiWYJ-A",
78
78
  "preventsDownload": false
79
79
  }
80
80
  }
@@ -20,36 +20,54 @@ m365 spo group member remove [options]
20
20
  : Name of the SharePoint group from which user has to be removed. Specify either `groupName` or `groupId`, but not both.
21
21
 
22
22
  `--userName [userName]`
23
- : The UPN (user principal name, eg. megan.bowen@contoso.com) of the user that needs to be removed. Specify either `userName`, `email`, or `userId`, but not multiple.
23
+ : The UPN (user principal name, eg. megan.bowen@contoso.com) of the user that needs to be removed. Specify either `userName`, `email`, `userId`, `aadGroupId` or `aadGroupName`.
24
24
 
25
25
  `--email [email]`
26
- : The email of the user to remove as a member. Specify either `userName`, `email`, or `userId`, but not multiple.
26
+ : The email of the user to remove as a member. Specify either `userName`, `email`, `userId`, `aadGroupId` or `aadGroupName`.
27
27
 
28
28
  `--userId [userId]`
29
- : The user Id (Id of the site user, eg. 14) of the user to remove as a member. Specify either `userName`, `email`, or `userId`, but not multiple.
29
+ : The user Id (Id of the site user, eg. 14) of the user to remove as a member. Specify either `userName`, `email`, `userId`, `aadGroupId` or `aadGroupName`.
30
+
31
+ `--aadGroupId [aadGroupId]`
32
+ : The object Id of the Azure AD group to remove as a member. Specify either `userName`, `email`, `userId`, `aadGroupId` or `aadGroupName`.
33
+
34
+ `--aadGroupName [aadGroupName]`
35
+ : The name of the Azure AD group to remove as a member. Specify either `userName`, `email`, `userId`, `aadGroupId` or `aadGroupName`.
30
36
 
31
37
  --8<-- "docs/cmd/_global.md"
32
38
 
33
39
  ## Examples
34
40
 
35
- Remove a user from a SharePoint group by userName.
41
+ Remove a user from a SharePoint group based on the id on a given web
36
42
 
37
43
  ```sh
38
44
  m365 spo group member remove --webUrl https://contoso.sharepoint.com/sites/SiteA --groupId 5 --userName "Alex.Wilber@contoso.com"
39
45
  ```
40
46
 
41
- Remove a user from a SharePoint group by email.
47
+ Remove a user from a SharePoint group based on the username on a given web
42
48
 
43
49
  ```sh
44
50
  m365 spo group member remove --webUrl https://contoso.sharepoint.com/sites/SiteA --groupName "Site A Visitors" --email "Alex.Wilber@contoso.com"
45
51
  ```
46
52
 
47
- Remove a user from a SharePoint group by id.
53
+ Remove a user from a SharePoint group by email.
48
54
 
49
55
  ```sh
50
56
  m365 spo group member remove --webUrl https://contoso.sharepoint.com/sites/SiteA --groupName "Site A Visitors" --userId 14
51
57
  ```
52
58
 
59
+ Remove an Azure AD group from a SharePoint group based on the Azure AD group name on a given web
60
+
61
+ ```sh
62
+ m365 spo group member remove --webUrl https://contoso.sharepoint.com/sites/SiteA --groupId 5 --aadGroupName "Azure AD Security Group"
63
+ ```
64
+
65
+ Remove an Azure AD group from a SharePoint group based on the Azure AD group ID on a given web
66
+
67
+ ```sh
68
+ m365 spo group member remove --webUrl https://contoso.sharepoint.com/sites/SiteA --groupName "Site A Visitors" --aadGroupId "5786b8e8-c495-4734-b345-756733960730"
69
+ ```
70
+
53
71
  ## Response
54
72
 
55
73
  The command won't return a response on success.
@@ -19,8 +19,11 @@ m365 spo list label set [options]
19
19
  `-u, --webUrl <webUrl>`
20
20
  : The URL of the site where the list is located.
21
21
 
22
+ `--name <name>`
23
+ : The label name to set on the list.
24
+
22
25
  `--label <label>`
23
- : The label to set on the list.
26
+ : (deprecated. Use `name` instead) The label name to set on the list.
24
27
 
25
28
  `-t, --listTitle [listTitle]`
26
29
  : The title of the list on which to set the label. Specify either `listTitle`, `listId`, or `listUrl` but not multiple.
@@ -48,16 +51,16 @@ A list retention label is a default label that will be applied to all new items
48
51
 
49
52
  ## Examples
50
53
 
51
- Sets retention label on the list with specified site-relative URL located in the specified site.
54
+ Sets a retention label by name on a given list
52
55
 
53
56
  ```sh
54
- m365 spo list retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listUrl 'Shared Documents' --label 'Some label'
57
+ m365 spo list retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listUrl 'Shared Documents' --name 'Some label'
55
58
  ```
56
59
 
57
- Sets retention label and disables editing and deleting items on the list and all existing items for the list with specified title located in the specified site.
60
+ Sets a retention label by name and disables editing and deleting items on the list and all existing items for a given list
58
61
 
59
62
  ```sh
60
- m365 spo list retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listTitle 'Documents' --label 'Some label' --blockEdit --blockDelete --syncToItems
63
+ m365 spo list retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listTitle 'Documents' --name 'Some label' --blockEdit --blockDelete --syncToItems
61
64
  ```
62
65
 
63
66
  ## Response
@@ -0,0 +1,58 @@
1
+ # spo listitem retentionlabel ensure
2
+
3
+ Apply a retention label to a list item
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 spo listitem retentionlabel ensure [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-u, --webUrl <webUrl>`
14
+ : URL of the site where the retentionlabel from a listitem to apply is located
15
+
16
+ `--listItemId <listItemId>`
17
+ : The ID of the list item for which the retention label should be applied.
18
+
19
+ `--listId [listId]`
20
+ : ID of the list where the retention label should be applied. Specify either `listTitle`, `listId` or `listUrl`
21
+
22
+ `--listTitle [listTitle]`
23
+ : Title of the list where the retention label should be applied. Specify either `listTitle`, `listId` or `listUrl`
24
+
25
+ `--listUrl [listUrl]`
26
+ : Server- or site-relative URL of the list. Specify either `listTitle`, `listId` or `listUrl`
27
+
28
+ `-n, --name [name]`
29
+ : The name of the retention label. Specify either `name` or `id`.
30
+
31
+ `-i, --id [id]`
32
+ : The id of the retention label. Specify either `name` or `id`.
33
+
34
+ --8<-- "docs/cmd/_global.md"
35
+
36
+ ## Examples
37
+
38
+ Applies the retention label _Some label_ to a list item in a given site based on the list id and label name
39
+
40
+ ```sh
41
+ m365 spo listitem retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listId 0cd891ef-afce-4e55-b836-fce03286cccf --listItemId 1 --name 'Some label'
42
+ ```
43
+
44
+ Applies a retention label to a list item in a given site based on the list title and label id
45
+
46
+ ```sh
47
+ m365 spo listitem retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listTitle 'List 1' --listItemId 1 --id '7a621a91-063b-461b-aff6-d713d5fb23eb'
48
+ ```
49
+
50
+ Applies the retention label _Some label_ to a list item in a given site based on the server relative list url
51
+
52
+ ```sh
53
+ m365 spo listitem retentionlabel ensure --webUrl https://contoso.sharepoint.com/sites/project-x --listUrl /sites/project-x/lists/TestList --listItemId 1 --name 'Some label'
54
+ ```
55
+
56
+ ## Response
57
+
58
+ The command won't return a response on success.