org.ovirt.engine.sdk.decorators.DataCenterClusterAffinityGroups.java Source code

Java tutorial

Introduction

Here is the source code for org.ovirt.engine.sdk.decorators.DataCenterClusterAffinityGroups.java

Source

//
// 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.decorators;

import java.io.IOException;
import java.util.List;
import java.util.UUID;

import org.apache.http.Header;
import org.apache.http.client.ClientProtocolException;
import org.ovirt.engine.sdk.common.CollectionDecorator;
import org.ovirt.engine.sdk.exceptions.ServerException;
import org.ovirt.engine.sdk.utils.CollectionUtils;
import org.ovirt.engine.sdk.utils.HttpHeaderBuilder;
import org.ovirt.engine.sdk.utils.HttpHeaderUtils;
import org.ovirt.engine.sdk.utils.UrlBuilder;
import org.ovirt.engine.sdk.utils.UrlBuilder;
import org.ovirt.engine.sdk.utils.UrlHelper;
import org.ovirt.engine.sdk.web.HttpProxyBroker;
import org.ovirt.engine.sdk.web.UrlParameterType;
import org.ovirt.engine.sdk.entities.Action;

/**
 * <p>DataCenterClusterAffinityGroups providing relation and functional services
 * <p>to {@link org.ovirt.engine.sdk.entities.AffinityGroups }.
 */
@SuppressWarnings("unused")
public class DataCenterClusterAffinityGroups extends
        CollectionDecorator<org.ovirt.engine.sdk.entities.AffinityGroup, org.ovirt.engine.sdk.entities.AffinityGroups, DataCenterClusterAffinityGroup> {

    private DataCenterCluster parent;

    /**
     * @param proxy HttpProxyBroker
     * @param parent DataCenterCluster
     */
    public DataCenterClusterAffinityGroups(HttpProxyBroker proxy, DataCenterCluster parent) {
        super(proxy, "affinitygroups");
        this.parent = parent;
    }

    /**
     * Lists DataCenterClusterAffinityGroup objects.
     *
     * @return
     *     List of {@link DataCenterClusterAffinityGroup }
     *
     * @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.
     */
    @Override
    public List<DataCenterClusterAffinityGroup> list()
            throws ClientProtocolException, ServerException, IOException {
        String url = this.parent.getHref() + SLASH + getName();
        return list(url, org.ovirt.engine.sdk.entities.AffinityGroups.class, DataCenterClusterAffinityGroup.class);
    }

    /**
     * Fetches DataCenterClusterAffinityGroup object by id.
     *
     * @return
     *     {@link DataCenterClusterAffinityGroup }
     *
     * @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.
     */
    @Override
    public DataCenterClusterAffinityGroup get(UUID id)
            throws ClientProtocolException, ServerException, IOException {
        String url = this.parent.getHref() + SLASH + getName() + SLASH + id.toString();
        return getProxy().get(url, org.ovirt.engine.sdk.entities.AffinityGroup.class,
                DataCenterClusterAffinityGroup.class);
    }

    /**
     * Fetches DataCenterClusterAffinityGroup object by id.
     *
     * @return
     *     {@link DataCenterClusterAffinityGroup }
     *
     * @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.
     */
    @Override
    public DataCenterClusterAffinityGroup getById(String id)
            throws ClientProtocolException, ServerException, IOException {
        String url = this.parent.getHref() + SLASH + getName() + SLASH + id;
        return getProxy().get(url, org.ovirt.engine.sdk.entities.AffinityGroup.class,
                DataCenterClusterAffinityGroup.class);
    }

    /**
     * Adds AffinityGroup object.
     *
     * @param affinitygroup {@link org.ovirt.engine.sdk.entities.AffinityGroup}
     * @return
     *     {@link DataCenterClusterAffinityGroup }
     *
     * @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.
     */
    public DataCenterClusterAffinityGroup add(org.ovirt.engine.sdk.entities.AffinityGroup affinitygroup)
            throws ClientProtocolException, ServerException, IOException {
        String url = this.parent.getHref() + SLASH + getName();

        HttpHeaderBuilder headersBuilder = new HttpHeaderBuilder();
        List<Header> headers = headersBuilder.build();

        UrlBuilder urlBuilder = new UrlBuilder(url);
        url = urlBuilder.build();

        return getProxy().add(url, affinitygroup, org.ovirt.engine.sdk.entities.AffinityGroup.class,
                DataCenterClusterAffinityGroup.class, headers);
    }

}