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

org.ovirt.engine.sdk.Api Maven / Gradle / Ivy

There is a newer version: 3.6.10.0
Show newest version
//
// Copyright (c) 2012 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.
//

// *********************************************************************
// ********************* GENERATED CODE - DO NOT MODIFY ****************
// *********************************************************************

package org.ovirt.engine.sdk;

import java.io.IOException;

import org.apache.http.client.ClientProtocolException;
import org.apache.log4j.ConsoleAppender;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.ovirt.engine.sdk.web.ConnectionsPool;
import org.ovirt.engine.sdk.web.ConnectionsPoolBuilder;
import org.ovirt.engine.sdk.web.HttpProxy;
import org.ovirt.engine.sdk.web.HttpProxyBroker;
import org.ovirt.engine.sdk.web.HttpProxyBuilder;
import org.ovirt.engine.sdk.decorators.*;
import org.ovirt.engine.sdk.entities.API;
import org.ovirt.engine.sdk.exceptions.ServerException;
import org.ovirt.engine.sdk.exceptions.UnsecuredConnectionAttemptError;
import org.ovirt.engine.sdk.utils.SerializationHelper;

/**
 * oVirt virtualization Java SDK.
 */
public class Api implements AutoCloseable {

    private volatile HttpProxyBroker proxy = null;
    private volatile API entryPoint = null;
    private final Object LOCK = new Object();

    private volatile Bookmarks bookmarks;
    private volatile Capabilities capabilities;
    private volatile Clusters clusters;
    private volatile CpuProfiles cpuProfiles;
    private volatile DataCenters dataCenters;
    private volatile DiskProfiles diskProfiles;
    private volatile Disks disks;
    private volatile Domains domains;
    private volatile Events events;
    private volatile ExternalHostProviders externalHostProviders;
    private volatile Groups groups;
    private volatile Hosts hosts;
    private volatile Icons icons;
    private volatile InstanceTypes instanceTypes;
    private volatile Jobs jobs;
    private volatile KatelloErrata katelloErrata;
    private volatile MacPools macPools;
    private volatile Networks networks;
    private volatile OpenStackImageProviders openStackImageProviders;
    private volatile OpenStackNetworkProviders openStackNetworkProviders;
    private volatile OpenStackVolumeProviders openStackVolumeProviders;
    private volatile OperatingSystemInfos operatingSystemInfos;
    private volatile Permissions permissions;
    private volatile Roles roles;
    private volatile SchedulingPolicies schedulingPolicies;
    private volatile SchedulingPolicyUnits schedulingPolicyUnits;
    private volatile StorageConnections storageConnections;
    private volatile StorageDomains storageDomains;
    private volatile Tags tags;
    private volatile Templates templates;
    private volatile Users users;
    private volatile VMs vMs;
    private volatile VmPools vmPools;
    private volatile VnicProfiles vnicProfiles;


    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site using
     *             HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password) throws ClientProtocolException,
            ServerException, IOException, UnsecuredConnectionAttemptError {
        this(
            url,
            username,
            password,
            null, // sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            null, // filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param keyStorePath
     *            path to CA certificate KeyStore
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, String keyStorePath)
            throws ClientProtocolException, ServerException, IOException,
                   UnsecuredConnectionAttemptError {
        this(
            url,
            username,
            password,
            null, // sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            keyStorePath,
            null, // keyStorePassword,
            null, // filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param keyStorePath
     *            path to CA certificate KeyStore
     * @param keyStorePassword
     *            password for the CA certificate KeyStore
     * @param filter
     *            enables filtering based on user's permissions
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, String keyStorePath,
            String keyStorePassword, Boolean filter) throws ClientProtocolException,
            ServerException, UnsecuredConnectionAttemptError, IOException {
        this(
            url,
            username,
            password,
            null, // sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            keyStorePath,
            keyStorePassword,
            filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String sessionid) throws ClientProtocolException, ServerException,
            IOException, UnsecuredConnectionAttemptError {
        this(
            url,
            null, // username,
            null, // password,
            sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            null, // filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param noHostVerification
     *            turns hostname verification off
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, boolean noHostVerification)
            throws ClientProtocolException, ServerException, UnsecuredConnectionAttemptError,
            IOException {
        this(
            url,
            username,
            password,
            null, // sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            null, // filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     * @param noHostVerification
     *            turns hostname verification off
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String sessionid, boolean noHostVerification)
            throws ClientProtocolException, ServerException, UnsecuredConnectionAttemptError,
            IOException {
        this(
            url,
            null, // username,
            null, // password,
            sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            null, // filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param noHostVerification
     *            turns hostname verification off
     * @param filter
     *            enables filtering based on user's permissions
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, Boolean noHostVerification,
            Boolean filter) throws ClientProtocolException, ServerException,
            UnsecuredConnectionAttemptError, IOException {
        this(
            url,
            username,
            password,
            null, // sessionid,
            null, // port,
            null, // requestTimeout,
            null, // sessionTimeout,
            null, // persistentAuth,
            null, // noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            filter,
            null, // debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     * @param port
     *            oVirt api port
     * @param requestTimeout
     *            request timeout (preserved for future use)
     * @param persistentAuth
     *            disable persistent authentication (will be used auth. per request)
     * @param noHostVerification
     *            turns hostname verification off
     * @param filter
     *            enables filtering based on user's permissions
     * @param debug
     *            enables debug mode
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, String sessionid, Integer port,
            Integer requestTimeout, Boolean persistentAuth, Boolean noHostVerification,
            Boolean filter, Boolean debug) throws ClientProtocolException, ServerException,
            UnsecuredConnectionAttemptError, IOException {
        this(
            url,
            username,
            password,
            sessionid,
            port,
            requestTimeout,
            null, // sessionTimeout,
            persistentAuth,
            noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            filter,
            debug,
            null  // kerberos,
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     * @param port
     *            oVirt api port
     * @param requestTimeout
     *            request timeout (preserved for future use)
     * @param sessionTimeout
     *            authentication session inactivity timeout in minutes (if persistentAuth is enabled)
     * @param persistentAuth
     *            disable persistent authentication (will be used auth. per request)
     * @param noHostVerification
     *            turns hostname verification off
     * @param filter
     *            enables filtering based on user's permissions
     * @param debug
     *            enables debug mode
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site
     *             using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, String sessionid, Integer port,
            Integer requestTimeout, Integer sessionTimeout, Boolean persistentAuth,
            Boolean noHostVerification, Boolean filter, Boolean debug) throws ClientProtocolException,
            ServerException, UnsecuredConnectionAttemptError, IOException {
        this(
            url,
            username,
            password,
            sessionid,
            port,
            requestTimeout,
            sessionTimeout,
            persistentAuth,
            noHostVerification,
            null, // keyStorePath,
            null, // keyStorePassword,
            filter,
            debug,
            null  // kerberos
        );
    }

    /**
     * @param url
     *            oVirt api url
     * @param username
     *            oVirt api username
     * @param password
     *            oVirt api password
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     * @param port
     *            oVirt api port
     * @param requestTimeout
     *            request timeout (preserved for future use)
     * @param sessionTimeout
     *            authentication session inactivity timeout in minutes (if persistentAuth is enabled)
     * @param persistentAuth
     *            disable persistent authentication
     *            (will be used auth. per request)
     * @param keyStorePath
     *            path to CA certificate KeyStore
     * @param keyStorePassword
     *            password for the CA certificate KeyStore
     * @param filter
     *            enables filtering based on user's permissions
     * @param debug
     *            enables debug mode
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured
     *             site using HTTP protocol has occurred.
     *
     * @deprecated Use the {@link ApiBuilder} class instead.
     */
    @Deprecated
    public Api(String url, String username, String password, String sessionid,
            Integer port, Integer requestTimeout, Integer sessionTimeout,
            Boolean persistentAuth, String keyStorePath, String keyStorePassword,
            Boolean filter, Boolean debug) throws ClientProtocolException,
            ServerException, UnsecuredConnectionAttemptError, IOException {
        this(
            url,
            username,
            password,
            sessionid,
            port,
            requestTimeout,
            sessionTimeout,
            persistentAuth,
            null, // noHostVerification,
            keyStorePath,
            keyStorePassword,
            filter,
            debug,
            null  // kerberos
        );
    }

    /**
     * This method is intended for use by the {@link org.ovirt.engine.sdk.ApiBuilder} class, don't use it directly.
     */
    Api(
        String url,
        String username,
        String password,
        String sessionid,
        Integer port,
        Integer requestTimeout,
        Integer sessionTimeout,
        Boolean persistentAuth,
        Boolean noHostVerification,
        String keyStorePath,
        String keyStorePassword,
        Boolean filter,
        Boolean debug,
        Boolean kerberos
    )
    throws ServerException, UnsecuredConnectionAttemptError, IOException {

        configureLog4J(debug);
        ConnectionsPool pool = new ConnectionsPoolBuilder()
                .url(url)
                .username(username)
                .password(password)
                .port(port)
                .requestTimeout(requestTimeout)
                .sessionTimeout(sessionTimeout)
                .noHostVerification(noHostVerification)
                .keyStorePath(keyStorePath)
                .keyStorePassword(keyStorePassword)
                .kerberos(kerberos)
                .build();
        HttpProxy httpProxy = new HttpProxyBuilder(pool)
                .sessionid(sessionid)
                .persistentAuth(persistentAuth)
                .filter(filter)
                .debug(debug)
                .build();
        this.proxy = new HttpProxyBroker(httpProxy);
        initResources();
    }

    /**
     * Configures log4j.
     */
    private void configureLog4J(Boolean debug) {
        String patternLayout = "%d %-5p [%c] %m%n";
        if (debug != null && Boolean.TRUE.equals(debug)) {

            Logger rootLogger = Logger.getRootLogger();
            if (!rootLogger.getAllAppenders().hasMoreElements()) {
                rootLogger.setLevel(Level.INFO);
                rootLogger.addAppender(new ConsoleAppender(
                        new PatternLayout(patternLayout)));

            }
            Logger pkgLogger =
                    rootLogger.getLoggerRepository()
                            .getLogger("org.apache.http");
            pkgLogger.setLevel(Level.DEBUG);
        } else {
            Logger rootLogger = Logger.getRootLogger();
            if (!rootLogger.getAllAppenders().hasMoreElements()) {
                rootLogger.setLevel(Level.OFF);
                rootLogger.addAppender(new ConsoleAppender(
                        new PatternLayout(patternLayout)));
            }
        }
    }

    /**
     * Fetches /api entry point
     *
     * @return API object instance
     */
    private API getEntryPoint() throws ClientProtocolException, ServerException, IOException,
            UnsecuredConnectionAttemptError {
        String entryPointXML = this.proxy.get(this.proxy.getRoot());
        if (entryPointXML != null && !entryPointXML.equals("")) {
            return SerializationHelper.unmarshall(API.class, entryPointXML);
        }
        throw new UnsecuredConnectionAttemptError();
    }

    /**
     * initializes resources
     */
    private synchronized void initResources() throws ClientProtocolException, ServerException, UnsecuredConnectionAttemptError,
            IOException {
        this.entryPoint = getEntryPoint();
    }

    /**
     * Enable/Disable client permissions based filtering (default is False)
     *
     * @param filter
     */
    public synchronized void setFilter(boolean filter) {
        this.proxy.setFilter(filter);
    }

    /**
     * Enable/Disable persistent authentication (default is True)
     *
     * @param persistentAuth
     */
    public synchronized void setPersistentAuth(boolean persistentAuth) {
        this.proxy.setPersistentAuth(persistentAuth);
    }

    /**
     * @return persistent authentication flag
     */
    public boolean isPersistentAuth() {
        return this.proxy.isPersistentAuth();
    }

    /**
     * @return Filter flag
     */
    public boolean isFilter() {
        return this.proxy.isFilter();
    }

    /**
     * @return Debug flag
     */
    public boolean isDebug() {
        return this.proxy.isDebug();
    }

    /**
     * @param sessionid
     *            oVirt api sessionid to authenticate the user with
     *            (used as SSO solution instead of username+password)
     */
    public synchronized void setSessionid(String sessionid) {
        this.proxy.setSessionid(sessionid);
    }

    /**
    * oVirt api sessionid to authenticate the user with
    * (used as SSO solution instead of username+password)
     */
    public boolean isSetSessionid() {
        return this.proxy.isSetSessionid();
    }

    /**
     * When SDK instance is no longer needed, shut down the connection
     * manager/httpproxy to ensure immediate deallocation of all system
     * resources.
     */
    public synchronized void shutdown() {
        proxy.shutdown();
    }

    /**
     * Closes this resource, relinquishing any underlying resources.
     * This method is invoked automatically on objects managed by the
     * try-with-resources statement.
     */
    @Override
    public void close() throws Exception {
        shutdown();
    }

    /**
     * Gets the value of the Bookmarks property.
     *
     * @return
     *     {@link Bookmarks }
     *
     */
    public Bookmarks getBookmarks() {
        if (this.bookmarks == null) {
            synchronized (this.LOCK) {
                if (this.bookmarks == null) {
                    this.bookmarks = new Bookmarks(proxy);
                }
            }
        }
        return bookmarks;
    }
    /**
     * Gets the value of the Capabilities property.
     *
     * @return
     *     {@link Capabilities }
     *
     */
    public Capabilities getCapabilities() {
        if (this.capabilities == null) {
            synchronized (this.LOCK) {
                if (this.capabilities == null) {
                    this.capabilities = new Capabilities(proxy);
                }
            }
        }
        return capabilities;
    }
    /**
     * Gets the value of the Clusters property.
     *
     * @return
     *     {@link Clusters }
     *
     */
    public Clusters getClusters() {
        if (this.clusters == null) {
            synchronized (this.LOCK) {
                if (this.clusters == null) {
                    this.clusters = new Clusters(proxy);
                }
            }
        }
        return clusters;
    }
    /**
     * Gets the value of the CpuProfiles property.
     *
     * @return
     *     {@link CpuProfiles }
     *
     */
    public CpuProfiles getCpuProfiles() {
        if (this.cpuProfiles == null) {
            synchronized (this.LOCK) {
                if (this.cpuProfiles == null) {
                    this.cpuProfiles = new CpuProfiles(proxy);
                }
            }
        }
        return cpuProfiles;
    }
    /**
     * Gets the value of the DataCenters property.
     *
     * @return
     *     {@link DataCenters }
     *
     */
    public DataCenters getDataCenters() {
        if (this.dataCenters == null) {
            synchronized (this.LOCK) {
                if (this.dataCenters == null) {
                    this.dataCenters = new DataCenters(proxy);
                }
            }
        }
        return dataCenters;
    }
    /**
     * Gets the value of the DiskProfiles property.
     *
     * @return
     *     {@link DiskProfiles }
     *
     */
    public DiskProfiles getDiskProfiles() {
        if (this.diskProfiles == null) {
            synchronized (this.LOCK) {
                if (this.diskProfiles == null) {
                    this.diskProfiles = new DiskProfiles(proxy);
                }
            }
        }
        return diskProfiles;
    }
    /**
     * Gets the value of the Disks property.
     *
     * @return
     *     {@link Disks }
     *
     */
    public Disks getDisks() {
        if (this.disks == null) {
            synchronized (this.LOCK) {
                if (this.disks == null) {
                    this.disks = new Disks(proxy);
                }
            }
        }
        return disks;
    }
    /**
     * Gets the value of the Domains property.
     *
     * @return
     *     {@link Domains }
     *
     */
    public Domains getDomains() {
        if (this.domains == null) {
            synchronized (this.LOCK) {
                if (this.domains == null) {
                    this.domains = new Domains(proxy);
                }
            }
        }
        return domains;
    }
    /**
     * Gets the value of the Events property.
     *
     * @return
     *     {@link Events }
     *
     */
    public Events getEvents() {
        if (this.events == null) {
            synchronized (this.LOCK) {
                if (this.events == null) {
                    this.events = new Events(proxy);
                }
            }
        }
        return events;
    }
    /**
     * Gets the value of the ExternalHostProviders property.
     *
     * @return
     *     {@link ExternalHostProviders }
     *
     */
    public ExternalHostProviders getExternalHostProviders() {
        if (this.externalHostProviders == null) {
            synchronized (this.LOCK) {
                if (this.externalHostProviders == null) {
                    this.externalHostProviders = new ExternalHostProviders(proxy);
                }
            }
        }
        return externalHostProviders;
    }
    /**
     * Gets the value of the Groups property.
     *
     * @return
     *     {@link Groups }
     *
     */
    public Groups getGroups() {
        if (this.groups == null) {
            synchronized (this.LOCK) {
                if (this.groups == null) {
                    this.groups = new Groups(proxy);
                }
            }
        }
        return groups;
    }
    /**
     * Gets the value of the Hosts property.
     *
     * @return
     *     {@link Hosts }
     *
     */
    public Hosts getHosts() {
        if (this.hosts == null) {
            synchronized (this.LOCK) {
                if (this.hosts == null) {
                    this.hosts = new Hosts(proxy);
                }
            }
        }
        return hosts;
    }
    /**
     * Gets the value of the Icons property.
     *
     * @return
     *     {@link Icons }
     *
     */
    public Icons getIcons() {
        if (this.icons == null) {
            synchronized (this.LOCK) {
                if (this.icons == null) {
                    this.icons = new Icons(proxy);
                }
            }
        }
        return icons;
    }
    /**
     * Gets the value of the InstanceTypes property.
     *
     * @return
     *     {@link InstanceTypes }
     *
     */
    public InstanceTypes getInstanceTypes() {
        if (this.instanceTypes == null) {
            synchronized (this.LOCK) {
                if (this.instanceTypes == null) {
                    this.instanceTypes = new InstanceTypes(proxy);
                }
            }
        }
        return instanceTypes;
    }
    /**
     * Gets the value of the Jobs property.
     *
     * @return
     *     {@link Jobs }
     *
     */
    public Jobs getJobs() {
        if (this.jobs == null) {
            synchronized (this.LOCK) {
                if (this.jobs == null) {
                    this.jobs = new Jobs(proxy);
                }
            }
        }
        return jobs;
    }
    /**
     * Gets the value of the KatelloErrata property.
     *
     * @return
     *     {@link KatelloErrata }
     *
     */
    public KatelloErrata getKatelloErrata() {
        if (this.katelloErrata == null) {
            synchronized (this.LOCK) {
                if (this.katelloErrata == null) {
                    this.katelloErrata = new KatelloErrata(proxy);
                }
            }
        }
        return katelloErrata;
    }
    /**
     * Gets the value of the MacPools property.
     *
     * @return
     *     {@link MacPools }
     *
     */
    public MacPools getMacPools() {
        if (this.macPools == null) {
            synchronized (this.LOCK) {
                if (this.macPools == null) {
                    this.macPools = new MacPools(proxy);
                }
            }
        }
        return macPools;
    }
    /**
     * Gets the value of the Networks property.
     *
     * @return
     *     {@link Networks }
     *
     */
    public Networks getNetworks() {
        if (this.networks == null) {
            synchronized (this.LOCK) {
                if (this.networks == null) {
                    this.networks = new Networks(proxy);
                }
            }
        }
        return networks;
    }
    /**
     * Gets the value of the OpenStackImageProviders property.
     *
     * @return
     *     {@link OpenStackImageProviders }
     *
     */
    public OpenStackImageProviders getOpenStackImageProviders() {
        if (this.openStackImageProviders == null) {
            synchronized (this.LOCK) {
                if (this.openStackImageProviders == null) {
                    this.openStackImageProviders = new OpenStackImageProviders(proxy);
                }
            }
        }
        return openStackImageProviders;
    }
    /**
     * Gets the value of the OpenStackNetworkProviders property.
     *
     * @return
     *     {@link OpenStackNetworkProviders }
     *
     */
    public OpenStackNetworkProviders getOpenStackNetworkProviders() {
        if (this.openStackNetworkProviders == null) {
            synchronized (this.LOCK) {
                if (this.openStackNetworkProviders == null) {
                    this.openStackNetworkProviders = new OpenStackNetworkProviders(proxy);
                }
            }
        }
        return openStackNetworkProviders;
    }
    /**
     * Gets the value of the OpenStackVolumeProviders property.
     *
     * @return
     *     {@link OpenStackVolumeProviders }
     *
     */
    public OpenStackVolumeProviders getOpenStackVolumeProviders() {
        if (this.openStackVolumeProviders == null) {
            synchronized (this.LOCK) {
                if (this.openStackVolumeProviders == null) {
                    this.openStackVolumeProviders = new OpenStackVolumeProviders(proxy);
                }
            }
        }
        return openStackVolumeProviders;
    }
    /**
     * Gets the value of the OperatingSystemInfos property.
     *
     * @return
     *     {@link OperatingSystemInfos }
     *
     */
    public OperatingSystemInfos getOperatingSystemInfos() {
        if (this.operatingSystemInfos == null) {
            synchronized (this.LOCK) {
                if (this.operatingSystemInfos == null) {
                    this.operatingSystemInfos = new OperatingSystemInfos(proxy);
                }
            }
        }
        return operatingSystemInfos;
    }
    /**
     * Gets the value of the Permissions property.
     *
     * @return
     *     {@link Permissions }
     *
     */
    public Permissions getPermissions() {
        if (this.permissions == null) {
            synchronized (this.LOCK) {
                if (this.permissions == null) {
                    this.permissions = new Permissions(proxy);
                }
            }
        }
        return permissions;
    }
    /**
     * Gets the value of the Roles property.
     *
     * @return
     *     {@link Roles }
     *
     */
    public Roles getRoles() {
        if (this.roles == null) {
            synchronized (this.LOCK) {
                if (this.roles == null) {
                    this.roles = new Roles(proxy);
                }
            }
        }
        return roles;
    }
    /**
     * Gets the value of the SchedulingPolicies property.
     *
     * @return
     *     {@link SchedulingPolicies }
     *
     */
    public SchedulingPolicies getSchedulingPolicies() {
        if (this.schedulingPolicies == null) {
            synchronized (this.LOCK) {
                if (this.schedulingPolicies == null) {
                    this.schedulingPolicies = new SchedulingPolicies(proxy);
                }
            }
        }
        return schedulingPolicies;
    }
    /**
     * Gets the value of the SchedulingPolicyUnits property.
     *
     * @return
     *     {@link SchedulingPolicyUnits }
     *
     */
    public SchedulingPolicyUnits getSchedulingPolicyUnits() {
        if (this.schedulingPolicyUnits == null) {
            synchronized (this.LOCK) {
                if (this.schedulingPolicyUnits == null) {
                    this.schedulingPolicyUnits = new SchedulingPolicyUnits(proxy);
                }
            }
        }
        return schedulingPolicyUnits;
    }
    /**
     * Gets the value of the StorageConnections property.
     *
     * @return
     *     {@link StorageConnections }
     *
     */
    public StorageConnections getStorageConnections() {
        if (this.storageConnections == null) {
            synchronized (this.LOCK) {
                if (this.storageConnections == null) {
                    this.storageConnections = new StorageConnections(proxy);
                }
            }
        }
        return storageConnections;
    }
    /**
     * Gets the value of the StorageDomains property.
     *
     * @return
     *     {@link StorageDomains }
     *
     */
    public StorageDomains getStorageDomains() {
        if (this.storageDomains == null) {
            synchronized (this.LOCK) {
                if (this.storageDomains == null) {
                    this.storageDomains = new StorageDomains(proxy);
                }
            }
        }
        return storageDomains;
    }
    /**
     * Gets the value of the Tags property.
     *
     * @return
     *     {@link Tags }
     *
     */
    public Tags getTags() {
        if (this.tags == null) {
            synchronized (this.LOCK) {
                if (this.tags == null) {
                    this.tags = new Tags(proxy);
                }
            }
        }
        return tags;
    }
    /**
     * Gets the value of the Templates property.
     *
     * @return
     *     {@link Templates }
     *
     */
    public Templates getTemplates() {
        if (this.templates == null) {
            synchronized (this.LOCK) {
                if (this.templates == null) {
                    this.templates = new Templates(proxy);
                }
            }
        }
        return templates;
    }
    /**
     * Gets the value of the Users property.
     *
     * @return
     *     {@link Users }
     *
     */
    public Users getUsers() {
        if (this.users == null) {
            synchronized (this.LOCK) {
                if (this.users == null) {
                    this.users = new Users(proxy);
                }
            }
        }
        return users;
    }
    /**
     * Gets the value of the VmPools property.
     *
     * @return
     *     {@link VmPools }
     *
     */
    public VmPools getVmPools() {
        if (this.vmPools == null) {
            synchronized (this.LOCK) {
                if (this.vmPools == null) {
                    this.vmPools = new VmPools(proxy);
                }
            }
        }
        return vmPools;
    }
    /**
     * Gets the value of the VMs property.
     *
     * @return
     *     {@link VMs }
     *
     */
    public VMs getVMs() {
        if (this.vMs == null) {
            synchronized (this.LOCK) {
                if (this.vMs == null) {
                    this.vMs = new VMs(proxy);
                }
            }
        }
        return vMs;
    }
    /**
     * Gets the value of the VnicProfiles property.
     *
     * @return
     *     {@link VnicProfiles }
     *
     */
    public VnicProfiles getVnicProfiles() {
        if (this.vnicProfiles == null) {
            synchronized (this.LOCK) {
                if (this.vnicProfiles == null) {
                    this.vnicProfiles = new VnicProfiles(proxy);
                }
            }
        }
        return vnicProfiles;
    }


    /**
     * Gets the value of the Comment property.
     *
     * @return {@link java.lang.String }
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site using HTTP protocol has occurred.
     */
    public java.lang.String getComment() throws ClientProtocolException, ServerException,
            UnsecuredConnectionAttemptError, IOException {
        return getEntryPoint().getComment();
    }
    /**
     * Gets the value of the ProductInfo property.
     *
     * @return {@link org.ovirt.engine.sdk.entities.ProductInfo }
     *
     */
    public org.ovirt.engine.sdk.entities.ProductInfo getProductInfo() {
        if (this.entryPoint != null) {
            return this.entryPoint.getProductInfo();
        }
        return null;
    }
    /**
     * Gets the value of the SpecialObjects property.
     *
     * @return {@link org.ovirt.engine.sdk.entities.SpecialObjects }
     *
     */
    public org.ovirt.engine.sdk.entities.SpecialObjects getSpecialObjects() {
        if (this.entryPoint != null) {
            return this.entryPoint.getSpecialObjects();
        }
        return null;
    }
    /**
     * Gets the value of the Summary property.
     *
     * @return {@link org.ovirt.engine.sdk.entities.ApiSummary }
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site using HTTP protocol has occurred.
     */
    public org.ovirt.engine.sdk.entities.ApiSummary getSummary() throws ClientProtocolException, ServerException,
            UnsecuredConnectionAttemptError, IOException {
        return getEntryPoint().getSummary();
    }
    /**
     * Gets the value of the Time property.
     *
     * @return {@link javax.xml.datatype.XMLGregorianCalendar }
     *
     * @throws ClientProtocolException
     *             Signals that HTTP/S protocol error has occurred.
     * @throws ServerException
     *             Signals that an oVirt api error has occurred.
     * @throws IOException
     *             Signals that an I/O exception of some sort has occurred.
     * @throws UnsecuredConnectionAttemptError
     *             Signals that attempt of connecting to SSL secured site using HTTP protocol has occurred.
     */
    public javax.xml.datatype.XMLGregorianCalendar getTime() throws ClientProtocolException, ServerException,
            UnsecuredConnectionAttemptError, IOException {
        return getEntryPoint().getTime();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy