SQL Server / Microsoft Graph / Create subjectRightsRequest
Back to Collection Items
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
DECLARE @hr int
DECLARE @iTmp0 int
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
-- This example assumes the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @http int
-- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0
EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
DECLARE @success int
-- Use this online tool to generate code from sample JSON: Generate Code to Create JSON
-- The following JSON is sent in the request body.
-- {
-- "type": "access",
-- "dataSubjectType": "currentEmployee",
-- "regulations": [
-- "Test Regulation"
-- ],
-- "displayName": "{{createRequestDisplayName}}",
-- "description": "{{createRequestDescription}}",
-- "internalDueDateTime": "{{internalDueDateTime}}",
-- "dataSubject": {
-- "firstName": "{{firstName}}",
-- "lastName": "{{lastName}}",
-- "email": "{{email}}",
-- "residency": "5000 148th Ave NE, Redmond, WA 98052",
-- "phoneNumber": "(425) 867-6537",
-- "SSN": "555-55-5555"
-- }
-- }
DECLARE @json int
-- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0
EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'type', 'access'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubjectType', 'currentEmployee'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'regulations[0]', 'Test Regulation'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'displayName', '{{createRequestDisplayName}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'description', '{{createRequestDescription}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'internalDueDateTime', '{{internalDueDateTime}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.firstName', '{{firstName}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.lastName', '{{lastName}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.email', '{{email}}'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.residency', '5000 148th Ave NE, Redmond, WA 98052'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.phoneNumber', '(425) 867-6537'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'dataSubject.SSN', '555-55-5555'
-- Adds the "Authorization: Bearer <access_token>" header.
EXEC sp_OASetProperty @http, 'AuthToken', '<access_token>'
EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'Content-Type', 'application/json'
DECLARE @resp int
EXEC sp_OAMethod @http, 'PostJson3', @resp OUT, 'https://graph.microsoft.com/v1.0/privacy/subjectRightsRequests', 'application/json', @json
EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT
IF @iTmp0 = 0
BEGIN
EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
RETURN
END
EXEC sp_OAGetProperty @resp, 'StatusCode', @iTmp0 OUT
PRINT @iTmp0
EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @resp
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
END
GO
Curl Command
curl -X POST
-H "Authorization: Bearer <access_token>"
-H "Content-Type: application/json"
-d '{
"type": "access",
"dataSubjectType": "currentEmployee",
"regulations": ["Test Regulation"],
"displayName": "{{createRequestDisplayName}}",
"description": "{{createRequestDescription}}",
"internalDueDateTime": "{{internalDueDateTime}}",
"dataSubject": {
"firstName": "{{firstName}}",
"lastName": "{{lastName}}",
"email": "{{email}}",
"residency": "5000 148th Ave NE, Redmond, WA 98052",
"phoneNumber": "(425) 867-6537",
"SSN": "555-55-5555"
}
}'
https://graph.microsoft.com/v1.0/privacy/subjectRightsRequests
Postman Collection Item JSON
{
"name": "Create subjectRightsRequest",
"event": [
{
"listen": "test",
"script": {
"exec": [
"var json = JSON.parse(responseBody);",
"postman.setEnvironmentVariable(\"subjectRightsRequestId\", json.id);"
],
"type": "text/javascript"
}
}
],
"request": {
"method": "POST",
"header": [
{
"key": "Content-Type",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"type\": \"access\",\n \"dataSubjectType\": \"currentEmployee\",\n \"regulations\": [\"Test Regulation\"],\n \"displayName\": \"{{createRequestDisplayName}}\",\n \"description\": \"{{createRequestDescription}}\",\n \"internalDueDateTime\": \"{{internalDueDateTime}}\",\n \"dataSubject\": {\n \"firstName\": \"{{firstName}}\",\n \"lastName\": \"{{lastName}}\",\n \"email\": \"{{email}}\",\n \"residency\": \"5000 148th Ave NE, Redmond, WA 98052\",\n \"phoneNumber\": \"(425) 867-6537\",\n \"SSN\": \"555-55-5555\"\n }\n}"
},
"url": {
"raw": "https://graph.microsoft.com/v1.0/privacy/subjectRightsRequests",
"protocol": "https",
"host": [
"graph",
"microsoft",
"com"
],
"path": [
"v1.0",
"privacy",
"subjectRightsRequests"
]
}
},
"response": [
]
}