NAME
Ubic::Multiservice - interface of multiservice representing several named services
SYNOPSIS
$service = $multiservice->service("yandex.yandex-ppb-people-pt.meta-all");
@services = $multiservice->services();
DESCRIPTION
Multiservice's interface consists of two fundamental methods: service($name)
to get service by it's name, and services()
to get list of all services.
Additionally, you can check whether multiservice contains service without instantiating it, using has_service($name)
method.
Remember that althouth multiservice is currently a service too, it doesn't implement start/stop/status methods. This is because user will usually want to see action's progress, and all output policy is defined in Ubic::Cmd class; interaction protocol between this class and Ubic::Cmd
class would be too hard to code.
METHODS
- service($name)
-
Get service by name.
This class provides common implementation which can delegate searching of subservices to multiservices (don't panic!), so subclasses should implement
simple_service
instead. - simple_service()
-
This method should be implemented by subclass.
- has_service($name)
-
Check whether service with specified name exists in this multiservice.
Like
service
, subclasses should usually implementhas_simple_service
instead. - has_simple_service($name)
-
This method should be implemented by subclass.
- services()
-
Construct all subservices. Because they are top-level, we don't need
simple_services()
.By default, it uses
service_names
to get list of services. - service_names()
-
Get list with names of all subservices.
Subclasses should usually override this method,
services
uses it in default implementation. - multiop()
-
Get multiop operation mode of object. There are three possible values which this method can return:
SEE ALSO
Ubic::Multiservice::Simple - class for defining simple multiservices.
Ubic::Multiservice::Dir - multiservice which loads service configs from files.
AUTHOR
Vyacheslav Matjukhin <mmcleric@yandex-team.ru>