Introduction:
Most of our community members might have already worked on integration scenarios involving G-Suite integration which requires complex modeling and process modelling. In this blog will discuss how to we can simplify G-Suite with SuccessFactors by leveraging SAP Cloud Platform Integration Suite services , SAP CPI and Open Connectors.
Also Read: What is SAP Cloud Platform Integration Certification?
High Level Design Overview:
data:image/s3,"s3://crabby-images/9b3b9/9b3b95a98223bf7c70010d294e83b99a96b77d6d" alt=""
New Employee Created /Employee Terminated in SAP SuccessFactors will be captured using Intelligent Service Center ( Using New Hire and Termination Event ) and sent to SAP CPI using Integration Center ( which sends all the required data for G-Suite ).Then SAP CPI perform necessary transformation to send the data to G-Suite using SAP Cloud Platform Open Connectors.
G-Suite Configuration:
Create G-Suite Trial Account ( if you dont have one ) by following below threads
Enable G-Suite with your own domain
Once you have access you will be able to login into G-Suite Admin Page which looks like below.
data:image/s3,"s3://crabby-images/e980d/e980d74628bc7bf47d6f159eeaba29147e728643" alt=""
Now login into Google Developer Console to enable Google Admin SDK API and create OAuth Credential to create or delete user accounts [ Directory APIs ] using SAP Open Connectors.
Step 1:
Create Project by navigating to IAM&Admin –> Manage Resources
data:image/s3,"s3://crabby-images/59202/59202c1e035b4893267a1092a7a89810a37f84a0" alt=""
data:image/s3,"s3://crabby-images/5a0a6/5a0a61f1767128ce41d04f6193586fb23b6ee316" alt=""
Step 2:
Navigate to APIs & Services to create OAuth Consent and Credentials required to connect from SAP Open Connectors.
data:image/s3,"s3://crabby-images/02c5b/02c5bd447dcfc067a7fa1c52a96c3b464094daa4" alt=""
Step 3:
Enable Google Admin SDK and Directory APIs required to create User Accounts in G-Suite
data:image/s3,"s3://crabby-images/0ec5e/0ec5eede445cce21fe24217a793444ddee850185" alt=""
Step 4:
Update OAuth Consent which is required further to create OAuth 2.0 credentials.
data:image/s3,"s3://crabby-images/f4499/f4499f51e0a3c379e4b0c42509ae7677bffe8a35" alt=""
Create an application by manually adding additional scope “https://www.googleapis.com/auth/admin.directory.user” as shown below
data:image/s3,"s3://crabby-images/21607/21607753d74df2ce7ef59ad5a2f49be3d1b95422" alt=""
Step 5:
Navigate to Credentials and Click on Create Credentials of the type OAuth Client ID.
data:image/s3,"s3://crabby-images/a3328/a3328271f33c4a01b1ad0c644d38c0ceff7ecf4e" alt=""
Name your Credential and update the Redirect Urls ( one for POSTMAN and one for Open Connectors ) as shown below.
data:image/s3,"s3://crabby-images/8ff3a/8ff3ac6ed16c1280c174a941012777528a6f4e71" alt=""
Step 6:
Now you have Client ID and Client Secret .Copy these details and keep it handy for further configurations we do in POSTMAN and Open Connectors.
data:image/s3,"s3://crabby-images/96196/9619617f442e91c87de8cb689d3e6e1bd7dab13b" alt=""
SAP Cloud Platform Integration Suite- Open Connector Configuration
Bypassing regular flow of using already built Open Connector element this time we will create an G-Suite Open Connector element from scratch using working POSTMAN collection.
Open your postman and create New Collection to have 3 operations GET,POST and DELETE operations.
data:image/s3,"s3://crabby-images/e37be/e37bed0cdfbcfb60831cc84eb004a83297198d88" alt=""
Add all the 3 Operations for connecting to G-Suite( have shown only GET here )
data:image/s3,"s3://crabby-images/9cdfb/9cdfb3c28b1ffd20f8692e3d659049b546c64ffb" alt=""
Click on Get New Authorization Code to configure details required for Access token ( This step will be again focused during SAP CP Open Connector Config ).
data:image/s3,"s3://crabby-images/d3caf/d3cafb549de3759bfd01ad2da2d4e5f947d400d4" alt=""
Now use this token to send a request to G-Suite to get details of user.
data:image/s3,"s3://crabby-images/d29b8/d29b899faff3831a1cc0755766671444c92f442e" alt=""
Now repeat the same for all the 3 operations and export the Postman Collection as JSON.
data:image/s3,"s3://crabby-images/332e5/332e5b366bc055e88a8f7178d4c61dbf433b55aa" alt=""
You can use below JSON export of the POSTMAN Collection for try out .
{
"info": {
"_postman_id": "9553f61d-88e8-4b6d-a1f9-55f9e8a6ef4b",
"name": "G-Suite Private Connector",
"description": "Collection for G-Suite Open Connector Element Creation",
"schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json"
},
"item": [
{
"name": "User",
"request": {
"auth": {
"type": "oauth2",
"oauth2": [
{
"key": "accessToken",
"value": "",
"type": "string"
},
{
"key": "tokenType",
"value": "Bearer",
"type": "string"
},
{
"key": "headerPrefix",
"value": "Bearer ",
"type": "string"
},
{
"key": "addTokenTo",
"value": "header",
"type": "string"
}
]
},
"method": "GET",
"header": [],
"url": {
"raw": "https://www.googleapis.com/admin/directory/v1/users/<GSUITE_ADMIN_USER_EMAIL>",
"protocol": "https",
"host": [
"www",
"googleapis",
"com"
],
"path": [
"admin",
"directory",
"v1",
"users",
"<GSUITE_ADMIN_USER_EMAIL>"
]
},
"description": "Get User from G-Suite Console- Operation:GET"
},
"response": []
},
{
"name": "User",
"request": {
"auth": {
"type": "oauth2",
"oauth2": [
{
"key": "accessToken",
"value": "",
"type": "string"
},
{
"key": "tokenType",
"value": "Bearer",
"type": "string"
},
{
"key": "headerPrefix",
"value": "Bearer ",
"type": "string"
},
{
"key": "addTokenTo",
"value": "header",
"type": "string"
}
]
},
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer [YOUR_ACCESS_TOKEN]"
},
{
"key": "Accept",
"value": "application/json"
},
{
"key": "Content-Type",
"value": "application/json"
}
],
"body": {
"mode": "raw",
"raw": "{\"name\":{\"familyName\":\"Bhat2\",\"givenName\":\"sri5\"},\"password\":\"Test$#!123\",\"primaryEmail\":\"srbhat9@EMAIL.COM\"}"
},
"url": {
"raw": "https://www.googleapis.com/admin/directory/v1/users",
"protocol": "https",
"host": [
"www",
"googleapis",
"com"
],
"path": [
"admin",
"directory",
"v1",
"users"
]
}
},
"response": []
},
{
"name": "User",
"request": {
"auth": {
"type": "oauth2",
"oauth2": [
{
"key": "accessToken",
"value": "<YOUR_ACCESS_TOKEN>",
"type": "string"
},
{
"key": "tokenType",
"value": "Bearer",
"type": "string"
},
{
"key": "headerPrefix",
"value": "Bearer ",
"type": "string"
},
{
"key": "addTokenTo",
"value": "header",
"type": "string"
}
]
},
"method": "DELETE",
"header": [
{
"key": "Authorization",
"value": "Bearer [YOUR_ACCESS_TOKEN]"
},
{
"key": "Accept",
"value": "application/json"
},
{
"key": "Content-Type",
"value": "application/json"
}
],
"body": {
"mode": "raw",
"raw": "{\"name\":{\"familyName\":\"Bhat2\",\"givenName\":\"sri5\"},\"password\":\"Test@1!123\",\"primaryEmail\":\"srbhat5@test.com\"}"
},
"url": {
"raw": "https://www.googleapis.com/admin/directory/v1/users/<EMAIL_ID_GSUITE_USER>",
"protocol": "https",
"host": [
"www",
"googleapis",
"com"
],
"path": [
"admin",
"directory",
"v1",
"users",
"<EMAIL_ID_GSUITE_USER>"
]
}
},
"response": []
}
],
"protocolProfileBehavior": {}
}
Now you have POSTMAN collection ( in JSON format ) will see how to build connector out of it.
Step 1:
Login to your Open Connectors instance and navigate to Connectors-> Click on Build New Connector
data:image/s3,"s3://crabby-images/1e19f/1e19fab49d6640f88e16f290c68b69621894ef8f" alt=""
Step 2:
Click on Import to select JSON you have exported from POSTMAN
data:image/s3,"s3://crabby-images/2702f/2702f7f9ba9b717b067fc27e4268d958e2d74426" alt=""
Step 3:
Select Postman 2.1 as import option and select the file from your local machine.Click on CONTINUE IMPORT once you are done.
data:image/s3,"s3://crabby-images/35609/3560906eb96e993042ea275e1af9d8895cfd84ae" alt=""
Step 4:
Rename your element ( if you want ) and Select All Resources as shown below
data:image/s3,"s3://crabby-images/3581e/3581eeeebaffd95339cd322e440a4de621e60f3d" alt=""
Step 5:
Now Setup Screen appears and copy paste the values from your POSTMAN as per mapping shown below.Save it once done.
data:image/s3,"s3://crabby-images/4e388/4e388ab3bda6a162fbfbf4c4216c0356d110c4d3" alt=""
Step 6:
Now Navigate to Resources and update the GET and DELETE operation to take input from your request ( User email id to be read or to be deleted ) .
data:image/s3,"s3://crabby-images/3c773/3c7733fe496201b0cea21309247795afb165d4f9" alt=""
Step 7:
Navigate to API Docs to visualize your newly created APIs look and click on Authenticate Instance to create new instance
data:image/s3,"s3://crabby-images/edb1a/edb1a0a8e98605c138d23e176240b8e7a1b4159a" alt=""
Step 8:
New window opens and populate Client ID and Client Secret you have generated from G-Suite Developer console.
data:image/s3,"s3://crabby-images/6a43b/6a43b0552adcf5bd4b40ac79f4f5461ef0f423fb" alt=""
Step 9:
Now you have successfully created G-Suite Element from your POSTMAN and it will be visible in Private section of overview page.
data:image/s3,"s3://crabby-images/ba71b/ba71bb2c976ef9b10f3e4a53140194a08975a491" alt=""
Make sure you have copied User,Organization and Element secret from instance you have created to configure SAP CPI Open Connectors Adapter.