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

org.ovirt.engine.sdk4.services.TagsService Maven / Gradle / Ivy

There is a newer version: 4.5.1
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 org.ovirt.engine.sdk4.services;

import java.io.IOException;
import java.math.BigInteger;
import java.util.List;
import org.ovirt.engine.sdk4.Request;
import org.ovirt.engine.sdk4.Response;
import org.ovirt.engine.sdk4.Service;
import org.ovirt.engine.sdk4.builders.TagBuilder;
import org.ovirt.engine.sdk4.types.Tag;

/**
 * Represents a service to manage collection of the tags in the system.
 */
public interface TagsService extends Service {
    /**
     * Add a new tag to the system.
     * 
     * For example, to add new tag with name `mytag` to the system send a request like this:
     * 
     * ....
     * POST /ovirt-engine/api/tags
     * ....
     * 
     * With a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     * 
     * ----
     * 
     * NOTE: The root tag is a special pseudo-tag assumed as the default parent tag if no parent tag is specified.
     * The root tag cannot be deleted nor assigned a parent tag.
     * 
     * To create new tag with specific parent tag send a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     *   
     *     myparenttag
     *   
     * 
     * ----
     */
    public interface AddRequest extends Request {
        AddRequest tag(Tag tag);
        /**
         * The added tag.
         */
        AddRequest tag(TagBuilder tag);
    }
    
    /**
     * Add a new tag to the system.
     * 
     * For example, to add new tag with name `mytag` to the system send a request like this:
     * 
     * ....
     * POST /ovirt-engine/api/tags
     * ....
     * 
     * With a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     * 
     * ----
     * 
     * NOTE: The root tag is a special pseudo-tag assumed as the default parent tag if no parent tag is specified.
     * The root tag cannot be deleted nor assigned a parent tag.
     * 
     * To create new tag with specific parent tag send a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     *   
     *     myparenttag
     *   
     * 
     * ----
     */
    public interface AddResponse extends Response {
        /**
         * The added tag.
         */
        Tag tag();
    }
    
    /**
     * Add a new tag to the system.
     * 
     * For example, to add new tag with name `mytag` to the system send a request like this:
     * 
     * ....
     * POST /ovirt-engine/api/tags
     * ....
     * 
     * With a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     * 
     * ----
     * 
     * NOTE: The root tag is a special pseudo-tag assumed as the default parent tag if no parent tag is specified.
     * The root tag cannot be deleted nor assigned a parent tag.
     * 
     * To create new tag with specific parent tag send a request body like this:
     * 
     * [source,xml]
     * ----
     * 
     *   mytag
     *   
     *     myparenttag
     *   
     * 
     * ----
     */
    AddRequest add();
    
    /**
     * List the tags in the system.
     * 
     * For example to list the full hierarchy of the tags in the system send a request like this:
     * 
     * ....
     * GET /ovirt-engine/api/tags
     * ....
     * 
     * [source,xml]
     * ----
     * 
     *   
     *     root2
     *     root2
     *     
     *   
     *   
     *     root3
     *     root3
     *     
     *   
     *   
     *     root
     *     root
     *   
     * 
     * ----
     * 
     * In the previous XML output you can see the following hierarchy of the tags:
     * ....
     * root:        (id: 111)
     *   - root2    (id: 222)
     *     - root3  (id: 333)
     * ....
     * 
     * The order of the returned list of tags isn't guaranteed.
     */
    public interface ListRequest extends Request {
        /**
         * Indicates which inner links should be _followed_. The objects referenced by these links will be fetched as part
         * of the current request. See <> for details.
         */
        ListRequest follow(String follow);
        /**
         * Sets the maximum number of tags to return. If not specified all the tags are returned.
         */
        ListRequest max(Integer max);
        /**
         * Sets the maximum number of tags to return. If not specified all the tags are returned.
         */
        ListRequest max(Long max);
        /**
         * Sets the maximum number of tags to return. If not specified all the tags are returned.
         */
        ListRequest max(BigInteger max);
    }
    
    /**
     * List the tags in the system.
     * 
     * For example to list the full hierarchy of the tags in the system send a request like this:
     * 
     * ....
     * GET /ovirt-engine/api/tags
     * ....
     * 
     * [source,xml]
     * ----
     * 
     *   
     *     root2
     *     root2
     *     
     *   
     *   
     *     root3
     *     root3
     *     
     *   
     *   
     *     root
     *     root
     *   
     * 
     * ----
     * 
     * In the previous XML output you can see the following hierarchy of the tags:
     * ....
     * root:        (id: 111)
     *   - root2    (id: 222)
     *     - root3  (id: 333)
     * ....
     * 
     * The order of the returned list of tags isn't guaranteed.
     */
    public interface ListResponse extends Response {
        /**
         * List of all tags in the system.
         */
        List tags();
    }
    
    /**
     * List the tags in the system.
     * 
     * For example to list the full hierarchy of the tags in the system send a request like this:
     * 
     * ....
     * GET /ovirt-engine/api/tags
     * ....
     * 
     * [source,xml]
     * ----
     * 
     *   
     *     root2
     *     root2
     *     
     *   
     *   
     *     root3
     *     root3
     *     
     *   
     *   
     *     root
     *     root
     *   
     * 
     * ----
     * 
     * In the previous XML output you can see the following hierarchy of the tags:
     * ....
     * root:        (id: 111)
     *   - root2    (id: 222)
     *     - root3  (id: 333)
     * ....
     * 
     * The order of the returned list of tags isn't guaranteed.
     */
    ListRequest list();
    
    /**
     * Reference to the service that manages a specific tag.
     */
    TagService tagService(String id);
    /**
     * Service locator method, returns individual service on which the URI is dispatched.
     */
    Service service(String path);
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy