<?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
<!--
	Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
	Use is subject to license terms.

 CDDL HEADER START

 The contents of this file are subject to the terms of the
 Common Development and Distribution License (the "License").
 You may not use this file except in compliance with the License.

 You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 or http://www.opensolaris.org/os/licensing.
 See the License for the specific language governing permissions
 and limitations under the License.

 When distributing Covered Code, include this CDDL HEADER in each
 file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 If applicable, add the following below this CDDL HEADER, with the
 fields enclosed by brackets "[]" replaced with your own identifying
 information: Portions Copyright [yyyy] [name of copyright owner]

 CDDL HEADER END

	ident	"%Z%%M%	%I%	%E% SMI"

	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='SUNWcsr:ike'>

<service
	name='network/ipsec/ike'
	type='service'
	version='1'>

	<create_default_instance enabled='false' />

	<single_instance />

	<!-- Read/Write access required to /var/run for lockfiles -->
	<dependency
		name='filesystem'
		grouping='require_all'
		restart_on='none'
		type='service'>
		<service_fmri
			value='svc:/system/filesystem/minimal'
		/>
	</dependency>

	<!-- Kernel needs to know supported IPsec algorithms -->
	<dependency
		name='algorithms'
		grouping='require_all'
		restart_on='none'
		type='service'>
		<service_fmri
			value='svc:/network/ipsec/ipsecalgs'
		/>
	</dependency>

	<dependent
		name='ike-network'
		grouping='optional_all'
		restart_on='none'>
		<service_fmri
			value='svc:/milestone/network'
		/>
	</dependent>

	<exec_method
		type='method'
		name='start'
		exec='/usr/lib/inet/in.iked'
		timeout_seconds='60' />

	<exec_method
		type='method'
		name='refresh'
		exec=':kill -HUP'
		timeout_seconds='60' />

	<exec_method
		type='method'
		name='stop'
		exec=':kill'
		timeout_seconds='60' />

	<property_group name='general' type='framework'>
		<!-- A user with this authorization can:

			svcadm restart ike
			svcadm refresh ike
			svcadm disable -t ike
			svcadm mark <state> ike
			svcadm clear ike

		see auths(1) and user_attr(4)-->

		<propval
			name='action_authorization'
			type='astring'
			value='solaris.smf.manage.ipsec'
		/>
		<!-- A user with this authorization can:
		
			svcadm disable ike
			svcadm enable ike

		see auths(1) and user_attr(4)-->

		<propval
			name='value_authorization'
			type='astring'
			value='solaris.smf.manage.ipsec'
		/>
	</property_group>

	<!-- The properties defined below can be changed by a user
	with 'solaris.smf.value.ipsec' authorization using the 
	svccfg(1M) command.

	EG:

	svccfg -s ipsec/ike setprop config/debug_level = all

	Now refresh the service:

	svcadm refresh ipsec/ike

	Note: svcadm disable/enable does not use the new property
	until after the service has been refreshed.

	***Do not edit this manifest to change these properties! -->

	<property_group name='config' type='application'>
		<propval
			name='config_file'
			type='astring'
			value='/etc/inet/ike/config'
		/>

		<!-- The default debug level is 'op' or operator debugging.
		The value 'all' has the same effect as the -d command line
		flag.

		The acceptable values for 'debug_level' and 'admin_privilege'
		are listed in the ikeadm(1M) man page.

		Note that DEBUG output is sent to 'debug_logfile', SMF
		messages and errors get written to 'restarter/log'
		these may be different files. -->

		<propval
			name='debug_level'
			type='astring'
			value='op'
		/>
		<propval
			name='debug_logfile'
			type='astring'
			value='/var/log/in.iked.log'
		/>
		<propval
			name='admin_privilege'
			type='astring'
			value='base'
		/>
		<propval
			name='ignore_errors'
			type='boolean'
			value='false'
		/>
		<propval
			name='value_authorization'
			type='astring'
			value='solaris.smf.value.ipsec'
		/>
	</property_group>

	<!-- default service model of 'contract' -->
	<property_group name='startd' type='framework'>
		<propval
			name='duration'
			type='astring'
			value='contract'
		/>
	</property_group>

	<stability value='Unstable' />

	<template>
		<common_name>
			<loctext xml:lang='C'>
			IKE daemon
			</loctext>
		</common_name>
		<documentation>
			<manpage title='in.iked' section='1M' manpath='/usr/share/man' />
		</documentation>
	</template>

</service>
</service_bundle>

