123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- # -*- Mode: Python -*-
- # vim: filetype=python
- ##
- # = User authorization
- ##
- ##
- # @QAuthZListPolicy:
- #
- # The authorization policy result
- #
- # @deny: deny access
- #
- # @allow: allow access
- #
- # Since: 4.0
- ##
- { 'enum': 'QAuthZListPolicy',
- 'prefix': 'QAUTHZ_LIST_POLICY',
- 'data': ['deny', 'allow']}
- ##
- # @QAuthZListFormat:
- #
- # The authorization policy match format
- #
- # @exact: an exact string match
- #
- # @glob: string with ? and * shell wildcard support
- #
- # Since: 4.0
- ##
- { 'enum': 'QAuthZListFormat',
- 'prefix': 'QAUTHZ_LIST_FORMAT',
- 'data': ['exact', 'glob']}
- ##
- # @QAuthZListRule:
- #
- # A single authorization rule.
- #
- # @match: a string or glob to match against a user identity
- #
- # @policy: the result to return if @match evaluates to true
- #
- # @format: the format of the @match rule (default 'exact')
- #
- # Since: 4.0
- ##
- { 'struct': 'QAuthZListRule',
- 'data': {'match': 'str',
- 'policy': 'QAuthZListPolicy',
- '*format': 'QAuthZListFormat'}}
- ##
- # @AuthZListProperties:
- #
- # Properties for authz-list objects.
- #
- # @policy: Default policy to apply when no rule matches (default:
- # deny)
- #
- # @rules: Authorization rules based on matching user
- #
- # Since: 4.0
- ##
- { 'struct': 'AuthZListProperties',
- 'data': { '*policy': 'QAuthZListPolicy',
- '*rules': ['QAuthZListRule'] } }
- ##
- # @AuthZListFileProperties:
- #
- # Properties for authz-listfile objects.
- #
- # @filename: File name to load the configuration from. The file must
- # contain valid JSON for AuthZListProperties.
- #
- # @refresh: If true, inotify is used to monitor the file,
- # automatically reloading changes. If an error occurs during
- # reloading, all authorizations will fail until the file is next
- # successfully loaded. (default: true if the binary was built
- # with CONFIG_INOTIFY1, false otherwise)
- #
- # Since: 4.0
- ##
- { 'struct': 'AuthZListFileProperties',
- 'data': { 'filename': 'str',
- '*refresh': 'bool' } }
- ##
- # @AuthZPAMProperties:
- #
- # Properties for authz-pam objects.
- #
- # @service: PAM service name to use for authorization
- #
- # Since: 4.0
- ##
- { 'struct': 'AuthZPAMProperties',
- 'data': { 'service': 'str' } }
- ##
- # @AuthZSimpleProperties:
- #
- # Properties for authz-simple objects.
- #
- # @identity: Identifies the allowed user. Its format depends on the
- # network service that authorization object is associated with.
- # For authorizing based on TLS x509 certificates, the identity
- # must be the x509 distinguished name.
- #
- # Since: 4.0
- ##
- { 'struct': 'AuthZSimpleProperties',
- 'data': { 'identity': 'str' } }
|