Sample code for 30+ languages & platforms
Classic ASP

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 Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

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

set http = Server.CreateObject("Chilkat.Http")

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

set jsonToken = Server.CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile("qa_data/tokens/msGraphGroup.json")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( jsonToken.LastErrorText) & "</pre>"
    Response.End
End If

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
' }

set json = Server.CreateObject("Chilkat.JsonObject")
success = json.UpdateString("description","Self help community for library")
success = json.UpdateString("displayName","Library Assist")
success = json.UpdateString("groupTypes[0]","Unified")
success = json.UpdateBool("mailEnabled",1)
success = json.UpdateString("mailNickname","library")
success = json.UpdateBool("securityEnabled",0)

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

set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpJson("POST","https://graph.microsoft.com/v1.0/groups",json,"application/json",resp)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
    Response.End
End If

success = json.Load(resp.BodyStr)
json.EmitCompact = 0

If (resp.StatusCode <> 201) Then
    Response.Write "<pre>" & Server.HTMLEncode( json.Emit()) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Failed, response status code = " & resp.StatusCode) & "</pre>"
    Response.End
End If

Response.Write "<pre>" & Server.HTMLEncode( json.Emit()) & "</pre>"

' 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")
Do While i < count_i
    json.I = i
    i = i + 1
Loop
i = 0
count_i = json.SizeOfArray("groupTypes")
Do While i < count_i
    json.I = i
    strVal = json.StringOf("groupTypes[i]")
    i = i + 1
Loop
i = 0
count_i = json.SizeOfArray("proxyAddresses")
Do While i < count_i
    json.I = i
    strVal = json.StringOf("proxyAddresses[i]")
    i = i + 1
Loop
i = 0
count_i = json.SizeOfArray("resourceBehaviorOptions")
Do While i < count_i
    json.I = i
    ' ...
    i = i + 1
Loop
i = 0
count_i = json.SizeOfArray("resourceProvisioningOptions")
Do While i < count_i
    json.I = i
    ' ...
    i = i + 1
Loop
i = 0
count_i = json.SizeOfArray("onPremisesProvisioningErrors")
Do While i < count_i
    json.I = i
    ' ...
    i = i + 1
Loop

Response.Write "<pre>" & Server.HTMLEncode( "Success.") & "</pre>"

%>
</body>
</html>