Skip to content

Bundle Configuration

Created via ./bin/console config:dump-reference DbpRelayEsignBundle | sed '/^$/d'

# Default configuration for "DbpRelayEsignBundle"
dbp_relay_esign:
  qualified_signature:
    # The URL to the PDF-AS server for qualified signatures
    server_url:           ~ # Required, Example: 'https://pdfas.example.com/pdf-as-web'
    # The URL pdf-as will redirect to when the signature is done (optional)
    callback_url:         ~ # Deprecated (Since dbp/relay-esign-bundle ???: The "callback_url" option is deprecated. The API server now provides the callback URL itself.), Example: 'https://pdfas.example.com/static/callback.html'
    # The URL pdf-as will redirect to when the signature failed (optional)
    error_callback_url:   ~ # Deprecated (Since dbp/relay-esign-bundle ???: The "error_callback_url" option is deprecated. The API server now provides the callback URL itself.), Example: 'https://pdfas.example.com/static/error.html'
    profiles:
      # Prototype
      -
        # The name of the profile, this needs to be passed to the API
        name:                 ~ # Required, Example: myprofile
        # The Symfony role required to use this profile. If set, overrides the authorization config.
        role:                 ~ # Deprecated (Since dbp/relay-esign-bundle ???: The "role" option is deprecated. Use the global authorization node instead.), Example: ROLE_FOOBAR
        # The PDF-AS signature profile ID to use
        profile_id:           ~ # Required, Example: MYPROFILE
        # For extending the PDF-AS signature layout with user provided text (optional)
        user_text:
          # The profile table ID to attach the content to.
          target_table:         ~ # Required, Example: usercontent
          # The index of the first unset row in the table (starts with 1)
          target_row:           ~ # Required, Example: '1'
          # In case there is content "child_table" will be attached to "parent_table" at "parent_row" (optional)
          attach:
            # The name of the parent table
            parent_table:         ~ # Required, Example: parent
            # Child table name
            child_table:          ~ # Required, Example: child
            # The index of the row where the child table will be attached to
            parent_row:           ~ # Required, Example: '4'
  advanced_signature:
    # The URL to the PDF-AS server for advanced signatures
    server_url:           ~ # Required, Example: 'https://pdfas.example.com/pdf-as-web'
    profiles:
      # Prototype
      -
        # The name of the profile, this needs to be passed to the API
        name:                 ~ # Required, Example: myprofile
        # The Symfony role required to use this profile. If set, overrides the authorization config.
        role:                 ~ # Deprecated (Since dbp/relay-esign-bundle ???: The "role" option is deprecated. Use the global authorization node instead.), Example: ROLE_FOOBAR
        # The PDF-AS signature key ID used for singing
        key_id:               ~ # Required, Example: MYKEY
        # The PDF-AS signature profile ID to use
        profile_id:           ~ # Required, Example: MYPROFILE
        # For extending the PDF-AS signature layout with user provided text (optional)
        user_text:
          # The profile table ID to attach the content to.
          target_table:         ~ # Required, Example: usercontent
          # The index of the first unset row in the table (starts with 1)
          target_row:           ~ # Required, Example: '1'
          # In case there is content "child_table" will be attached to "parent_table" at "parent_row" (optional)
          attach:
            # The name of the parent table
            parent_table:         ~ # Required, Example: parent
            # Child table name
            child_table:          ~ # Required, Example: child
            # The index of the row where the child table will be attached to
            parent_row:           ~ # Required, Example: '4'
  authorization:
    policies:             []
    roles:
      # Returns true if the user is allowed to sign things in general.
      ROLE_SIGNER:          user.isAuthenticated()
      # Returns true if the user is allowed to verify signatures.
      ROLE_VERIFIER:        'false'
    resource_permissions:
      # Returns true if the user can sign with the given profile.
      ROLE_PROFILE_SIGNER:  'false'
    attributes:           []

Examples

dbp_relay_esign:
  qualified_signature:
    server_url: 'https://sig.tugraz.at/pdf-as-web'
    profiles:
      - name: default
        profile_id: 'SIGNATURBLOCK_SMALL_DE_NOTE_PDFA'
  authorization:
    roles:
      ROLE_SIGNER: 'user.isAuthenticated()'
    resource_permissions:
      ROLE_PROFILE_SIGNER: 'true'
dbp_relay_esign:
  advanced_signature:
    server_url: 'https://pdfas.tugraz.at/pdf-as-web'
    profiles:
      - name: official
        key_id: tugraz-official
        profile_id: SIGNATURBLOCK_TUGRAZ_AMTSSIGNATUR
      - name: sap
        key_id: tugraz-sap
        profile_id: SIGNATURBLOCK_TUGRAZ_SAP
  authorization:
    roles:
      ROLE_SIGNER: 'user.isAuthenticated()'
    resource_permissions:
      ROLE_PROFILE_SIGNER: >
        (resource.getName() === "official" && user.get("SCOPE_OFFICIAL-SIGNATURE")) ||
        (resource.getName() === "sap" && user.get("SCOPE_SAP-SIGNATURE"))

Authorization

The bundle authorization config consists of two roles:

  • ROLE_SIGNER - Should evaluate to true if the user is allowed to sign in general.
  • ROLE_VERIFIER - Should evaluate to true if the user is allowed to verify signatures.

In addition, there is one resource based role:

  • ROLE_PROFILE_SIGNER - Returns true if the user can sign with the given profile. The resource is a profile object which only has a getName() method returning the profile name.

For a user to be able to sign with a specific profile both the ROLE_SIGNER and ROLE_PROFILE_SIGNER roles need to evaluate to true for the selected profile.

Symfony-Role based authorization (deprecated)

Each profile in the bundle configuration can have a role key which is a Symfony role that is required to use this profile. If set, this overrides the global authorization configuration for this profile alone.

To port to the new authorization system, you need to remove the role key from the config, which makes the global authorization configuration apply to the profile. Instead of checking for a Symfony role you need to check for a user attribute.

before:

profiles:
  name: my-profile
  profile_id: 'SIGNATURBLOCK_SMALL_DE_NOTE_PDFA'
  role: ROLE_FOOBAR

after:

profiles:
  name: my-profile
  profile_id: 'SIGNATURBLOCK_SMALL_DE_NOTE_PDFA'
  authorization:
    resource_permissions:
      ROLE_PROFILE_SIGNER: >
        resource.getName() === "my-profile" && user.get("SOMETHING_THAT_IS_TRUE_IF_WE_CAN_SIGN_USING_MY_PROFILE")

User Defined Text

This allows the user of the API to append custom rows to a table in the visible signature block.

Both qualified_profile as well as every entry in advanced_profiles allows setting an optional user text configuration:

  • user_text.target_table - The profile table ID to attach the content to
  • user_text.target_row - The index of the first unset row in the table (starts with 1)
  • user_text.attach.parent_table/user_text.attach.child_table/user_text.attach.parent_row (optional) - In case there is content to add the child will be attached to parent at row row.

The extra attachment configuration is required because pdf-as-web doesn't allow reachable empty tables, so we either have to add to existing tables or attach a new table depending on wether we want to add rows or not. Example:

# We attach user text rows to "user" at row 1
# and if there are any rows we attach "user" to "info" at row 2
user_text:
  target_table: user
  target_row: 1
  attach:
    parent_table: info
    child_table: user
    parent_row: 2

To allow the esign bundle to add custom text to the signature profiles you need to whitelist these configuration objects in the pdf-as-web.properties file of pdf-as-web:

allow.ext.overwrite=true
ext.overwrite.wl.01=^sig_obj\\.SIGNATURBLOCK_TUGRAZ_AMTSSIGNATUR\\..*$
ext.overwrite.wl.02=^sig_obj\\.SIGNATURBLOCK_TUGRAZ_SAP\\..*$

Note that this allows changing everything regarding the signature profile, so make sure the SOAP API isn't publicly reachable.

PDF-AS Configuration

It's recommended to have two separate pdf-as servers for the advanced and qualified signatures because the advanced signature one can not be public while the qualified one needs to be accessible from the internet for talking with handy-signatur.at

Qualified Server

FIXME: other unrelated required options

Advanced Server

FIXME: other unrelated required options

The pdf-as-web service needs to be configured in pdf-as-web.properties to contain a keystore list containing the keys referenced in the bundle config file.

# Local key store list
ksl.tugraz-official.enabled=true
ksl.tugraz-official.file=/path/to/tomcat/conf/pdf-as/my-pdf-cert.p12
ksl.tugraz-official.type=PKCS12
ksl.tugraz-official.pass=keystore-password
ksl.tugraz-official.key.alias=mycert
ksl.tugraz-official.key.pass=cert-password

In addition, in the pdf-as configuration (config.properties) the referenced profiles need to be defined. Usually they are defined in extra files under ./profiles and then included in config.properties:

include.01 = profiles/SIGNATURBLOCK_TUGRAZ_AMTSSIGNATUR.properties
include.02 = profiles/SIGNATURBLOCK_TUGRAZ_SAP.properties

The signature property files included need to use the profile key referenced in the bundle config:

...
sig_obj.SIGNATURBLOCK_TUGRAZ_AMTSSIGNATUR = ...
...