Delphi ActiveX
Delphi ActiveX
Create Group
See more Microsoft Group Examples
Create a new group as specified in the request body. You can create one of three types of groups:- Office 365 Group (unified group)
- Dynamic group
- Security group
This operation returns by default only a subset of the properties for each group. These default properties are noted in the Properties section.
See https://docs.microsoft.com/en-us/graph/api/group-post-groups?view=graph-rest-1.0 for more information.
Chilkat Delphi ActiveX Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
http: TChilkatHttp;
jsonToken: TChilkatJsonObject;
json: TChilkatJsonObject;
resp: TChilkatHttpResponse;
id: WideString;
deletedDateTime: WideString;
classification: WideString;
createdDateTime: WideString;
description: WideString;
displayName: WideString;
mail: WideString;
mailEnabled: Integer;
mailNickname: WideString;
onPremisesLastSyncDateTime: WideString;
onPremisesSecurityIdentifier: WideString;
onPremisesSyncEnabled: WideString;
preferredDataLocation: WideString;
renewedDateTime: WideString;
securityEnabled: Integer;
visibility: WideString;
i: Integer;
count_i: Integer;
strVal: WideString;
begin
success := 0;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := TChilkatHttp.Create(Self);
// Use your previously obtained access token as shown here:
// Get Microsoft Graph OAuth2 Access Token with Group.ReadWrite.All scope.
jsonToken := TChilkatJsonObject.Create(Self);
success := jsonToken.LoadFile('qa_data/tokens/msGraphGroup.json');
if (success = 0) then
begin
Memo1.Lines.Add(jsonToken.LastErrorText);
Exit;
end;
http.AuthToken := jsonToken.StringOf('access_token');
// Create a JSON body for the HTTP POST
// Use this online tool to generate the code from sample JSON:
// Generate Code to Create JSON
// {
// "description": "Self help community for library",
// "displayName": "Library Assist",
// "groupTypes": [
// "Unified"
// ],
// "mailEnabled": true,
// "mailNickname": "library",
// "securityEnabled": false
// }
json := TChilkatJsonObject.Create(Self);
json.UpdateString('description','Self help community for library');
json.UpdateString('displayName','Library Assist');
json.UpdateString('groupTypes[0]','Unified');
json.UpdateBool('mailEnabled',1);
json.UpdateString('mailNickname','library');
json.UpdateBool('securityEnabled',0);
// POST the JSON to https://graph.microsoft.com/v1.0/groups
resp := TChilkatHttpResponse.Create(Self);
success := http.HttpJson('POST','https://graph.microsoft.com/v1.0/groups',json.ControlInterface,'application/json',resp.ControlInterface);
if (success = 0) then
begin
Memo1.Lines.Add(http.LastErrorText);
Exit;
end;
json.Load(resp.BodyStr);
json.EmitCompact := 0;
if (resp.StatusCode <> 201) then
begin
Memo1.Lines.Add(json.Emit());
Memo1.Lines.Add('Failed, response status code = ' + IntToStr(resp.StatusCode));
Exit;
end;
Memo1.Lines.Add(json.Emit());
// A sample response:
// (See code for parsing this response below..)
// {
// "id": "b320ee12-b1cd-4cca-b648-a437be61c5cd",
// "deletedDateTime": null,
// "classification": null,
// "createdDateTime": "2018-12-22T00:51:37Z",
// "creationOptions": [],
// "description": "Self help community for library",
// "displayName": "Library Assist",
// "groupTypes": [
// "Unified"
// ],
// "mail": "library7423@contoso.com",
// "mailEnabled": true,
// "mailNickname": "library",
// "onPremisesLastSyncDateTime": null,
// "onPremisesSecurityIdentifier": null,
// "onPremisesSyncEnabled": null,
// "preferredDataLocation": "CAN",
// "proxyAddresses": [
// "SMTP:library7423@contoso.com"
// ],
// "renewedDateTime": "2018-12-22T00:51:37Z",
// "resourceBehaviorOptions": [],
// "resourceProvisioningOptions": [],
// "securityEnabled": false,
// "visibility": "Public",
// "onPremisesProvisioningErrors": []
// }
// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
id := json.StringOf('id');
deletedDateTime := json.StringOf('deletedDateTime');
classification := json.StringOf('classification');
createdDateTime := json.StringOf('createdDateTime');
description := json.StringOf('description');
displayName := json.StringOf('displayName');
mail := json.StringOf('mail');
mailEnabled := json.BoolOf('mailEnabled');
mailNickname := json.StringOf('mailNickname');
onPremisesLastSyncDateTime := json.StringOf('onPremisesLastSyncDateTime');
onPremisesSecurityIdentifier := json.StringOf('onPremisesSecurityIdentifier');
onPremisesSyncEnabled := json.StringOf('onPremisesSyncEnabled');
preferredDataLocation := json.StringOf('preferredDataLocation');
renewedDateTime := json.StringOf('renewedDateTime');
securityEnabled := json.BoolOf('securityEnabled');
visibility := json.StringOf('visibility');
i := 0;
count_i := json.SizeOfArray('creationOptions');
while i < count_i do
begin
json.I := i;
i := i + 1;
end;
i := 0;
count_i := json.SizeOfArray('groupTypes');
while i < count_i do
begin
json.I := i;
strVal := json.StringOf('groupTypes[i]');
i := i + 1;
end;
i := 0;
count_i := json.SizeOfArray('proxyAddresses');
while i < count_i do
begin
json.I := i;
strVal := json.StringOf('proxyAddresses[i]');
i := i + 1;
end;
i := 0;
count_i := json.SizeOfArray('resourceBehaviorOptions');
while i < count_i do
begin
json.I := i;
// ...
i := i + 1;
end;
i := 0;
count_i := json.SizeOfArray('resourceProvisioningOptions');
while i < count_i do
begin
json.I := i;
// ...
i := i + 1;
end;
i := 0;
count_i := json.SizeOfArray('onPremisesProvisioningErrors');
while i < count_i do
begin
json.I := i;
// ...
i := i + 1;
end;
Memo1.Lines.Add('Success.');
end;