summaryrefslogtreecommitdiffstats
path: root/ipaclient/remote_plugins/2_164/pkinit.py
blob: fcb4c6b6bfb1eb19f9831193c7946f06859d580e (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
#
# Copyright (C) 2016  FreeIPA Contributors see COPYING for license
#

# pylint: disable=unused-import
import six

from . import Command, Method, Object
from ipalib import api, parameters, output
from ipalib.parameters import DefaultFrom
from ipalib.plugable import Registry
from ipalib.text import _
from ipapython.dn import DN
from ipapython.dnsutil import DNSName

if six.PY3:
    unicode = str

__doc__ = _("""
Kerberos pkinit options

Enable or disable anonymous pkinit using the principal
WELLKNOWN/ANONYMOUS@REALM. The server must have been installed with
pkinit support.

EXAMPLES:

 Enable anonymous pkinit:
  ipa pkinit-anonymous enable

 Disable anonymous pkinit:
  ipa pkinit-anonymous disable

For more information on anonymous pkinit see:

http://k5wiki.kerberos.org/wiki/Projects/Anonymous_pkinit
""")

register = Registry()


@register()
class pkinit(Object):
    takes_params = (
    )


@register()
class pkinit_anonymous(Command):
    __doc__ = _("Enable or Disable Anonymous PKINIT.")

    takes_args = (
        parameters.Str(
            'action',
        ),
    )
    takes_options = (
    )
    has_output = (
        output.Output(
            'result',
        ),
    )