<?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
<!--
    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

    Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
    Use is subject to license terms.

    Copyright 2021 Friedrich Kink <friedrich.kink@gmail.com>

    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='service/network/smtp/opendkim:opendkim'>
<service name="network/smtp" type="service" version="1">

        <single_instance/>

        <dependency name="fs-local" grouping="require_all" restart_on="none" type="service">
                <service_fmri value="svc:/system/filesystem/local"/>
        </dependency>

        <dependency name="network-service" grouping="require_all" restart_on="none" type="service">
                <service_fmri value="svc:/network/service"/>
        </dependency>

        <dependency name="name-services" grouping="require_all" restart_on="refresh" type="service">
                <service_fmri value="svc:/milestone/name-services"/>
        </dependency>

        <dependency name="identity" grouping="optional_all" restart_on="refresh" type="service">
                <service_fmri value="svc:/system/identity:domain"/>
        </dependency>

        <dependency name="system-log" grouping="optional_all" restart_on="none" type="service">
                <service_fmri value="svc:/system/system-log"/>
        </dependency>

        <property_group name="firewall_context" type="com.sun,fw_definition">
                <propval name="name" type="astring" value="smtp"/>
        </property_group>

        <property_group name="firewall_config" type="com.sun,fw_configuration">
                <propval name="policy" type="astring" value="use_global"/>
                <propval name="block_policy" type="astring" value="use_global"/>
                <propval name="apply_to" type="astring" value=""/>
                <propval name="apply_to_6" type="astring" value=""/>
                <propval name="exceptions" type="astring" value=""/>
                <propval name="exceptions_6" type="astring" value=""/>
                <propval name="target" type="astring" value=""/>
                <propval name="target_6" type="astring" value=""/>
                <propval name="value_authorization" type="astring" value="solaris.smf.value.firewall.config"/>
        </property_group>

        <instance name="opendkim" enabled="false">

                <dependency name="config-file" grouping="require_all" restart_on="refresh" type="path">
                        <service_fmri value="file://localhost/etc/mail/opendkim.conf"/>
                </dependency>

                <dependency name="nsswitch" grouping="require_all" restart_on="refresh" type="path">
                        <service_fmri value="file://localhost/etc/nsswitch.conf"/>
                </dependency>

                <dependency name="autofs" grouping="optional_all" restart_on="none" type="service">
                        <service_fmri value="svc:/system/filesystem/autofs"/>
                </dependency>

                <dependent name="smtp-opendkim_multi-user" grouping="optional_all" restart_on="none">
                                <service_fmri value="svc:/milestone/multi-user"/>
                </dependent>

                <exec_method type="method" name="start" exec="/usr/sbin/opendkim" timeout_seconds="60">
			<method_context>
				 <method_credential user='opendkim' group='opendkim' privileges='basic,net_privaddr,proc_setid,file_dac_read,file_dac_search'/>
			</method_context>
		</exec_method>

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

                <property_group name="startd" type="framework">
                        <propval name="ignore_error" type="astring" value="core,signal"/>
                </property_group>

                <property_group name="general" type="framework">
                        <propval name="action_authorization" type="astring" value="solaris.smf.manage.opendkim"/>
                </property_group>

                <template>
                        <common_name>
                                <loctext xml:lang="C">
                                OpenDKIM is an open source implementation of the DKIM (Domain Keys Identified Mail) sender authentication system
                                </loctext>
                        </common_name>
                        <documentation>
                                <manpage title="opendkim" section="1M" manpath="/usr/share/man"/>
                        </documentation>
                </template>

        </instance>

        <stability value="Unstable"/>

</service>

</service_bundle>