I have implemented NextCloud in my environment. I need to design a blueprint and let my clients to send their request to access a 5 GB space on NextCloud environment so I decided to integrate my NextCloud to Active Directory then design a XaaS blueprint that run a custom workflow to add my clients username to a specific group that has already accessed 5 GB on NextCloud.
Before working with Active Directory plugin, I should configure my active directory as an endpoint within the vRealize Automation.
I go to the administration\vRO Configuration\endpoints the select new and choose Active directory and configure it as shown below
data:image/s3,"s3://crabby-images/695ac/695acf358068b15aa5c93e2dcf70f9855b7c2d38" alt=""
data:image/s3,"s3://crabby-images/9af02/9af026fca3d78d87a825f1e233b00afa89110566" alt=""
Our workflow contains 3 parts:
- At the first it reads requested username which is a active directory username (Get vRA Requested User)
- Use username string to search in active directory and seek the exact username in AD:User format (getAdUserByname)
- Try to connect the active directory and join in to the NextCloud group which is already accessed to 5GB space on the NextCloud environment (Add a user to a user group)
data:image/s3,"s3://crabby-images/39e2b/39e2b716502367c69771f09ce3092e9e675a3009" alt=""
In the first part I should write a custom script that read a string username from requested packet so I need to create a workflow in vRO
On the workflow tab I create a folder named NextCloud and create this my workflow within it
data:image/s3,"s3://crabby-images/91a78/91a780bc445a5b7356a4c8a58e20fe9f91b81731" alt=""
In the next screen I should go to Schema tab
data:image/s3,"s3://crabby-images/a86c5/a86c52155c6c7cfb83eb437a73ab1eadb5bfd901" alt=""
Now I Should drag a script task to the right window and configure it. I go to the output tab and create a output parameter in string type and named it “vraUser”.
data:image/s3,"s3://crabby-images/3f328/3f3289e264b31fcec3e8c925b11f71110f6980b6" alt=""
In the visual binding tab I connect the vraUser to the output attribute
data:image/s3,"s3://crabby-images/6a6b0/6a6b09f0f94745c97b4fc092d92ece0d46633d07" alt=""
In the Scripting tab I should write the codes below, These codes helps me to fill the vraUser variable with the requested user.
var executionContext = System.getContext();
var vraUser = executionContext.getParameter("__asd_requestedBy");
data:image/s3,"s3://crabby-images/082cd/082cda0551526129f30726c3cf590b4aa30f3e07" alt=""
In the 2nd part I build an action to convert username string to AD:User format and reuse it in the future.Here I have shown how to create an action in vRO.
After login to the vRO client I should go to the Design section and select the action tab then right click on the com.vmware.library.microsoft.activeDirectory and select Add action
data:image/s3,"s3://crabby-images/d1bd1/d1bd120815cc38a1abed2a64e450dd848ccf9c15" alt=""
data:image/s3,"s3://crabby-images/1e8a0/1e8a0e57c763e77853a09f1e153aed244ed83838" alt=""
Click on the Scripting tab and enter this code:
user = ActiveDirectory.searchExactMatch("User", username, 1, adHost)[0];
return user;
Now I need to add attributes that needed here for input section.Click on the right arrow
data:image/s3,"s3://crabby-images/b6102/b61022e2f944afb83a1d4190bcc169ac6cffb963" alt=""
I should create 2 attributes:
- username (String type) and
- adHost (AD:AdHost
data:image/s3,"s3://crabby-images/c9a94/c9a9442fd777fc76d0ee59aa04c016b5fe442087" alt=""
Now I need to define Return type, click on void above the right arrow and set it to AD:User
data:image/s3,"s3://crabby-images/336b3/336b39ce12e72a5575ac833ad23e94cd927b754b" alt=""
The action is ready!
First I put my created action next to my script.
data:image/s3,"s3://crabby-images/cd480/cd480f006f815c15c5bd4212a24bbe890d868645" alt=""
Drag vraUser to connect to the username I fill the username with my script in the first part ( It contains requested user)
data:image/s3,"s3://crabby-images/d8129/d81296afc749b8c1f9b607c265a25b682a33b3c9" alt=""
I also need to connect ad host from the middle window to the “In Attribute”. Here I need to define the adHost which means Active directory Server.
data:image/s3,"s3://crabby-images/34f0d/34f0d70b7f2f1dd55eded0aa2002c3d811141350" alt=""
And select Active directory in the “Value” section
data:image/s3,"s3://crabby-images/40bd6/40bd638034fe39b1640d73aba88260ba655ca519" alt=""
Then connect the actionResult to a space in Out Attributes and named it “vraAdUser”
data:image/s3,"s3://crabby-images/5c2fe/5c2fe8b3874c4cacbfd18250a07eb1b597cf4f4e" alt=""
the last part is putting the prepared workflow named “add a user to a user group”.
data:image/s3,"s3://crabby-images/78da4/78da468426bb8ac3a0e3262b5db25527c1e87147" alt=""
In this section I go and edit this workflow, so I go to the Visual Binding tab and configure it like this:
data:image/s3,"s3://crabby-images/a913a/a913ae920c68f29bca98ff27d8280af6523975af" alt=""
As shown above I connect user to “vraAdUser” which I configure it before in second part and it has contained the requested user in AD:User type and then connect the group and create an “In attribute” and configure it with NextCloud group.
data:image/s3,"s3://crabby-images/d3f94/d3f94e0db31aaaeba8927974f2c85c738c940bf9" alt=""
Click OK and save the workflow.
Now I must go and build a XaaS Blueprint in my vRA.
data:image/s3,"s3://crabby-images/94053/94053a04ffcc8b7ccbe70dffffb365f858109d3f" alt=""
data:image/s3,"s3://crabby-images/84f2d/84f2de04f15ec00d18ad96224a7bce57882bee7a" alt=""
data:image/s3,"s3://crabby-images/a6d6d/a6d6d617fed142614f9ffeb1c5d1aaa3fec1bf51" alt=""
data:image/s3,"s3://crabby-images/2ec58/2ec582a9d0111e436f76382567f58d3b0c991833" alt=""
data:image/s3,"s3://crabby-images/ac919/ac919e8e6c98a72b7ee9956854dc01517ec0a872" alt=""
Don’t forget to publush your XaaS Blueprint
data:image/s3,"s3://crabby-images/52e67/52e67ab9d944042f5808ffe5118d2af95eb2dc06" alt=""
Now I need to go in catalog item and assign this XaaS Blueprint a service
data:image/s3,"s3://crabby-images/d01d9/d01d94003259af4a65dca03696f3678f0be36cd0" alt=""
data:image/s3,"s3://crabby-images/31eba/31ebaa36fb9c6db24fa4edc6813b9991483c8de9" alt=""
Mission has completed.