All Downloads are FREE. Search and download functionalities are using the official Maven repository.

services.HostService Maven / Gradle / Ivy

There is a newer version: 4.6.0
Show newest version
/*
Copyright (c) 2015 Red Hat, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

package services;

import annotations.Area;
import mixins.Follow;
import org.ovirt.api.metamodel.annotations.In;
import org.ovirt.api.metamodel.annotations.InputDetail;
import org.ovirt.api.metamodel.annotations.Out;
import org.ovirt.api.metamodel.annotations.Service;
import services.externalhostproviders.KatelloErrataService;
import types.Cluster;
import types.Host;
import types.HostNic;
import types.IscsiDetails;
import types.NetworkAttachment;
import types.NetworkLabel;
import types.PowerManagement;
import types.Ssh;
import types.StorageDomain;
import static org.ovirt.api.metamodel.language.ApiLanguage.COLLECTION;
import static org.ovirt.api.metamodel.language.ApiLanguage.mandatory;
import static org.ovirt.api.metamodel.language.ApiLanguage.optional;
import static org.ovirt.api.metamodel.language.ApiLanguage.or;

/**
 * A service to manage a host.
 *
 * @author Yaniv Bronheim 
 * @author Megan Lewis 
 * @date 17 Oct 17
 * @status updated_by_docs
 */
@Service
@Area("Infrastructure")
public interface HostService extends MeasurableService {
    /**
     * Activates the host for use, for example to run virtual machines.
     *
     * @author Oved Ourfali 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Activate {
        /**
         * Indicates if the activation should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();
    }

    /**
     * Approve a pre-installed Hypervisor host for usage in the virtualization environment.
     *
     * This action also accepts an optional cluster element to define the target cluster for this host.
     *
     * @author Oved Ourfali 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Approve {
        /**
         * The host to approve.
         *
         * @author Aleksei Slaikovskii 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Host host();

        @InputDetail
        default void inputDetail() {
            or(optional(cluster().id()), optional(cluster().name()));
        }

        /**
         * The cluster where the host will be added after it is approved.
         *
         * @author Aleksei Slaikovskii 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Cluster cluster();

        /**
         * Indicates if the approval should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();

        /**
         * Approve the specified host to be added to the engine by using the root password (deprecated verb). This
         * occurs when the host registers itself with the engine.
         *
         * @author Ori Liel 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        interface UsingRootPassword extends Approve {
            @InputDetail
            default void inputDetail() {
                mandatory(host().rootPassword());//DEPRECATED
            }
        }

        /**
         * Approve the specified host to be added to the engine by using ssh authentication. This occurs when the host
         * registers itself with the engine.
         *
         * @author Ori Liel 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        interface UsingSsh extends Approve {
            @InputDetail
            default void inputDetail() {
                mandatory(host().ssh().authenticationMethod());
                mandatory(host().ssh().user().password());
                mandatory(host().ssh().user().userName());
            }
        }
    }

    /**
     * Marks the network configuration as good and persists it inside the host.
     *
     * An API user commits the network configuration to persist a host network interface attachment or detachment, or
     * persist the creation and deletion of a bonded interface.
     *
     * IMPORTANT: Networking configuration is only committed after the engine has established that host connectivity is
     * not lost as a result of the configuration changes. If host connectivity is lost, the host requires a reboot and
     * automatically reverts to the previous networking configuration.
     *
     * For example, to commit the network configuration of host with id `123` send a request like this:
     *
     * [source]
     * ----
     * POST /ovirt-engine/api/hosts/123/commitnetconfig
     * ----
     *
     * With a request body like this:
     *
     * [source,xml]
     * ----
     * 
     * ----
     *
     * @author Juan Hernandez 
     * @author Martin Mucha 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface CommitNetConfig {
        /**
         * Indicates if the action should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();
    }

    /**
     * Deactivates the host to perform maintenance tasks.
     *
     * @author Oved Ourfali 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Deactivate {
        @InputDetail
        default void inputDetail() {
            optional(reason());
        }
        @In String reason();

        /**
         * Indicates if the deactivation should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();

        /**
         * Indicates if the gluster service should be stopped as part of deactivating the host. It can be used while
         * performing maintenance operations on the gluster host. Default value for this variable is `false`.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean stopGlusterService();
    }

    /**
     * Enrolls the certificate of the host. Useful in case you get a warning that it is about to expire or has already
     * expired.
     *
     * @author Oved Ourfali 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface EnrollCertificate {
        /**
         * Indicates if the enrollment should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();
    }

    /**
     * Controls the host's power management device.
     *
     * For example, to start the host. This can be done via:
     *
     * [source]
     * ----
     * #!/bin/sh -ex
     *
     * url="https://engine.example.com/ovirt-engine/api"
     * user="admin@internal"
     * password="..."
     *
     * curl \
     * --verbose \
     * --cacert /etc/pki/ovirt-engine/ca.pem \
     * --user "${user}:${password}" \
     * --request POST \
     * --header "Version: 4" \
     * --header "Content-Type: application/xml" \
     * --header "Accept: application/xml" \
     * --data '
     * 
     *   start
     * 
     * ' \
     * "${url}/hosts/123/fence"
     * ----
     * @author Oved Ourfali 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Fence {
        @InputDetail
        default void inputDetail() {
            mandatory(fenceType());
        }
        @In String fenceType();
        @Out PowerManagement powerManagement();

        /**
         * Indicates if the fencing should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();
    }

    /**
     * To manually set a host as the storage pool manager (SPM).
     *
     * [source]
     * ----
     * POST /ovirt-engine/api/hosts/123/forceselectspm
     * ----
     *
     * With a request body like this:
     *
     * [source,xml]
     * ----
     * 
     * ----
     *
     * @author Liron Aravot 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface ForceSelectSpm {
        /**
         * Indicates if the action should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();
    }

    /**
     * Gets the host details.
     *
     * [source]
     * ----
     * GET /ovirt-engine/api/hosts/123
     * ----
     *
     * @author Oved Ourfali 
     * @author Aleksei Slaikovskii 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Get extends Follow {
        /**
         * The queried host.
         *
         * @author Aleksei Slaikovskii 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @Out Host host();

        /**
         * Indicates if the results should be filtered according to the permissions of the user.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean filter();

        /**
         * Indicates if all of the attributes of the host should be included in the response.
         *
         * By default the following attributes are excluded:
         *
         * - `hosted_engine`
         *
         * For example, to retrieve the complete representation of host '123':
         *
         * ....
         * GET /ovirt-engine/api/hosts/123?all_content=true
         * ....
         *
         * NOTE: These attributes are not included by default because retrieving them impacts performance. They are
         * seldom used and require additional queries to the database. Use this parameter with caution and only when
         * specifically required.
         *
         * @author Juan Hernandez 
         * @author Tahlia Richardson 
         * @date 26 Apr 2017
         * @status updated_by_docs
         */
        @In Boolean allContent();
    }

    /**
     * Installs the latest version of VDSM and related software on the host.
     *
     * The action also performs every configuration steps on the host which is done during adding host to the engine:
     * kdump configuration, hosted-engine deploy, kernel options changes, etc.
     *
     * The host type defines additional parameters for the action.
     *
     * Example of installing a host, using `curl` and JSON, plain:
     *
     * [source,bash]
     * ----
     * curl \
     * --verbose \
     * --cacert /etc/pki/ovirt-engine/ca.pem \
     * --request PUT \
     * --header "Content-Type: application/json" \
     * --header "Accept: application/json" \
     * --header "Version: 4" \
     * --user "admin@internal:..." \
     * --data '
     * {
     *   "root_password": "myrootpassword"
     * }
     * ' \
     * "https://engine.example.com/ovirt-engine/api/hosts/123"
     * ----
     *
     * Example of installing a host, using `curl` and JSON, with hosted engine components:
     *
     * [source,bash]
     * ----
     * curl \
     * curl \
     * --verbose \
     * --cacert /etc/pki/ovirt-engine/ca.pem \
     * --request PUT \
     * --header "Content-Type: application/json" \
     * --header "Accept: application/json" \
     * --header "Version: 4" \
     * --user "admin@internal:..." \
     * --data '
     * {
     *   "root_password": "myrootpassword"
     * }
     * ' \
     * "https://engine.example.com/ovirt-engine/api/hosts/123?deploy_hosted_engine=true"
     * ----
     *
     * IMPORTANT: Since version 4.1.2 of the engine when a host is reinstalled we override the host firewall
     * definitions by default.
     *
     * @author Oved Ourfali 
     * @author Roy Golan 
     * @author Megan Lewis 
     * @date 17 Oct 17
     * @status updated_by_docs
     */
    interface Install {
        @InputDetail
        default void inputDetail() {
            optional(host().overrideIptables());
            optional(image());
        }

        /**
         * Install VDSM and other packages required to get the host ready to be used in the engine providing the root
         * password. This has been deprecated.
         *
         * @author Ori Liel 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        interface UsingRootPassword extends Install {
            @InputDetail
            default void inputDetail() {
                optional(rootPassword());
            }
        }

        /**
         * Install VDSM and other packages required to get the host ready to be used in the engine providing the SSH
         * password.
         *
         * @author Ori Liel 
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        interface UsingSsh extends Install {
            @InputDetail
            default void inputDetail() {
                optional(ssh().authenticationMethod());
                optional(ssh().fingerprint());
                optional(ssh().port());
                optional(ssh().user().password());
                optional(ssh().user().userName());
            }
        }
        /**
         * The password of of the `root` user, used to connect to the host via SSH.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In String rootPassword();

        /**
         * The SSH details used to connect to the host.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Ssh ssh();

        /**
         * The `override_iptables` property is used to indicate if the firewall configuration should be replaced by the
         * default one.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Host host();

        /**
         * When installing {hypervisor-name}, an ISO image file is required.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In String image();

        /**
         * Indicates if the installation should be performed asynchronously.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean async();

        /**
         * When set to `true` it means this host should also deploy the self-hosted engine components. A missing value
         * is treated as `true` i.e deploy. Omitting this parameter means `false` and will perform no operation in the
         * self-hosted engine area.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean deployHostedEngine();

        /**
         * When set to `true` it means this host should un-deploy the self-hosted engine components and this host will
         * not function as part of the High Availability cluster. A missing value is treated as `true` i.e un-deploy
         * Omitting this parameter means `false` and will perform no operation in the self-hosted engine area.
         *
         * @author Megan Lewis 
         * @date 17 Oct 17
         * @status updated_by_docs
         */
        @In Boolean undeployHostedEngine();
    }

    /**
     * Discovers iSCSI targets on the host, using the initiator details.
     *
     * For example, to discover iSCSI targets available in `myiscsi.example.com`,
     * from host `123`, send a request like this:
     *
     * [source]
     * ----
     * POST /ovirt-engine/api/hosts/123/iscsidiscover
     * ----
     *
     * With a request body like this:
     *
     * [source,xml]
     * ----
     * 
     *   
     *     
myiscsi.example.com
*
*
* ---- * * The result will be like this: * * [source,xml] * ---- * * *
10.35.1.72
* 3260 * 10.35.1.72:3260,1 * iqn.2015-08.com.tgt:444 *
*
* ---- * * @author Oved Ourfali * @author Megan Lewis * @author Ala Hino * @date 23 Nov 2017 * @status updated_by_docs */ interface IscsiDiscover { @InputDetail default void inputDetail() { mandatory(iscsi().address()); } /** * The target iSCSI device. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In IscsiDetails iscsi(); /** * The iSCSI targets. * * Since version 4.2 of the engine, this parameter is deprecated, use * `discovered_targets` instead. * * @author Oved Ourfali * @author Megan Lewis * @author Ala Hino * @date 23 Nov 2017 * @status updated_by_docs */ @Deprecated @Out String[] iscsiTargets(); /** * The discovered targets including all connection information. * * @author Ala Hino * @date 23 Nov 2017 * @status updated_by_docs * @since 4.2 */ @Out IscsiDetails[] discoveredTargets(); /** * Indicates if the discovery should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Login to iSCSI targets on the host, using the target details. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface IscsiLogin { @InputDetail default void inputDetail() { mandatory(iscsi().address()); mandatory(iscsi().target()); } /** * The target iSCSI device. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In IscsiDetails iscsi(); /** * Indicates if the login should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Discovers the block Storage Domains which are candidates to be imported to the setup. For FCP no arguments are * required. * * @author Ori Liel * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface UnregisteredStorageDomainsDiscover { @InputDetail default void inputDetail() { optional(iscsi().address()); optional(iscsi().target()); } @In IscsiDetails iscsi(); @Out StorageDomain[] storageDomains(); /** * Indicates if the discovery should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Update the host properties. * * For example, to update a the kernel command line of a host send a request like this: * * [source] * ---- * PUT /ovirt-engine/api/hosts/123 * ---- * * With request body like this: * * [source, xml] * ---- * * * vfio_iommu_type1.allow_unsafe_interrupts=1 * * * ---- * * @author Jakub Niedermertl * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface Update { @InputDetail default void inputDetail() { optional(host().address()); optional(host().comment()); optional(host().display().address()); optional(host().name()); optional(host().port()); optional(host().powerManagement().automaticPmEnabled()); optional(host().powerManagement().enabled()); optional(host().powerManagement().kdumpDetection()); optional(host().spm().priority()); or(optional(host().cluster().id()), optional(host().cluster().name())); // optional(host().powerManagement()[COLLECTION].propietary!!(); } /** * Update the specified host in the system. This is deprecated and is provided only for backwards compatibility. * * @author Ori Liel * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface UsingRootPassword extends Update { @InputDetail default void inputDetail() { optional(host().externalHostProvider().id()); optional(host().rootPassword()); //DEPRECATED } } /** * Updates the specified host in the system. * * @author Ori Liel * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface UsingSsh extends Update { @InputDetail default void inputDetail() { optional(host().ssh().fingerprint()); optional(host().ssh().port()); optional(host().ssh().user().userName()); } } @In @Out Host host(); /** * Indicates if the update should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Upgrades VDSM and selected software on the host. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface Upgrade { @InputDetail default void inputDetail() { optional(image()); } /** * The image parameter specifies path to image, which is used for upgrade. This parameter is used only to * upgrade Vintage Node hosts and it is not relevant for other hosts types. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In String image(); /** * Indicates if the host should be rebooted after upgrade. * By default the host is rebooted. * * NOTE: This parameter is ignored for {hypervisor-name}, which is always rebooted after upgrade. * * @author Ondra Machacek * @author Byron Gravenorst * @date 20 Oct 2017 * @status updated_by_docs * @since 4.2 */ @In Boolean reboot(); /** * Indicates if the upgrade should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Check if there are upgrades available for the host. If there are upgrades available an icon will be displayed * next to host status icon in the Administration Portal. Audit log messages are also added to indicate the * availability of upgrades. The upgrade can be started from the webadmin or by using the * <> host action. * * @author Ravi Nori * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs * @since 4.1 */ interface UpgradeCheck { } /** * Refresh the host devices and capabilities. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface Refresh { /** * Indicates if the refresh should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * Remove the host from the system. * * [source] * ---- * #!/bin/sh -ex * * url="https://engine.example.com/ovirt-engine/api" * user="admin@internal" * password="..." * * curl \ * --verbose \ * --cacert /etc/pki/ovirt-engine/ca.pem \ * --user "${user}:${password}" \ * --request DELETE \ * --header "Version: 4" \ * "${url}/hosts/1ff7a191-2f3b-4eff-812b-9f91a30c3acc" * ---- * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface Remove { /** * Indicates if the remove should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * This method is used to change the configuration of the network interfaces of a host. * * For example, if you have a host with three network interfaces `eth0`, `eth1` and `eth2` and you want to configure * a new bond using `eth0` and `eth1`, and put a VLAN on top of it. Using a simple shell script and the `curl` * command line HTTP client that can be done as follows: * * [source] * ---- * #!/bin/sh -ex * * url="https://engine.example.com/ovirt-engine/api" * user="admin@internal" * password="..." * * curl \ * --verbose \ * --cacert /etc/pki/ovirt-engine/ca.pem \ * --user "${user}:${password}" \ * --request POST \ * --header "Version: 4" \ * --header "Content-Type: application/xml" \ * --header "Accept: application/xml" \ * --data ' * * * * bond0 * * * * * * * * eth1 * * * eth2 * * * * * * * * * myvlan * * * bond0 * * * static * * *
192.168.122.10
* 255.255.255.0 *
*
*
* * * 1.1.1.1 * 2.2.2.2 * * *
*
*
* ' \ * "${url}/hosts/1ff7a191-2f3b-4eff-812b-9f91a30c3acc/setupnetworks" * ---- * * NOTE: This is valid for version 4 of the API. In previous versions some elements were represented as XML * attributes instead of XML elements. In particular the `options` and `ip` elements were represented as follows: * * [source,xml] * ---- * * * * ---- * * Using the Python SDK the same can be done with the following code: * * [source,python] * ---- * # Find the service that manages the collection of hosts: * hosts_service = connection.system_service().hosts_service() * * # Find the host: * host = hosts_service.list(search='name=myhost')[0] * * # Find the service that manages the host: * host_service = hosts_service.host_service(host.id) * * # Configure the network adding a bond with two slaves and attaching it to a * # network with an static IP address: * host_service.setup_networks( * modified_bonds=[ * types.HostNic( * name='bond0', * bonding=types.Bonding( * options=[ * types.Option( * name='mode', * value='4', * ), * types.Option( * name='miimon', * value='100', * ), * ], * slaves=[ * types.HostNic( * name='eth1', * ), * types.HostNic( * name='eth2', * ), * ], * ), * ), * ], * modified_network_attachments=[ * types.NetworkAttachment( * network=types.Network( * name='myvlan', * ), * host_nic=types.HostNic( * name='bond0', * ), * ip_address_assignments=[ * types.IpAddressAssignment( * assignment_method=types.BootProtocol.STATIC, * ip=types.Ip( * address='192.168.122.10', * netmask='255.255.255.0', * ), * ), * ], * dns_resolver_configuration=types.DnsResolverConfiguration( * name_servers=[ * '1.1.1.1', * '2.2.2.2', * ], * ), * ), * ], * ) * * # After modifying the network configuration it is very important to make it * # persistent: * host_service.commit_net_config() * ---- * * IMPORTANT: To make sure that the network configuration has been saved in the host, and that it will be applied * when the host is rebooted, remember to call <>. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ interface SetupNetworks { @InputDetail default void inputDetail() { optional(checkConnectivity()); optional(connectivityTimeout()); or(optional(modifiedNetworkAttachments()[COLLECTION].hostNic().name()), optional(modifiedNetworkAttachments()[COLLECTION].hostNic().id())); optional(modifiedNetworkAttachments()[COLLECTION].id()); optional(modifiedNetworkAttachments()[COLLECTION].ipAddressAssignments()[COLLECTION].ip()); optional(modifiedNetworkAttachments()[COLLECTION].ipAddressAssignments()[COLLECTION].assignmentMethod()); or(optional(modifiedNetworkAttachments()[COLLECTION].network().name()), optional(modifiedNetworkAttachments()[COLLECTION].network().id())); optional(modifiedNetworkAttachments()[COLLECTION].properties()[COLLECTION].name()); optional(modifiedNetworkAttachments()[COLLECTION].properties()[COLLECTION].value()); optional(removedLabels()[COLLECTION].id()); optional(synchronizedNetworkAttachments()[COLLECTION].id()); optional(removedNetworkAttachments()[COLLECTION].id()); or(optional(modifiedLabels()[COLLECTION].hostNic().name()), optional(modifiedLabels()[COLLECTION].hostNic().id())); optional(modifiedLabels()[COLLECTION].id()); // optional(modifiedBonds()[COLLECTION].slaves().hostNic--collection()); optional(modifiedBonds()[COLLECTION].bonding().options()[COLLECTION].name()); optional(modifiedBonds()[COLLECTION].bonding().options()[COLLECTION].value()); or(optional(modifiedBonds()[COLLECTION].name()), optional(modifiedBonds()[COLLECTION].id())); or(optional(removedBonds()[COLLECTION].name()), optional(removedBonds()[COLLECTION].id())); } @In NetworkAttachment[] modifiedNetworkAttachments(); @In NetworkAttachment[] removedNetworkAttachments(); /** * A list of network attachments that will be synchronized. * * @author Leon Goldberg * @author Byron Gravenorst * @date 31 Jan 18 * @status updated_by_docs */ @In NetworkAttachment[] synchronizedNetworkAttachments(); @In HostNic[] modifiedBonds(); @In HostNic[] removedBonds(); @In NetworkLabel[] modifiedLabels(); @In NetworkLabel[] removedLabels(); @In Boolean checkConnectivity(); @In Integer connectivityTimeout(); /** * Indicates if the action should be performed asynchronously. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @In Boolean async(); } /** * To synchronize all networks on the host, send a request like this: * * [source] * ---- * POST /ovirt-engine/api/hosts/123/syncallnetworks * ---- * * With a request body like this: * * [source,xml] * ---- * * ---- * * @author Leon Goldberg * @author Tahlia Richardson * @date 07 Feb 18 * @since 4.2.2 * @status updated_by_docs */ interface SyncAllNetworks { /** * Indicates if the action should be performed asynchronously. * * @author Leon Goldberg * @author Tahlia Richardson * @date 30 Jan 18 * @status updated_by_docs */ @In Boolean async(); } /** * A reference to the host permission service. * Use this service to manage permissions on the host object. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service AssignedPermissionsService permissions(); /** * A reference to the host tags service. Use this service to manage tags on the host object. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service AssignedTagsService tags(); /** * A reference to the fence agents service. Use this service to manage fence and power management agents on the host * object. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service FenceAgentsService fenceAgents(); /** * A reference to the host devices service. Use this service to view the devices of the host object. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service HostDevicesService devices(); /** * A reference to the host hooks service. Use this service to view the hooks available in the host object. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service HostHooksService hooks(); /** * A reference to the service that manages the network interface devices on the host. * * @author Martin Mucha * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service HostNicsService nics(); /** * A reference to the service that manage NUMA nodes for the host. * * @author Yaniv Bronheim * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service HostNumaNodesService numaNodes(); /** * A reference to the service that manages the host's storage. * * @author Yaniv Bronheim * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service HostStorageService storage(); /** * A reference to the service that can show the applicable errata available on the host. This information is taken * from Katello. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service KatelloErrataService katelloErrata(); /** * A reference to the network attachments service. You can use this service to attach Logical networks to host * interfaces. * * @author Oved Ourfali * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service NetworkAttachmentsService networkAttachments(); /** * A reference to storage connection extensions. * * @author Yaniv Bronheim * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service StorageServerConnectionExtensionsService storageConnectionExtensions(); /** * A reference to unmanaged networks. * * @author Yaniv Bronheim * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service UnmanagedNetworksService unmanagedNetworks(); /** * List of scheduling labels assigned to this host. * * @author Megan Lewis * @date 17 Oct 17 * @status updated_by_docs */ @Service AssignedAffinityLabelsService affinityLabels(); /** * External network providers provisioned by the system on the host. * * @author Dominik Holler * @author Byron Gravenorst * @date 09 Oct 2017 * @status updated_by_docs * @since 4.2 */ @Service ExternalNetworkProviderConfigurationsService externalNetworkProviderConfigurations(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy