Skip to content

Role Types

Volker Hilsheimer edited this page Jan 31, 2022 · 2 revisions

Each subdirectory within the roles directory represents a role. minicoin will automatically set up the respective provisioning, depending on the directory contents.

For each role specified, minicoin will set up one or more vagrant provisioners depending on the contents of the respective role directory. Docker containers can be run using the special role type docker.

As far as the provisioning is executed on the guest, it will be run with root privileges.

Scripted

Minicoin will always look for a provisioning script file; provision.sh for linux/macOS guests, and provision.cmd or provision.ps1 file for Windows guests. Such a script will be executed on the guest using shell provisioning.

The script will receive the name of the role for which it was run, the name of the machine, and the user name on the host, as command line arguments.

If the role is parameterized, then the parameters are passed to the provisioning script as named arguments.

- name: parameterized
  box: generic/ubuntu1804
  roles:
    - role: arguments
      param1: foo
      param2: bar

the script roles/arguments/provision.sh will be called with arguments --param1 foo --param2 bar in the example above.

Scripted provisioning is always done for roles that provide a provision script, even if there is another provisioner type (such as ansible or disk) present for that role.

As a special case, the script role can be used to execute an inline script on the guest, ie.

- name: hello
  box: generic/ubuntu1804
  roles:
    - role: script
      script: "echo Hello World"

Host-side scripting

Roles can provide pre-provision.sh and post-provision.sh script files; those will be executed on the host before and after the guest is being provisioned, respectively. This functionality is not available when using minicoin on a Windows host.

In addition, the hostscript role allows the definition of inline scripts that will be run as pre- and post-provisioning steps on the host:

- name: verbose
  box: generic/ubuntu1804
  roles:
    - role: hostscript
      preprovision: "wget latest_keys"
      postprovision: "rm latest_keys"

Uploading files

To upload a file or directory to the guest during provisiniong, use the upload role, and specify a list of local files and remote destinations, e.g:

- name: box
  box: generic/ubuntu1804
  roles:
    - role: upload
      files:
        ~/.ssh/id_rsa: ~/.ssh/id_rsa

The local file needs to exist on the host. On the guest, the necessary directory structure will be created automatically.

Mutagen file system sync

Use the mutagen role to sync local directories to the guest file system.

- name: box
  box: generic/ubuntu1804
  roles:
    - role: mutagen
      paths:
        - ~/qt/dev/qtbase
        - ~/qt/dev/qtdeclarative

If mutagen is available on the host, then the sync will be created on the host. Otherwise (or if the reverse attribute is set to true), mutagen will be installed on the guest, and will communicate to the host system via ssh (which requires an SSH server on the host).

For cloud VMs, mutagen needs to be installed on the host.

Docker

minicoin can build a Dockerfile, or run a docker image.

To run an image, use the role type docker, and specify the image and other options as parameters:

  - name: webserver
    box: generic/ubuntu1804
    roles:
      - docker: name # name of the container
        image: # mandatory; name of the image; will be pulled if needed
        args: # optional; arguments to be passed to `docker run`
        cmd: # optional; command to execute, overrides default CMD of the image
        restart: # optional; defaults to "always", can be "no"
        detach: # optional; defaults to true, can be "false"

If minicoin finds a Dockerfile in the role directory, then the Dockerfile will be built. Parameters are passed to the docker build run:

  - name: db-server
    box: generic/ubuntu1804
    roles:
      - role: builder
        tag: builder/wasm:5.13

This will call docker build --rm --tag builder/wasm:513.

Ansible

If minicoin finds a playbook.yml file, then the machine will be provisioned using ansible.

Disks

If minicoin finds a disk.yml file, then a disk or drive will be inserted or attached.

file: filename # .iso for a DVD, or .vdi for a drive
archive: archive.zip # a compressed file for downloading

A file attribute can point to an ISO image, which will be inserted as a DVD into the guest VM. If file points to a VDI file, then that file will be attached as a harddrive. An ISO image can be attached to multiple guests; a VDI can as well, but each guest will perform write operations to a separate VDI file.

The drive image file will be looked for in the hidden .diskcache folder. If the file does not exist, then the archive attribute can point at a zip-file that can be downloaded from one of the global URLs under the disks key.

Disk are inserted or attached during boot time and before any other provisioners are run. Boxes might need to specify how the disk can be attached by setting parameters in the provisioner, e.g

- name: linux
  box: generic/ubuntu1804
  roles:
    - role: disk
      storagectl: IDE # defaults to SATA
      port: 1 # default to 1 for ISO, 2 for VDI
      mtype: standard # defaults to multiattach for VDI

Provider-specific provisioning

It's possible to specify provider-specific settings. Many of these changes will only have an effect when the box is created, and cannot be changed during later provisioning, or when the box is already running.

See the Provider Notes for provider-specific provisioning roles.