| # -*- 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' } } |