org.ovirt.engine.sdk4.services.VmWatchdogService Maven / Gradle / Ivy
/*
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 org.ovirt.engine.sdk4.Request;
import org.ovirt.engine.sdk4.Response;
import org.ovirt.engine.sdk4.Service;
import org.ovirt.engine.sdk4.builders.WatchdogBuilder;
import org.ovirt.engine.sdk4.types.Watchdog;
/**
* A service managing a watchdog on virtual machines.
*/
public interface VmWatchdogService extends Service {
/**
* Returns the information about the watchdog.
*/
public interface GetRequest extends Request {
}
/**
* Returns the information about the watchdog.
*/
public interface GetResponse extends Response {
/**
* The information about the watchdog.
*
* The information consists of `model` element, `action` element and the reference to the
* virtual machine. It may look like this:
*
* [source,xml]
* ----
*
*
*
* poweroff
* i6300esb
*
*
* ----
*/
Watchdog watchdog();
}
/**
* Returns the information about the watchdog.
*/
GetRequest get();
/**
* Removes the watchdog from the virtual machine.
*
* For example, to remove a watchdog from a virtual machine, send a request like this:
*
* [source]
* ----
* DELETE /ovirt-engine/api/vms/123/watchdogs/00000000-0000-0000-0000-000000000000
* ----
*/
public interface RemoveRequest extends Request {
/**
* Indicates if the remove should be performed asynchronously.
*/
RemoveRequest async(Boolean async);
}
/**
* Removes the watchdog from the virtual machine.
*
* For example, to remove a watchdog from a virtual machine, send a request like this:
*
* [source]
* ----
* DELETE /ovirt-engine/api/vms/123/watchdogs/00000000-0000-0000-0000-000000000000
* ----
*/
public interface RemoveResponse extends Response {
}
/**
* Removes the watchdog from the virtual machine.
*
* For example, to remove a watchdog from a virtual machine, send a request like this:
*
* [source]
* ----
* DELETE /ovirt-engine/api/vms/123/watchdogs/00000000-0000-0000-0000-000000000000
* ----
*/
RemoveRequest remove();
/**
* Updates the information about the watchdog.
*
* You can update the information using `action` and `model` elements.
*
* For example, to update a watchdog, send a request like this:
*
* [source]
* ----
* PUT /ovirt-engine/api/vms/123/watchdogs
*
* reset
*
* ----
*
* with response body:
*
* [source,xml]
* ----
*
*
* reset
* i6300esb
*
* ----
*/
public interface UpdateRequest extends Request {
/**
* Indicates if the update should be performed asynchronously.
*/
UpdateRequest async(Boolean async);
UpdateRequest watchdog(Watchdog watchdog);
/**
* The information about the watchdog.
*
* The request data must contain at least one of `model` and `action`
* elements. The response data contains complete information about the
* updated watchdog.
*/
UpdateRequest watchdog(WatchdogBuilder watchdog);
}
/**
* Updates the information about the watchdog.
*
* You can update the information using `action` and `model` elements.
*
* For example, to update a watchdog, send a request like this:
*
* [source]
* ----
* PUT /ovirt-engine/api/vms/123/watchdogs
*
* reset
*
* ----
*
* with response body:
*
* [source,xml]
* ----
*
*
* reset
* i6300esb
*
* ----
*/
public interface UpdateResponse extends Response {
/**
* The information about the watchdog.
*
* The request data must contain at least one of `model` and `action`
* elements. The response data contains complete information about the
* updated watchdog.
*/
Watchdog watchdog();
}
/**
* Updates the information about the watchdog.
*
* You can update the information using `action` and `model` elements.
*
* For example, to update a watchdog, send a request like this:
*
* [source]
* ----
* PUT /ovirt-engine/api/vms/123/watchdogs
*
* reset
*
* ----
*
* with response body:
*
* [source,xml]
* ----
*
*
* reset
* i6300esb
*
* ----
*/
UpdateRequest update();
/**
* Service locator method, returns individual service on which the URI is dispatched.
*/
Service service(String path);
}