summaryrefslogtreecommitdiff
path: root/usr/src/cmd/cmd-inet/usr.sbin/ipsecutils/manual-key.xml
blob: d1dac2b94cae42a9ef174f649578eaddab0adbe4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
<?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:manual-key'>

<service
        name='network/ipsec/manual-key'
        type='service'
        version='1'>

        <!-- The 'manual-key' service is delivered disabled
	because there is not a default configuration file.
        See note below on changing the default configuration file. -->

        <create_default_instance enabled='false' />

        <single_instance />

	<!-- Read/Write access to /var/run required for lock files -->
	<dependency
		name='filesystem'
		grouping='require_all'
		restart_on='none'
		type='service'>
		<service_fmri
			value='svc:/system/filesystem/minimal'
		/>
	</dependency>
	<!-- Kernel needs to know IPsec supported algorithms -->
        <dependency
                name='algorithms'
                grouping='require_all'
                restart_on='none'
                type='service'>
                <service_fmri
                        value='svc:/network/ipsec/ipsecalgs'
                />
        </dependency>

        <!-- If we are enabled, we should be running fairly early -->

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

        <exec_method
                type='method'
                name='start'
                exec='/usr/sbin/ipseckey -f  %{config/config_file}'
                timeout_seconds='60'
        />

	<!-- To prevent ipseckey generating warnings about duplicate
	SAs when the service is refreshed, ipseckey will flush the
	existing SAs when its called from smf(5). -->

        <exec_method
                type='method'
                name='refresh'
                exec='/usr/sbin/ipseckey -f  %{config/config_file}'
                timeout_seconds='60'
        />

        <exec_method
                type='method'
                name='stop'
                exec='/usr/sbin/ipseckey flush'
                timeout_seconds='60'
        />

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

			svcadm restart manual-key
			svcadm refresh manual-key
			svcadm mark <state> manual-key
			svcadm clear manual-key

		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 manual-key
			svcadm enable manual-key

		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 manual-key setprop config/config_file = /new/config_file

	The new configurations will be read on service refresh:

	svcadm refresh ipsec/manual-key

	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/secret/ipseckeys'
                />
		<propval
			name='value_authorization'
			type='astring'
			value='solaris.smf.value.ipsec'
		/>
        </property_group>

        <property_group name='startd' type='framework'>
                <propval
                        name='duration'
                        type='astring'
                        value='transient'
                />
        </property_group>

        <stability value='Unstable' />

        <template>
                <common_name>
                        <loctext xml:lang='C'>
                                manually keyed IPsec startup
                        </loctext>
                </common_name>
                <description>
                        <loctext xml:lang='C'>
                                Loads static security associations
                        </loctext>
                </description>
                <documentation>
                        <manpage title='ipseckey' section='1M'
                                manpath='/usr/share/man' />
                </documentation>
        </template>
</service>
</service_bundle>