<?xml version="1.0" ?>
<!--
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
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.
NOTE: This service manifest is not editable; its contents will
be overwritten by package or patch operations, including
operating system upgrade. Make customizations in a different
file.
-->
<service_bundle type="manifest" name="cinder-api">
<service version="1" type="service"
name="application/openstack/cinder/cinder-api">
<dependency name='multiuser' grouping='require_all' restart_on='error'
type='service'>
<service_fmri value='svc:/milestone/multi-user:default' />
</dependency>
<dependency name='upgrade' grouping='require_all' restart_on='none'
type='service'>
<service_fmri
value='svc:/application/openstack/cinder/cinder-upgrade' />
</dependency>
<!-- create a dependency on the cinder_db service so the cinder
services do not collide when creating the database -->
<dependency name='cinder_db' grouping='optional_all' restart_on='error'
type='service'>
<service_fmri value='svc:/application/openstack/cinder/cinder-db'/>
</dependency>
<dependency name='ntp' grouping='optional_all' restart_on='none'
type='service'>
</dependency>
<dependency name='rabbitmq' grouping='optional_all' restart_on='none'
type='service'>
<service_fmri value='svc:/application/rabbitmq'/>
</dependency>
<logfile_attributes permissions='600'/>
<exec_method timeout_seconds="60" type="method" name="start"
exec="/lib/svc/method/cinder-api %m">
<method_context>
<method_credential user='cinder' group='cinder'
privileges='basic,{zone}:/system/volatile/cinder_wsgi_*'/>
</method_context>
</exec_method>
<exec_method timeout_seconds="60" type="method" name="stop"
exec="/lib/svc/method/cinder-api %m">
<method_context>
<method_credential user='cinder' group='cinder'/>
</method_context>
</exec_method>
<exec_method timeout_seconds="60" type="method" name="restart"
exec="/lib/svc/method/cinder-api %m">
<method_context>
<method_credential user='cinder' group='cinder' />
</method_context>
</exec_method>
<property_group type="framework" name="startd">
<propval type="astring" name="ignore_error" value="core,signal"/>
</property_group>
<instance name='default' enabled='false'>
<property_group name='general' type='framework'>
<propval name='action_authorization' type='astring'
value='solaris.smf.manage.cinder' />
<propval name='value_authorization' type='astring'
value='solaris.smf.value.cinder' />
</property_group>
<property_group name='cinder-api_stencil' type='configfile'>
<propval name='path' type='astring'
value='/var/lib/cinder/cinder.httpd.conf'/>
<propval name='mode' type='astring' value='0444'/>
<propval name='owner' type='astring' value='cinder'/>
<propval name='group' type='astring' value='cinder'/>
</property_group>
<property_group name='config' type='application'>
<propval name='access_log' type='astring'
value='/var/log/cinder/cinder_access.log'/>
<propval name='error_log' type='astring'
value='/var/log/cinder/cinder_error.log'/>
<propval name='port' type='count' value='8776'/>
<propval name='servername' type='astring' value='127.0.0.1'/>
<propval name='use_tls' type='boolean' value='false'/>
</property_group>
</instance>
<template>
<common_name>
<loctext xml:lang="C">
OpenStack Cinder API Service
</loctext>
</common_name>
<description>
<loctext xml:lang="C">
cinder-api is a server daemon that provides the Cinder API service in
order to provide volume management for the OpenStack Compute service.
</loctext>
</description>
<documentation>
<external_logfile
path='/var/log/cinder/cinder_access.log'/>
<external_logfile
path='/var/log/cinder/cinder_error.log'/>
</documentation>
<pg_pattern required='true' type='application' name='config'>
<prop_pattern required='true' type='astring' name='access_log'>
<description>
<loctext xml:lang='C'>
The absolute path for the Apache access log file. Defaults to
</loctext>
</description>
</prop_pattern>
<prop_pattern required='true' type='astring' name='error_log'>
<description>
<loctext xml:lang='C'>
The absolute path for the Apache error log file. Defaults to
</loctext>
</description>
</prop_pattern>
<prop_pattern required='true' type='count' name='port'>
<description>
<loctext xml:lang='C'>
The port for public requests. Default value is 8776.
</loctext>
</description>
</prop_pattern>
<prop_pattern required='true' type='astring' name='servername'>
<description>
<loctext xml:lang='C'>
The Apache ServerName Directive. Hostname and port that the
server uses to identify itself.
</loctext>
</description>
</prop_pattern>
<prop_pattern required='false' type='astring' name='ssl_cert_file'>
<description>
<loctext xml:lang='C'>
Server PEM-encoded X.509 Certificate file.
</loctext>
</description>
</prop_pattern>
<prop_pattern required='false' type='astring' name='ssl_ca_cert_file'>
<description>
<loctext xml:lang='C'>
File of concatenated PEM-encoded CA Certificates for Client Auth.
</loctext>
</description>
</prop_pattern>
<prop_pattern required='false' type='astring' name='ssl_cert_key_file'>
<description>
<loctext xml:lang='C'>
Server PEM-encoded Private Key file.
</loctext>
</description>
</prop_pattern>
<prop_pattern required='true' type='boolean' name='use_tls'>
<description>
<loctext xml:lang='C'>
Boolean property to indicate usage of TLS. Defaults to 'false'.
</loctext>
</description>
</prop_pattern>
</pg_pattern>
</template>
</service>
</service_bundle>