- IMPORTANT - There is currently a bug with Policy Buckets for UCS Domain Profiles. That is the only reason ucs_domain_profiles are not in the same folder as chassis and servers. When this is fixed the ucs_domain_profiles folder will be merged with the profiles folder. Because of this limitation at this time make sure to create a seperate policy for Domains of the following types:
- network_connectivity_policies - If Using Standalone Server Policies
- ntp_policies - If Using Standalone Server Policies
- snmp_policies
- syslog_policies
- Python 3.6 or Greater
- Refer to requirements.txt for libraries needed to be installed or simply install the requirements file as shown below:
pip install -r requirements.txt
The script utilizes features introduced in 0.14 of Terraform. So we need 0.14 or preferrably >1.0
This script will utilize the Intersight Terraform Provider and two modules built off of the Intersight Provider.
- It is recommend to add the following secure variables to your environment before running the script
## Intersight Variables
export TF_VAR_apikey="<your_intersight_api_key>"
export TF_VAR_secretkey=`cat ~/Downloads/SecretKey.txt`
# The above example is based on the key being in your Downloads folder. Correct for your environment
## Terraform Cloud Variables
export TF_VAR_terraform_cloud_token="<your_terraform_cloud_token>"
- Running the wizard to use a configuration migrated from UCS Manager using the IMM Transition Tool
./main.py -j {json_file_name.json}
- Running the Wizard to generate IaC through a Question and Answer Wizard
./main.py
- Help Information
./main.py -h
Intersight Easy IMM Deployment Module
optional arguments:
-h, --help show this help message and exit
-a API_KEY_ID, --api-key-id API_KEY_ID
The Intersight API client key id for HTTP signature scheme
-s API_KEY_FILE, --api-key-file API_KEY_FILE
Name of file containing The Intersight secret key for the HTTP signature scheme
--api-key-v3 Use New API client (v3) key
-d DIR, --dir DIR The Directory to Publish the Terraform Files to.
-i, --ignore-tls Ignore TLS server-side certificate verification
-j JSON_FILE, --json_file JSON_FILE
The IMM Transition Tool JSON Dump File to Convert to HCL.
-u URL, --url URL The Intersight root URL for the API endpoint. The default is https://intersight.com
After the Script has generated the Terraform Directories and downloaded the resources from the Easy IMM Repository, the data will need to be pushed to Intersight using Terraform Cloud. It is important to execute the Workspaces in the following Order:
- pools and ucs_domain_profiles*
- policies
- profiles
- It doesn't matter if you run pools or ucs_domain_profiles first as there is no dependency between both of them. Both Just need to be run before you run policies and profiles.
This code is provided as is. No warranty, support, or guarantee is provided with this. But in typical github fashion there is the opportunity to collaborate and share Bug's/Feedback/PR Requests.
The purpose of this Python Tool is to deploy Policy/Profiles to Intersight using Infastructure as Code with Terraform. The Wizard is a step for users to create and better understand how to utilize Terraform for managing infrastrudture.
The goal of this module is to begin to familiarize you with Terraform through the following steps:
- Begin to familiarize users with Terraform format and variable creation.
- Once a user feels conformatable with auto generated files, Transition towards writing your own modules to consume the IMM Modules.
- And lastly build your confidence to write your own code as well.
The wizard will show after each section what the Terraform code being generated will look like. Point you to the directly where the code will be stored. And lastly, publish the code to Terraform Cloud and when you are ready.
- Use Cases
- Create Pools
- Create Policies
- Deploy UCS Domains in IMM Mode
- Create UCS Service Profiles and Templates
- Create Pools
- Create Policies
- Create UCS Domain Profiles and attach Fabric Interconnects to the profiles
- Create Service Profiles and Templates and deploy physical infrastructure
This set of modules support creating the following Pool Types:
- FC Pools
- IP Pools
- IQN Pools
- MAC Pools
- UUID Pools
This set of modules support creating the following Policy Types:
- Adapter Configuration
- BIOS
- Boot Order
- Certificate Management
- Device Connector
- Ethernet Adapter
- Ethernet Network
- Ethernet Network Control
- Ethernet Network Group
- Ethernet QoS
- Fibre Channel Adapter
- Fibre Channel Network
- Fibre Channel QoS
- IMC Access
- Flow Control
- IPMI Over LAN
- iSCSI Adapter
- iSCSI Boot
- iSCSI Static Target
- LAN Connectivity
- LDAP
- Link Aggregation
- Link Control
- Local User
- Multicast
- Network Connectivity
- NTP
- Persistent Memory
- Port
- Power
- SAN Connectivity
- SD Card
- Serial over LAN
- SMTP
- SNMP
- SSH
- Storage
- Switch Control
- Syslog
- System QoS
- Thermal
- Virtual KVM
- Virtual Media
- VLAN
- VSAN
This set of modules support creating the following Profile Types:
- UCS Chassis Profile
- UCS Domain Profile
- UCS Server Profile
- UCS Server Template - Important Note. The script only uses Server Templates for holding policies. This allows for flexibility around allowing the script to override policies by assigning unique policies to servers that is not supported by standard templates.
To sum this up... the goal is to deploy the infrastructure using Terraform through an easy to consume wizard.
Youtube Video's to follow. This is still a work in progress