This post describes how to perform VCF bringup via Ansible. If you need another VCF related ansible playbooks check rest of my blog posts in here.

Backing to VCF bringup, my folder structure is as follow:

startVcfBringup.yml
/roles/
  /runVcfBringup/
    /defaults/
      main.yml
    /tasks/
      main.yml
      validateVcfBringup.yml
      startVcfBringup.yml

startVcfBringup.yml playbook

# Playbook performs validation and deployment of SDDC via CloudBuilder API
---
- name: Start VCF bringup
  hosts: localhost
  gather_facts: false
  vars_files:
    - group_vars/myVars
  tasks:
    - name: Import role runVcfBringup
      include_role:
        name: runVcfBringup

 


  • Top 18 Best Web Hosting Services In 2024: Despite there are multiple web hosting providers available in the market, choosing the best one is really a hard nut to crack!! Because almost all service providers are offering their services with the same features and quality.
  • How to start your own Crypto currency website: For a cryptocurrency news website, choosing the right Content Management System (CMS) is crucial for managing content effectively, ensuring security, and providing a great user experience. Here are some of the best CMS options tailored for such a site, each with its unique strengths:
  • The Evolution of Coffee Brewing Methods: A Historical Perspective: Coffee has been brewed and enjoyed for centuries, with various methods evolving over time to create the perfect cup of joe. From early methods like the Ibrik method and coffee pots for coffee houses to modern technologies like the AeroPress and Hario V60, the world of coffee brewing has come a long way.
  • Stop WordPress from Creating Extra Cropped Image Sizes: Whenever you upload an image to your WordPress site through the media library, it automatically creates and stores multiple additional versions of that image. If your site doesn’t utilize these extra image sizes, they will consume valuable storage space and increase the size of your server backups.
  • Explain WordPress Portfolio and how to created them: WordPress portfolios are digital showcases for individuals or businesses to display their work, projects, or professional accomplishments. This feature is particularly useful for creatives, freelancers, and agencies looking to exhibit their skills or services in a visually appealing and organized manner. Portfolios in WordPress can be created using various methods, including themes that come with built-in portfolio functionalities, plugins that add portfolio features, or custom coding for a more personalized approach.
  • 15 Essential WordPress Plugins For Every Site: Plugins are essential for every type of website, as they provide additional features and customization options that are not available in the core WordPress platform. A study by CodeinWP found that the average WordPress site has 20 active plugins, indicating the importance of plugins in website development.
  • SAILING and YACHTING: Awesome Sailing Vlogs for the Enthusiast
  • Comparing Google and Microsoft’s Success in Capitalizing on Generative AI: The buzz of interest in AI services helped drive revenue for Microsoft’s biggest unit, cloud services—up by 7 percentage points compared to a year ago—and Microsoft’s overall sales rose 17 percent to nearly $62 billion. It also gained cloud market share, Nadella added. The number of $100 million cloud deals that Microsoft landed increased 80 percent during the quarter compared to the same period a year ago, and $10 million deals doubled.
  • The Best WordPress Hosting Solution in Australia: Each of our WordPress hosting solutions are fine-tuned, blazing fast and are ready for you! Starting a WordPress website has never been easier with our free 1-click WordPress installation, enterprise-grade security and an assortment of tutorials and helpful guides to get you started, all backed by our 99.9% uptime guarantee.
  • Elementor vs Beaver Builder: A Comparison of Design Flexibility and Performance in WordPress: Elementor and Beaver Builder are two of the most widely recognized options, each providing distinct features that cater to varying user requirements. This article conducts a comprehensive comparison of these tools, examining their design flexibility, performance metrics, and overall user experience.
  • The Best Contact Form Plugins for WordPress to Easily Manage User Inquiries: In an effort to improve user interactions on WordPress websites hosting, the examination of contact form plugins becomes essential. This article aims to present an overview of the top 5 contact form plugins available for WordPress, highlighting their features and pricing structures to facilitate an well-considered choices process.
  • What are the 20 best Joomla plugins: Joomla plugins are small, task-specific extensions that enhance or modify the core functionality of a Joomla website. They operate as event-driven scripts, listening for specific “events” triggered by Joomla or its components and executing corresponding actions. Plugins are a crucial part of Joomla’s extensibility, allowing developers to add features or customise behaviour without altering the core Joomla code.
  • How to design a strong off-page SEO strategy: Lessons learnt from earning over 50,000 contextual links for thousands of websites in the toughest niches. In 2023, virtually every business that has a website is prioritizing their investment in SEO. The reason being, amidst the chaos of the current year, customers are resorting to online channels for safe purchasing, and optimizing their online presence is a surefire way to gain an edge over rivals. While some firms have set up internal teams, and others have hired external agencies to boost their search engine rankings, a documented off-page SEO strategy is still a rarity among most businesses.
  • What are WordPress Plugins? WordPress plugins are modular pieces of software that can be added to a WordPress site to extend or enhance its functionality without modifying the core WordPress code. They allow website owners to add features, improve performance, and customise the behaviour of their websites easily, catering to a wide range of needs, from SEO and security to e-commerce and design enhancements.

 

/roles/runVcfBringup/defaults/main.yml

  • cloudBuilderRestApiSddcValidate – var for Cloud Builder API used for input specification validation.
  • cloudBuilderRestApiSddcCreate: var for Cloud Builder API used triggering the task using the valid input specification.
  • bringupJsonPath – var for location on my ansible host where Deployment Parameter Workbook file converted to json is located (input specification).
---
# defaults file for runVcfBringup

cloudBuilderRestApiSddcValidate: "https://{{ CloudBuilderFQDN }}/v1/sddcs/validations"
cloudBuilderRestApiSddcCreate: "https://{{ CloudBuilderFQDN }}/v1/sddcs"
bringupJsonPath: "/home/admin/vcfBringup.json"
cbAdminUser: "admin"
cbAdminUserPassword: "P@ssw0rd"

/roles/runVcfBringup/tasks/main.yml

---

- name: Validate JSON input for VCF bring up
  import_tasks: validateVcfBringup.yml

- name: Create VCF bringup basing on JSON input
  import_tasks: startVcfBringup.yml

/roles/runVcfBringup/tasks/validateVcfBringup.yml

---
#validateVcfBringup.yml

- name: Trigger VCF parameter Workbook JSON input validation
  uri:
    url: "{{ cloudBuilderRestApiSddcValidate }}"
    method: POST
    user: "{{ cbAdminUser }}"
    password: "{{ cbAdminUserPassword }}"
    validate_certs: no
    force_basic_auth: yes
    return_content: yes
    body_format: json
    body: "{{ lookup('file','{{ bringupJsonPath }}') }}"
    status_code: 200,202
  register: vcfBringupValidation

- name: Register validation task ID
  set_fact:
    validationId: "{{ vcfBringupValidation.json.id }}"

- name: Get validation status
  uri:
    url: "{{ cloudBuilderRestApiSddcValidate }}/{{ validationId }}"
    method: GET
    user: "{{ cbAdminUser }}"
    password: "{{ cbAdminUserPassword }}"
    validate_certs: no
    force_basic_auth: yes
    return_content: yes
    body_format: json
  register: vcfBringupValidationQuery
  until: (vcfBringupValidationQuery.json.resultStatus | lower == 'succeeded') or (vcfBringupValidationQuery.json.resultStatus | lower == 'failed')
  delay: 30
  retries: 200

- name: Show validation report
  debug: 
    var: vcfBringupValidationQuery
    verbosity: 1

- name: Error message if validation failed
  fail:
    msg: 
      - "Validation failed. Failed steps have to be fixed before continue."
  when: vcfBringupValidationQuery.json.resultStatus | lower == 'failed'

- name: No error message if validation is successful
  debug:
    msg: "Validation successful. Proceeding with VCF bring up."
  when: vcfBringupValidationQuery.json.resultStatus | lower == 'succeeded'

/roles/runVcfBringup/tasks/startVcfBringup.yml

---
#startVcfBringup.yml

- name: Start VCF bring-up process
  uri:
    url: "{{ cloudBuilderRestApiSddcCreate }}"
    method: POST
    user: "{{ cbAdminUser }}"
    password: "{{ cbAdminUserPassword }}"
    validate_certs: no
    force_basic_auth: yes
    return_content: yes
    body_format: json
    body: "{{ lookup('file','{{ bringupJsonPath }}') }}"
    status_code: 200,202
  register: vcfBringupCreation

- name: Register creation task ID
  set_fact:
    taskId: "{{ vcfBringupCreation.json.id }}"

- name: Get creation task status
  uri:
    url: "{{ cloudBuilderRestApiSddcCreate }}/{{ taskId }}"
    method: GET
    user: "{{ cbAdminUser }}"
    password: "{{ cbAdminUserPassword }}"
    validate_certs: no
    force_basic_auth: yes
    return_content: yes
    body_format: json
  register: vcfBringupCreationTask
  until: (vcfBringupCreationTask.json.status | lower == 'completed_with_success') or (vcfBringupCreationTask.json.status | lower == 'completed_with_failure')
  delay: 60
  retries: 200

- name: Show creation report
  debug: 
    var: vcfBringupCreationTask
    verbosity: 1

- name: Error message if creation failed
  fail:
    msg: 
      - "VCF bring up failed. Failed steps have to be fixed before continue. Task have to be retried. Task ID: {{ taskId }}"
  when: vcfBringupCreationTask.json.status | lower == 'completed_with_failure'

- name: No error message if creation is successful
  debug:
    msg: "VCF bring up performed successfully."
  when: vcfBringupCreationTask.json.status | lower == 'completed_with_success'

Similar Posts