{% extends "base.html" %} {% load i18n %} {% load static %} {% load bootstrap_icons %} {% block title %}{% trans "Create new instance" %}{% endblock %} {% block style %} <link href="{% static "css/bootstrap-multiselect.css" %}" rel="stylesheet"> {% endblock %} {% block page_heading %} {% blocktrans with host=compute.name %}New instance on {{ host }} {% endblocktrans %} {% endblock page_heading %} {% block content %} {% include 'pleasewaitdialog.html' %} {% if form.errors %} {% for field in form %} {% for error in field.errors %} <div class="alert alert-danger"> <strong>{{ field.label }}:</strong> <span>{{ error|escape }}</span> </div> {% endfor %} {% endfor %} {% for error in form.non_field_errors %} <div class="alert alert-danger"> <strong>{{ error|escape }}</strong> </div> {% endfor %} {% endif %} <div class="row"> <div class="col-lg-12"> <div role="tabpanel"> <!-- Nav tabs --> <ul class="nav nav-tabs" role="tablist" aria-label="Instance create method"> <li class="nav-item" role="presentation"> <button class="nav-link float-end" data-bs-toggle="tab" data-bs-target="#" type="button" role="tab" aria-controls="go_compute" onclick="goto_compute()"> <span>{% bs_icon 'arrow-left'%} </span> </button> </li> <li class="nav-item" role="presentation"> <button class="nav-link active" data-bs-toggle="tab" data-bs-target="#flavor" type="button" role="tab" aria-controls="flavor" aria-selected="true"> {% trans "Flavor" %} </button> </li> <li class="nav-item" role="presentation"> <button class="nav-link" data-bs-toggle="tab" data-bs-target="#addCustom" type="button" role="tab" aria-controls="addCustom" aria-selected="false"> {% trans "Custom" %} </button> </li> <li class="nav-item" role="presentation"> <button class="nav-link" data-bs-toggle="tab" data-bs-target="#add-from-temp" type="button" role="tab" aria-controls="add-from-temp" aria-selected="false"> {% trans "Template" %} </button> </li> </ul> <!-- Tab panes --> <div class="tab-content"> <div role="tabpanel" class="tab-pane tab-pane-bordered active" id="flavor"> {% include 'create_flav_block.html' %} <h3 class="page-header">{% trans "Create from flavor" %}</h3> {% if not flavors %} <div class="col-lg-12"> <div class="alert alert-warning shadow-sm"> {% bs_icon 'exclamation-triangle'%} <strong>{% trans "Warning" %}:</strong> {% trans "Hypervisor doesn't have any Flavors" %} </div> </div> {% else %} <div class="table-responsive"> <table class="table table-hover"> <thead> <tr> <th scope="col">#</th> <th scope="col">{% trans "Name" %}</th> <th scope="col">{% trans "VCPU" %}</th> <th scope="col">{% trans "RAM" %}</th> <th scope="col">{% trans "HDD" %}</th> <th scope="colgroup" colspan="2">{% trans "Action" %}</th> </tr> </thead> <tbody> {% for flavor in flavors %} <tr> <td>{{ forloop.counter }}</td> <td>{{ flavor.label }}</td> <td>{{ flavor.vcpu }}</td> <td>{{ flavor.memory }} {% trans "MB" %}</td> <td>{{ flavor.disk }} {% trans "GB" %}</td> <td style="width:5px;"> <div class="modal fade" id="addVMflavor{{ forloop.counter }}" tabindex="-1" role="dialog" aria-labelledby="addVMFlavorLabel" aria-hidden="true"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title">{% trans "Create Virtual Machine" %} ({{ flavor.label }})</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> <form method="post" role="form" aria-label="Create instance from flavor form">{% csrf_token %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Name" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="name" placeholder="{% trans "Name" %}" maxlength="64" required pattern="[a-zA-Z0-9\.\-_]+"> <input type="hidden" name="vcpu" value="{{ flavor.vcpu }}"> <input type="hidden" name="memory" value="{{ flavor.memory }}"> <input type="hidden" name="hdd_size" value="{{ flavor.disk }}"> </div> </div> {% if firmwares %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Firmware" %}</label> <div class="col-sm-7"> <select class="form-select" id="select_firmware" name="firmware"> {% for frm in firmwares %} <option value="{{ frm }}" {% if frm in default_firmware %}selected{% endif %}>{{ frm }}</option> {% endfor %} </select> </div> </div> {% endif %} {% if dom_caps.cpu_modes %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "VCPU Config" %}</label> <div class="col-sm-7"> <select class="form-select" id="vcpu_mode" name="vcpu_mode"> <option value=""> {% trans 'no-mode' %}</option> {% for mode in dom_caps.cpu_modes %} {% if mode == 'custom' %} <optgroup label="Custom CPU Models"> {% for model in dom_caps.cpu_custom_models %} <option value="{{ model }}"> {% trans model %}</option> {% endfor %} </optgroup> {% else %} <option value="{{ mode }}" {% if mode == default_cpu_mode %}selected {% endif %}> {% trans mode %} </option> {% endif %} {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Storage" %}</label> <div class="col-sm-7"> <input type="hidden" name="cache_mode" value="default"> <select class="form-select" name="storage"> {% if storages %} {% for storage in storages %} <option value="{{ storage }}">{{ storage }}</option> {% endfor %} {% else %} <option value="">{% trans "None" %}</option> {% endif %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Network" %}</label> <div class="col-sm-7"> <select class="form-select" name="networks"> {% for network in networks %} <option value="{{ network }}">{{ network }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Advanced" %}</label> <div class="d-grid col-sm-7"> <button class="btn btn-outline-light" type="button" data-bs-toggle="collapse" data-bs-target="#flav-add-collapse" aria-expanded="false" aria-controls="flav-add-collapse"> <span>{% bs_icon 'caret-down'%} </span> </button> </div> </div> <div class="collapse" id="flav-add-collapse"> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "MAC" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="mac" maxlength="17" value="{{ mac_auto }}" required pattern="[a-zA-Z0-9:]+"> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "NWFilter" %}</label> <div class="col-sm-7"> <select class="form-select" name="nwfilter"> <option value="">{% trans "None" %}</option> {% for nwfilter in nwfilters %} <option value="{{ nwfilter }}">{{ nwfilter }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "NIC Type" %} </label> <div class="col-sm-7"> <select class="form-select" name="net_model"> {% for model in net_models_host %} <option value="{{ model }}" {% if model == default_nic_type %} selected {% endif %}>{{ model }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "HDD cache mode" %}</label> <div class="col-sm-7"> <select class="form-select" id="cache_mode" name="cache_mode"> {% for mode, name in cache_modes %} <option value="{{ mode }}" {% if mode == default_cache %}selected {% endif %}> {% trans name %}</option> {% endfor %} </select> </div> </div> {% if dom_caps.graphics_support == 'yes' %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Graphics" %}</label> <div class="col-sm-7"> <select class="form-select" name="graphics"> {% for graphics in dom_caps.graphics_types %} <option value="{{ graphics }}" {% if default_graphics == graphics %}selected{% endif %}>{{ graphics }}</option> {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Video" %}</label> <div class="col-sm-7"> <select class="form-select" name="video"> {% if not videos %} <option value="vga">vga</option> <option value="cirrus">cirrus</option> {% endif %} {% for video in videos %} <option value="{{ video }}" {% if default_video == video %}selected{% endif %}>{{ video }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Console Access" %}</label> <div class="col-sm-7"> <select class="form-select" name="listener_addr"> {% for addr, label in listener_addr %} <option value="{{ addr }}" {% if addr == "0.0.0.0" %} selected {% endif %}>{{ label }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Console Password" %}</label> <div class="col-sm-7"> <input class="form-control" type="password" name="console_pass" placeholder="{% trans "Console Password" %}" maxlength="64"> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Add CD-Rom" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_cdrom" name="add_cdrom"> <option value="None" {% if bus == default_cdrom %}selected{% endif %}>--{% trans "False" %}--</option> {% for bus in disk_buses %} <option value="{{ bus }}" {% if bus == default_cdrom %}selected {% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Add Input Device" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_input" name="add_input"> <option value="None" {% if bus == default_input_device_bus %}selected{% endif %}>--{% trans "False" %}--</option> {% for bus in input_device_buses %} <option value="{{ bus }}" {% if bus == default_input_device_bus %}selected{% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-4 col-form-label">{% trans "Guest Agent" %}</label> <div class="col-sm-7"> <input type="checkbox" name="qemu_ga" value="true" checked> </div> </div> {% if virtio_support %} <div class="row"> <label class="col-sm-4 col-form-label">{% trans "VirtIO" %}</label> <div class="col-sm-7"> <input type="checkbox" name="virtio" value="{{ virtio_support }}" checked> </div> </div> {% endif %} </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">{% trans "Close" %}</button> {% if storages %} <button type="submit" class="btn btn-primary" name="create">{% trans "Create" %}</button> {% else %} <button class="btn btn-primary disabled">{% trans "Create" %}</button> {% endif %} </div> </form> </div> </div> </div> <a data-bs-toggle="modal" href="#addVMflavor{{ forloop.counter }}" class="btn btn-sm btn-secondary"> <span >{% bs_icon 'plus'%} </span> </a> </td> <td style="width:5px;"> <form action="{% url 'instances:flavor_delete' flavor.id %}" method="post" role="form" aria-label="Delete flavor form"> {% csrf_token %} <button type="submit" class="btn btn-sm btn-secondary" name="delete_flavor" onclick="return confirm('{% trans "Are you sure?" %}')"> {% bs_icon 'trash' %} </button> </form> </td> </tr> {% endfor %} </tbody> </table> </div> {% endif %} <div class="clearfix"></div> </div> <div role="tabpanel" class="tab-pane tab-pane-bordered" id="addCustom"> <div> <form method="post" role="form" aria-label="Create custom instance form">{% csrf_token %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Name" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="name" placeholder="{% trans "Name" %}" maxlength="64" required pattern="[a-zA-Z0-9\.\-_]+"> </div> </div> {% if firmwares %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Firmware" %}</label> <div class="col-sm-7"> <select class="form-select" id="select_firmware" name="firmware"> {% for frm in firmwares %} <option value="{{ frm }}" {% if frm == default_firmware %}selected{% endif %}>{{ frm }}</option> {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VCPU" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="vcpu" value="1" maxlength="2" required pattern="[0-9]"> </div> </div> {% if dom_caps.cpu_modes %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VCPU Config" %}</label> <div class="col-sm-7"> <select class="form-select" id="vcpu_mode" name="vcpu_mode"> <option value=""> {% trans 'no-mode' %}</option> {% for mode in dom_caps.cpu_modes %} {% if mode == 'custom' %} <optgroup label="Custom CPU Models"> {% for model in dom_caps.cpu_custom_models %} <option value="{{ model }}"> {% trans model %}</option> {% endfor %} </optgroup> {% else %} <option value="{{ mode }}" {% if mode == default_cpu_mode %}selected {% endif %}> {% trans mode %} </option> {% endif %} {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "RAM" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="memory" value="512" maxlength="5" required pattern="[0-9]+"> </div> <label class="col-sm-1 col-form-label">{% trans "MB" %}</label> </div> <div id="disk_list_div" class="row d-none"> <label class="col-sm-3 col-form-label" id="added_disks">{% trans "Added Disks" %}</label> <div class="col-sm-7"> <ul id="img-list" class="row"> <!-- populated from javascript --> </ul> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "HDD" %}</label> <input id="images" name="images" type="hidden" value=""/> <div class="col-sm-3"> <select class="form-select" id="storage-control" name="storage-control" onchange="get_cust_vols({{ compute_id }}, value);"> {% if storages %} <option value disabled selected>{% trans "Select pool" %}...</option> {% for storage in storages %} <option value="{{ storage }}" >{{ storage }}</option> {% endfor %} {% else %} <option value="">{% trans "None" %}</option> {% endif %} </select> </div> <div class="col-sm-4"> <select class="form-select" id="image-control" name="image-control" multiple="multiple"> <!-- populated from javascript --> </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Network" %}</label> <div class="col-sm-7"> <ul id="net-list"> <!-- populated from javascript --> </ul> <input id="networks" type="hidden" name="networks" value=""/> <select class="form-select" id="network-control" name="network-control" multiple="multiple"> {% for network in networks %} <option value="{{ network }}">{{ network }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Advanced" %}</label> <div class="d-grid col-sm-7"> <button class="btn btn-outline-light" type="button" data-bs-toggle="collapse" data-bs-target="#custadvcollapse" aria-expanded="false" aria-controls="custadvcollapse"> <span>{% bs_icon 'caret-down'%} </span> </button> </div> </div> <div class="collapse" id="custadvcollapse"> <div class="row meta-prealloc"> <label class="col-sm-3 col-form-label">{% trans "Disk Metadata" %}</label> <div class="col-sm-7"> <input type="checkbox" name="meta_prealloc" title="{% trans "Metadata preallocation" %}" value="true"> </div> <label class="col-lg-1 col-form-label">{% trans "Image" %}</label> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "HDD Cache Mode" %}</label> <div class="col-sm-7"> <select class="form-select" id="cache_mode" name="cache_mode"> {% for mode, name in cache_modes %} <option value="{{ mode }}" {% if mode == default_cache %}selected {% endif %}> {% trans name %}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "NWFilter" %}</label> <div class="col-sm-7"> <select class="form-select" name="nwfilter"> <option value="">{% trans "None" %}</option> {% for nwfilter in nwfilters %} <option value="{{ nwfilter }}">{{ nwfilter }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "NIC Type" %} </label> <div class="col-sm-7"> <select class="form-select" name="net_model"> {% for model in net_models_host %} <option value="{{ model }}" {% if model == default_nic_type %} selected {% endif %}>{{ model }}</option> {% endfor %} </select> </div> </div> {% if dom_caps.graphics_support == 'yes' %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Graphics" %}</label> <div class="col-sm-7"> <select class="form-select" name="graphics"> {% for graphics in dom_caps.graphics_types %} <option value="{{ graphics }}" {% if default_graphics == graphics %}selected{% endif %}>{{ graphics }}</option> {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Video" %}</label> <div class="col-sm-7"> <select class="form-select" name="video"> {% if not videos %} <option value="vga">vga</option> <option value="cirrus">cirrus</option> {% endif %} {% for video in videos %} <option value="{{ video }}">{{ video }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Console Access" %}</label> <div class="col-sm-7"> <select class="form-select" name="listener_addr"> {% for addr, label in listener_addr %} <option value="{{ addr }}" {% if addr == "0.0.0.0" %} selected {% endif %}>{{ label }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Console Password" %}</label> <div class="col-sm-7"> <input type="password" class="form-control" name="console_pass" placeholder="{% trans "Console Password" %}" maxlength="64"> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Add CD-Rom" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_cdrom" name="add_cdrom"> <option value="None" {% if bus == default_cdrom %}selected{% endif %} >--{% trans "False" %}--</option> {% for bus in disk_buses %} <option value="{{ bus }}" {% if bus == default_cdrom %}selected {% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Add Input Device" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_input" name="add_input"> <option value="None" {% if bus == default_input_device_bus %}selected{% endif %}>--{% trans "False" %}--</option> {% for bus in input_device_buses %} <option value="{{ bus }}" {% if bus == default_input_device_bus %}selected{% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Guest Agent" %}</label> <div class="col-sm-6"> <input type="checkbox" name="qemu_ga" value="true" checked> </div> </div> {% if virtio_support %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VirtIO" %}</label> <div class="col-sm-6"> <input type="checkbox" name="virtio" value="{{ virtio_support }}" checked> </div> </div> {% endif %} </div> <div class="row"> <div class="d-grid col-sm-7 offset-3"> {% if storages %} <button type="submit" class="btn btn-primary" name="create" formnovalidate onclick="showPleaseWaitDialog()" value="1"> {% trans "Create" %} </button> {% else %} <button class="btn btn-primary disabled"> {% trans "Create" %} </button> {% endif %} </div> </div> </form> </div> <div class="clearfix"></div> </div> <div role="tabpanel" class="tab-pane tab-pane-bordered" id="add-from-temp"> <div> <form method="post" role="form" aria-label="Create instance from template form">{% csrf_token %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Name" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="name" placeholder="{% trans "Name" %}" maxlength="64" required pattern="[a-zA-Z0-9\.\-_]+"> </div> </div> {% if firmwares %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Firmware" %}</label> <div class="col-sm-7"> <select class="form-select" id="select_firmware" name="firmware"> {% for frm in firmwares %} <option value="{{ frm }}" {% if frm == default_firmware %}selected{% endif %}>{{ frm }}</option> {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VCPU" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="vcpu" value="1" maxlength="2" required pattern="[0-9]"> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VCPU Config" %}</label> <div class="col-sm-7"> <select class="form-select" id="vcpu_mode" name="vcpu_mode"> <option value=""> {% trans 'no-mode' %}</option> {% for mode in dom_caps.cpu_modes %} {% if mode == 'custom' %} <optgroup label="Custom CPU Models"> {% for model in dom_caps.cpu_custom_models %} <option value="{{ model }}"> {% trans model %}</option> {% endfor %} </optgroup> {% else %} <option value="{{ mode }}" {% if mode == default_cpu_mode %}selected{% endif %}> {% trans mode %} </option> {% endif %} {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "RAM" %}</label> <div class="col-sm-7"> <input type="text" class="form-control" name="memory" value="512" maxlength="5" required pattern="[0-9]+"> </div> <label class="col-sm-1 col-form-label">{% trans "MB" %}</label> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Template Disk" %}</label> <input id="images" name="images" type="hidden" value=""/> <div class="col-sm-3"> <select class="form-select" onchange="get_template_vols({{ compute_id }}, value);"> {% if storages %} <option value disabled selected>{% trans "Select pool" %}...</option> {% for storage in storages %} <option value="{{ storage }}" >{{ storage }}</option> {% endfor %} {% else %} <option value="">{% trans "None" %}</option> {% endif %} </select> </div> <div class="col-sm-4"> <select class="form-select" id="template" name="template" disabled> <!-- populated from javascript --> </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Storage" %}</label> <div class="col-sm-7"> <select class="form-select" id="storage" name="storage" disabled> {% if storages %} {% for storage in storages %} <option value="{{ storage }}" >{{ storage }}</option> {% endfor %} {% else %} <option value="">{% trans "None" %}</option> {% endif %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Network/MAC" %}</label> <div class="col-sm-3"> <select class="form-select" name="networks"> {% for network in networks %} <option value="{{ network }}">{{ network }}</option> {% endfor %} </select> </div> <div class="col-sm-4"> <input type="text" class="form-control" name="mac" maxlength="17" value="{{ mac_auto }}" required pattern="[a-zA-Z0-9:]+"> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Advanced" %}</label> <div class="d-grid col-sm-7"> <button class="btn btn-outline-light" type="button" data-bs-toggle="collapse" data-bs-target="#tempAdvCollapse" aria-expanded="false" aria-controls="tempAdvCollapse"> <span>{% bs_icon 'caret-down'%} </span> </button> </div> </div> <div class="collapse" id="tempAdvCollapse"> <div class="row meta-prealloc"> <label class="col-sm-3 col-form-label">{% trans "Disk Metadata" %}</label> <div class="col-sm-7"> <input type="checkbox" name="meta_prealloc" title="{% trans "Metadata preallocation" %}" value="true"> </div> <label class="col-lg-1 col-form-label">{% trans "Image" %}</label> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "HDD cache mode" %}</label> <div class="col-sm-7"> <select class="form-select" id="cache_mode" name="cache_mode"> {% for mode, name in cache_modes %} <option value="{{ mode }}" {% if mode == default_cache %}selected{% endif %}> {% trans name %}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "NWFilter" %}</label> <div class="col-sm-7"> <select class="form-select" name="nwfilter"> <option value="">{% trans "None" %}</option> {% for nwfilter in nwfilters %} <option value="{{ nwfilter }}">{{ nwfilter }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "NIC Type" %} </label> <div class="col-sm-7"> <select class="form-select" name="net_model"> {% for model in net_models_host %} <option value="{{ model }}" {% if model == default_nic_type %} selected {% endif %}>{{ model }}</option> {% endfor %} </select> </div> </div> {% if dom_caps.graphics_support == 'yes' %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Graphics" %}</label> <div class="col-sm-7"> <select class="form-select" name="graphics"> {% for graphics in dom_caps.graphics_types %} <option value="{{ graphics }}" {% if default_graphics == graphics %}selected{% endif %}>{{ graphics }}</option> {% endfor %} </select> </div> </div> {% endif %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Video" %}</label> <div class="col-sm-7"> <select class="form-select" name="video"> {% if not videos %} <option value="vga">vga</option> <option value="cirrus">cirrus</option> {% endif %} {% for video in videos %} <option value="{{ video }}">{{ video }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Console Access" %}</label> <div class="col-sm-7"> <select class="form-select" name="listener_addr"> {% for addr, label in listener_addr %} <option value="{{ addr }}" {% if addr == "0.0.0.0" %} selected {% endif %}>{{ label }}</option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Console Password" %}</label> <div class="col-sm-7"> <input type="password" class="form-control" name="console_pass" placeholder="{% trans "Console Password" %}" maxlength="64"> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Add CD-Rom" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_cdrom" name="add_cdrom"> <option value="None" {% if bus == default_cdrom %}selected{% endif %}>--{% trans "False" %}--</option> {% for bus in disk_buses %} <option value="{{ bus }}" {% if bus == default_cdrom %}selected {% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Add Input Device" %}</label> <div class="col-sm-7"> <select class="form-select" id="add_input" name="add_input"> <option value="None" {% if bus == default_input_device_bus %}selected{% endif %}>--{% trans "False" %}--</option> {% for bus in input_device_buses %} <option value="{{ bus }}" {% if bus == default_input_device_bus %}selected{% endif %}> {% trans bus %} </option> {% endfor %} </select> </div> </div> <div class="row"> <label class="col-sm-3 col-form-label">{% trans "Guest Agent" %}</label> <div class="col-sm-6"> <input type="checkbox" name="qemu_ga" value="true" checked> </div> </div> {% if virtio_support %} <div class="row"> <label class="col-sm-3 col-form-label">{% trans "VirtIO" %}</label> <div class="col-sm-6"> <input type="checkbox" name="virtio" value="{{ virtio_support }}" checked> </div> </div> {% endif %} </div> <div class="row"> <div class="d-grid col-sm-7 offset-3"> {% if storages %} <button type="submit" class="btn btn-primary" name="create" value="1" formnovalidate onclick="showPleaseWaitDialog()"> {% trans "Create" %} </button> {% else %} <button class="btn btn-primary disabled"> {% trans "Create" %} </button> {% endif %} </div> </div> </form> </div> <div class="clearfix"></div> </div> </div><!-- /Tab panes --> </div> {% endblock %} {% block script %} <script src="{% static 'js/bootstrap-multiselect.js' %}"></script> <script> function toggleValue(string, updated_value, checked) { let result = ''; if (checked) { result = string; if (result != '') result += ','; result += updated_value; } else { $.each(string.split(','), function (index, value) { if (value == updated_value) return; if (result != '') result += ','; result += value; }); } return result; } $(document).ready(function () { $('#image-control').multiselect({ disableIfEmpty: true, enableCaseInsensitiveFiltering: true, maxHeight: 400, inheritClass: true, buttonWidth:function (options, select) { return '100%'; }, buttonText: function (options, select) { return 'Add image...'; }, buttonTitle: function (options, select) { return ''; }, onChange: function (element, checked) { let input_value = toggleValue($('#images').val(), element.val(), checked); $('#images').val(input_value); let selected_list_html = ''; let counter = 0; if (input_value != '') { $('#disk_list_div').removeClass('d-none'); $.each(input_value.split(','), function (index, value) { var li = '<li>hdd' + counter + ' - ' + '<select name="device' + counter + '" class="image-format" onchange="get_disk_bus_choices({{ compute_id }},' + counter + ', value);">' + '{% for dev in disk_devices %}' + '<option value=' + '"{{ dev }}">' + '{% trans dev %}</option>' + '{% endfor %}' + '</select>' + '<select id="bus' + counter + '" name="bus' + counter + '" class="image-format">' + '{% for bus in disk_buses %}' + '<option value=' + '"{{ bus }}"' + '{% if bus == default_bus %}selected{% endif %}>' + '{% trans bus %}</option>' + '{% endfor %}' + '</select>' + ' -> ' + value + ' ' + '<a class="btn-link float-end" onclick="javascript:$(\'#image-control\').multiselect(\'deselect\', \'' + value + '\', true)"> X </a></li>'; selected_list_html += li; counter++; }); }else { $('#disk_list_div').addClass('d-none'); } $('#img-list').html(selected_list_html); } }); $('#network-control').multiselect({ inheritClass: true, buttonText: function (options, select) { return 'Add network'; }, buttonTitle: function (options, select) { return ''; }, buttonWidth:function (options, select) { return '100%'; }, onChange: function (element, checked) { let input_value = toggleValue($('#networks').val(), element.val(), checked); $('#networks').val(input_value); let selected_list_html = ''; mac_array = []; net_counter = 0; if (input_value != '') { $.each(input_value.split(','), function (index, value) { let li = '<li><input type="text" class="input-xs" name="mac'+ net_counter +'" maxlength="17" required pattern="[a-zA-Z0-9:]+" onchange="populate_mac(' + net_counter +')">' + ' eth' + net_counter + ' -> ' + value + ' ' + '<a class="btn-link float-end" onclick="$(\'#network-control\').multiselect(\'deselect\', \'' + value + '\', true)"> X </a></li>'; random_mac(net_counter); selected_list_html += li; net_counter++; }); } $('#net-list').html(selected_list_html); } }); }); var mac_array = []; function random_mac(c) { $.getJSON("{% url 'instances:random_mac_address' %}", function (data) { mac_array[c] = data['mac']; $('input[name="mac' + c + '"').val(data['mac']); populate_mac(c); }); } function populate_mac(c){ mac_array[c] = $('input[name="mac' + c + '"').val(); $('input[name="mac"').val(mac_array.join(",")); } $("id[vcpu_mode]").multiselect(); function get_cust_vols(compute_id, pool) { get_vol_url = "/computes/" + compute_id + "/storage/" + pool + "/volumes"; $.getJSON(get_vol_url, function (data) { $("#image-control").find('option').remove(); $.each(data['vols'], function(i, item) { $("#image-control").append('<option value=' + item +'>' + item + '</option>'); }); $('#image-control').multiselect('rebuild'); }); } function get_template_vols(compute_id, pool) { get_vol_url = "/computes/" + compute_id + "/storage/" + pool + "/volumes"; $.getJSON(get_vol_url, function (data) { $("#template").find('option').remove(); $.each(data['vols'], function(i, item) { $("#template").append('<option value=' + item +'>' + item + '</option>'); }); }); $("#template").removeAttr("disabled"); $("#storage").val(pool).change(); $("#storage").removeAttr("disabled"); } function get_disk_bus_choices(compute_id, dev_idx, disk_type){ let arch = $('select[name="arch"]').val(); let machine = $("select[id='machine-control']").val(); get_diskBus_url = "/computes/" + compute_id + "/archs/" + arch + "/machines/" + machine + "/disks/" + disk_type + "/buses"; $.getJSON(get_diskBus_url, function (data) { $("#bus" + dev_idx).find('option').remove(); $.each(data['bus'], function(i, item) { $("#bus" + dev_idx).append('<option value=' + item +'>' + item + '</option>'); }); }); } </script> {% if request.user.is_superuser %} <script> function goto_compute() { let compute = {{ compute.id }}; window.location.href = "{% url 'instances:create_instance_select_type' 1 %}".replace(1, compute); } </script> {% endif %} {% endblock %}