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 agetName()
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 touser_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 thechild
will be attached toparent
at rowrow
.
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 = ...
...