Sample code for 30+ languages & platforms
Lianja

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 Lianja Downloads

Lianja
llSuccess = .F.

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

loHttp = createobject("CkHttp")

// Use your previously obtained access token as shown here:
//    Get Microsoft Graph OAuth2 Access Token with Group.ReadWrite.All scope.

loJsonToken = createobject("CkJsonObject")
llSuccess = loJsonToken.LoadFile("qa_data/tokens/msGraphGroup.json")
if (llSuccess = .F.) then
    ? loJsonToken.LastErrorText
    release loHttp
    release loJsonToken
    return
endif

loHttp.AuthToken = loJsonToken.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
// }

loJson = createobject("CkJsonObject")
loJson.UpdateString("description","Self help community for library")
loJson.UpdateString("displayName","Library Assist")
loJson.UpdateString("groupTypes[0]","Unified")
loJson.UpdateBool("mailEnabled",.T.)
loJson.UpdateString("mailNickname","library")
loJson.UpdateBool("securityEnabled",.F.)

// POST the JSON to https://graph.microsoft.com/v1.0/groups

loResp = createobject("CkHttpResponse")
llSuccess = loHttp.HttpJson("POST","https://graph.microsoft.com/v1.0/groups",loJson,"application/json",loResp)
if (llSuccess = .F.) then
    ? loHttp.LastErrorText
    release loHttp
    release loJsonToken
    release loJson
    release loResp
    return
endif

loJson.Load(loResp.BodyStr)
loJson.EmitCompact = .F.

if (loResp.StatusCode <> 201) then
    ? loJson.Emit()
    ? "Failed, response status code = " + str(loResp.StatusCode)
    release loHttp
    release loJsonToken
    release loJson
    release loResp
    return
endif

? loJson.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

lcId = loJson.StringOf("id")
lcDeletedDateTime = loJson.StringOf("deletedDateTime")
lcClassification = loJson.StringOf("classification")
lcCreatedDateTime = loJson.StringOf("createdDateTime")
lcDescription = loJson.StringOf("description")
lcDisplayName = loJson.StringOf("displayName")
lcMail = loJson.StringOf("mail")
llMailEnabled = loJson.BoolOf("mailEnabled")
lcMailNickname = loJson.StringOf("mailNickname")
lcOnPremisesLastSyncDateTime = loJson.StringOf("onPremisesLastSyncDateTime")
lcOnPremisesSecurityIdentifier = loJson.StringOf("onPremisesSecurityIdentifier")
lcOnPremisesSyncEnabled = loJson.StringOf("onPremisesSyncEnabled")
lcPreferredDataLocation = loJson.StringOf("preferredDataLocation")
lcRenewedDateTime = loJson.StringOf("renewedDateTime")
llSecurityEnabled = loJson.BoolOf("securityEnabled")
lcVisibility = loJson.StringOf("visibility")
i = 0
lnCount_i = loJson.SizeOfArray("creationOptions")
do while i < lnCount_i
    loJson.I = i
    i = i + 1
enddo
i = 0
lnCount_i = loJson.SizeOfArray("groupTypes")
do while i < lnCount_i
    loJson.I = i
    lcStrVal = loJson.StringOf("groupTypes[i]")
    i = i + 1
enddo
i = 0
lnCount_i = loJson.SizeOfArray("proxyAddresses")
do while i < lnCount_i
    loJson.I = i
    lcStrVal = loJson.StringOf("proxyAddresses[i]")
    i = i + 1
enddo
i = 0
lnCount_i = loJson.SizeOfArray("resourceBehaviorOptions")
do while i < lnCount_i
    loJson.I = i
    // ...
    i = i + 1
enddo
i = 0
lnCount_i = loJson.SizeOfArray("resourceProvisioningOptions")
do while i < lnCount_i
    loJson.I = i
    // ...
    i = i + 1
enddo
i = 0
lnCount_i = loJson.SizeOfArray("onPremisesProvisioningErrors")
do while i < lnCount_i
    loJson.I = i
    // ...
    i = i + 1
enddo

? "Success."


release loHttp
release loJsonToken
release loJson
release loResp