I wanted to give my users the capability to create a snapshot but limit them to only 1 snapshot and have a predefined description from the snapshot so i can know that it was taken from vRA.
For the purpose of this i will be using a customer workflow in Orchestrator and Resource Actions and in Cloud Assembly.
Since Orchestrator comes with a number of pre defined workflows in always like to jump start by find something thats similar with what im trying to do. For the purpose of this we will be using the Create Snapshot Workflow.
To get started we can go to Orchestrator -> Workflows -> search for Create a snapshot. Once found we can click on Actions -> Duplicate
data:image/s3,"s3://crabby-images/83822/83822497e3f4aa4b27c89cbee99e146423bbaa6c" alt="image Cosmin`s Blog"
We can see that a Copy has been created. We will modify this so it can fit the custom specifications required.
Click on Open on the Copy:
data:image/s3,"s3://crabby-images/82d23/82d231ea33ffb98b9448e3d5c3b8d7885be5337b" alt="image1 Cosmin`s Blog"
Change the name to something more meaningful like VM Snapshot
data:image/s3,"s3://crabby-images/9f42a/9f42a7ce414a39799382bd313c46a9ba1fdeaeb5" alt="image2 Cosmin`s Blog"
Click on Variables, select all the variables and click Delete
data:image/s3,"s3://crabby-images/76423/764233fda0f6ea8296f46b9e440f04c884035010" alt="image3 Cosmin`s Blog"
Click on New, give it a title like errMachineHasSnapshot and a value thatw ill displayed if a VM has an existing snapshot like The virtual machine already has a snaphost. Please delete this snapshot before trying this action again. Click Create
data:image/s3,"s3://crabby-images/1a81c/1a81c85c215d978a3227b08059b19743463a45fc" alt="image4 Cosmin`s Blog"
Click on the Schema tab and delete the existing items by clicking on the red x on the top right corner
data:image/s3,"s3://crabby-images/2ee6e/2ee6eadcf9e6a94607b362a4baee5db06625e911" alt="image6 Cosmin`s Blog"
Drag and drop from the left a Decision, throw exception and a workflow element in to the canvas
data:image/s3,"s3://crabby-images/313f0/313f091c847d0ed3f89da520760674e3c5ccd5a2" alt="image7 Cosmin`s Blog"
I named the first step VM Has Snapshot?. Under inputs i added vm. It would look like the screenshot below
data:image/s3,"s3://crabby-images/5c341/5c341702b4559df26f43f20aa2fc95cfd92b76af" alt="image8 Cosmin`s Blog"
Under the javascript we will be using this code
var snapshots = System.getModule("com.vmware.library.vc.vm.snapshot").getAllSnapshotsOfVM(vm) ;
if (snapshots == null || snapshots.length == 0) {
// No snapshots found; proceed with creating a new one
return true;
} else {
// Found at least one snapshot; end the workflow
return false;
}
data:image/s3,"s3://crabby-images/21e11/21e117eeaae2e0ec1c882969b1ff0ee47252fd30" alt="image12 Cosmin`s Blog"
The error handling Exception Handling we will be using the previously created errMachineHasSnapshot
data:image/s3,"s3://crabby-images/23fc6/23fc679ca4dacea50e1eeac4f2f6ac7862bdfbc6" alt="image13 Cosmin`s Blog"
The workflow element should look like this after selecting the Workflow Create a snapshot
data:image/s3,"s3://crabby-images/95617/956175ff0fae2cf86a05e392584aaf29b5bdd5d2" alt="image9 Cosmin`s Blog"
The next step is to fix the inputs. We will be removing the Choose the VM tab by clicking on the x
data:image/s3,"s3://crabby-images/24c9f/24c9f0b5d4c2adcb1eb369661685c55fc9a82764" alt="image10 Cosmin`s Blog"
data:image/s3,"s3://crabby-images/6469f/6469fe74e94ee6c64b6c1af32ba2659ccadad983" alt="image11 Cosmin`s Blog"
We will be replacing the first item with vm and the display type
data:image/s3,"s3://crabby-images/ca92e/ca92e6f236efee1ed33652e009a9890c05056083" alt="image14 Cosmin`s Blog"
It should look like this:
data:image/s3,"s3://crabby-images/29bdf/29bdf25c74833f98fb91ee40325def537a367281" alt="image15 Cosmin`s Blog"
In the end we should have the following:
data:image/s3,"s3://crabby-images/2301d/2301d3ad3720ce8198ead45d9ee9d36991a2ad08" alt="image16 Cosmin`s Blog"
Next go to Actions and click on New Action
data:image/s3,"s3://crabby-images/ca352/ca352b6a5dbd52cc818eff5bd342d0ff3ccf6dbf" alt="image23 Cosmin`s Blog"
Give it a Name and a Module name
data:image/s3,"s3://crabby-images/eb5b8/eb5b8707fb2e0cc2fc492445cbe75e207d952255" alt="image24 Cosmin`s Blog"
Under Script type in
var allVms = VcPlugin.getAllVirtualMachines();
for (var I in allVms) {
if (allVms[I].name === name) {
return allVms[I];
}
}
return null;
data:image/s3,"s3://crabby-images/06499/06499b27811454ea09f82da0c254fd593901813a" alt="image25 Cosmin`s Blog"
Under the Return type enter VC:VirtualMachine. Under the Inputs type in name and click Create on the bottom left
data:image/s3,"s3://crabby-images/e9d06/e9d06030e157927870147529fc004a211ec12f50" alt="image26 Cosmin`s Blog"
Once were done we can save it and move on to Cloud assembly to create the resource action
Go to Cloud Assembly -> Design -> Resource Actions click on new resource action
data:image/s3,"s3://crabby-images/22e63/22e63c82369f5b06e06b13bf6091a92e60ad7ff2" alt="image17 Cosmin`s Blog"
In the name field type something like CustomSnapshot, Display name VM Snapshot, give a description and toggle the activate switch to on
data:image/s3,"s3://crabby-images/50243/50243f15adf1765b56013b613f896a21a3305758" alt="image18 Cosmin`s Blog"
Under Resource type click on add pick Cloud.vSphere.Machine
data:image/s3,"s3://crabby-images/ba913/ba913597f302c8d1d2ed9ac9b63e3254e18fcc6c" alt="image19 Cosmin`s Blog"
Under Workflow click Add and pick VM Snapshot
data:image/s3,"s3://crabby-images/390e3/390e349943778deae6b697240e702ab769d37542" alt="image20 Cosmin`s Blog"
In the Property Binding pick getVmByName action and under string enter ${properties.resourceName}
data:image/s3,"s3://crabby-images/b5755/b575513fe580795b72b085cb9659e695b9b7b994" alt="image28 Cosmin`s Blog"
On the bottom click on edit request parameters
data:image/s3,"s3://crabby-images/20502/20502d6027dfc19b03928719ce3fe0f2a99e4ec4" alt="image29 Cosmin`s Blog"
click on vm and change the Label to Reason and Display type to DropDown
data:image/s3,"s3://crabby-images/87818/878181335f3fbcd0e03b55e07f3d39460b9dd642" alt="image30 Cosmin`s Blog"
Under Values Type in the options that you want to have shown Separated by , ex: Patching,New Release
data:image/s3,"s3://crabby-images/21715/21715fb3380a3040667b5625f31b391c721bde8b" alt="image31 Cosmin`s Blog"
Under Constraints make it as required by Picking Yes in the required field
data:image/s3,"s3://crabby-images/860e7/860e7251525ec6031d9f707f8d7ba374e5d1c466" alt="image32 Cosmin`s Blog"
The other fields and options can be modified as needed
Once everything is saved we can test out the Day 2 action by going to an existing deployment and trying to create a snapshot. We can see in the menu an additional option all the way to the bottom:
data:image/s3,"s3://crabby-images/5ca67/5ca6761b8938774dd159a4b6ad3d54718f7360ba" alt="image33 Cosmin`s Blog"
When choosing the option we can see the custom form that we filled in earlier
data:image/s3,"s3://crabby-images/6b104/6b104da629fac3c0a9436c3858d70e18252c16ab" alt="image34 Cosmin`s Blog"