Order PKIo Qualified eSeal

POST https://certcentral.digicert.eu/services/v2/order/certificate/pkio_qualified_organisation_services
Use this endpoint to order a PKIo Qualified Electronic Seal certificate. This certificate is issued to a Dutch organisation for e-signing, enabling them to sign contracts, legal documents, and official communications with a qualified electronic signature.

Public Key Infrastructure for Organizations (PKIo) certificates are part of the PKIoverheid framework (a public key infrastructure managed by the Dutch government). PKIo certificates are primarily used in Netherlands and Belgium.

Example requests and responses

cURL

curl -X POST \
  'https://certcentral.digicert.eu/services/v2/order/certificate/pkio_qualified_organisation_services' \
  -H 'Content-Type: application/json' \
  -H 'X-DC-DEVKEY: {{api_key}}' \
  -d '{
    "certificate": {
		"signature_hash": "sha256",
		"profile_option": "nonrepudiation",
	},
	"csa_agreed_to": true,
	"provisioning_method": "qscd",
	"ship_info": {
		"name": "John Doe",
		"addr1": "534 Jefferson Street",
		"addr2": "Floor 94",
		"city": "New Orleans",
		"state": "la",
		"zip": "58061",
		"country": "us",
		"method": "STANDARD"
	},
	"organization": {
		"id": "2042709",
		"contacts": [
			{
				"user_id": "2812497",
				"first_name": "John",
				"last_name": "Doe",
				"job_title": "Engineer",
				"telephone": "1801-903-4284",
				"email": "john.doe@johndoe.com",
				"contact_type": "verified_contact"
			}
		]
	},
        "order_validity": {
                "years": 1
        },
	"payment_method": "balance"
}
{
  "id": 112233,
  "requests": [
    {
      "id": 113,
      "status": "pending"
    }
  ]
}
{
  "id": 112233,
  "requests": [
    {
      "id": 113,
      "status": "submitted"
    }
  ]
}
{
  "id": 112233,
  "requests": [
    {
      "id": 113,
      "status": "approved"
    }
  ],  
  "certificate_id": 113
}
{
  "id": 112233,  
  "certificate_id": 113
}

Request parameters

NameReq/OptTypeDescription
certificaterequiredobjectCertificate details.
.. signature_hashrequiredstringHash algorithm used for signing the certificate.
EU Qualified certificates support only SHA-256 hash algorithm.
.. profile_optionrequiredstringIf you are using custom certificate profiles, specify the profile name (for example, nonrepudiation).
PKIo certificates support only nonrepudiation profile option.
.. is_rsassa_pssoptionalbooleanIf true, DigiCert issues the end-entity certificate with an RSASSA-PSS signature. If false (default), DigiCert issues the end-entity certificate with an RSA signature.
Important: This parameter is only honored when the issuing ICA certificate has an RSA key. If the issuing ICA certificate has an ECC key, DigiCert issues the end-entity certificate with an ECC signature that has same key size as the issuing ICA certificate.
csa_agreed_torequiredbooleanSpecify if the Certificate Subscriber Agreement (CSA) has been agreed to. Set this parameter to true to indicate agreement and false for disagreement.
Default: true
provisioning_methodrequiredstringSpecify the key provisioning method. Key provisioning method refers to where the private key and the certificate will be stored.
Currently, only Qualified signature/seal creation device (QSCD) key provisioning method is supported. This method provides a qualified certificate that can create qualified electronic signatures or seals. If you select the qscd provisioning method in the request body, DigiCert ships the QSCD hardware token to you. You must include shipping details in the ship_info object to receive the QSCD. After receiving the device and the PIN, you must use the DigiCert Trust Assistant to initialize and install your certificate on the token. To do so, use the certificate’s order details page on the CertCentral Europe platform user interface to download and install the DigiCert Trust Assistant. You can use the DigiCert Trust Assistant to unlock and install the certificate on your QSCD token.
ship_infooptionalobjectFor orders with the provisioning_method of qscd, specify the shipping address for the hardware token.
.. namerequiredstringFirst and last name of the recipient of the order.
.. addr1requiredstringShipping address for the token.
.. addr2requiredstringContinuation of street address.
.. cityrequiredstringShipping city.
.. staterequiredstringShipping state.
.. ziprequiredstringShipping postal code.
.. countryrequiredstringShipping country.
.. methodrequiredstringShipping priority for the token.
Allowed values: STANDARD or EXPEDITED (incurs additional cost).
organizationrequiredobjectObject with information about the organization to associate with the request. You can associate the request with an existing organization, or you can create a new organization when you submit the order request.
To associate the request with an existing organization, pass the ID of the organization as the value of organization.id in the body of your request. To create a new organization, include the details of the organization in the organization object. For more information about the structure and required parameters of the organization object, see the Create organization documentation.
Note: When you submit an order with organization details instead of providing an organization ID, we check the organizations that already exist in your account to avoid creating a duplicate.
To override this behavior and force the request to create a new organization, set the organization.skip_duplicate_org_check parameter to true in the body of your request.
Important: When you want to associate an order with an existing organization, we recommend always using the ID of the organization instead of the organization’s details in the body of your request. To get the ID values for organizations in your account, use the List organizations endpoint. Additionally, we recommend deactivating unused organizations to ensure they are never accidentally assigned to a new order request. To deactivate an organization, use the Deactivate organization endpoint.
.. idrequiredintegerThe ID of an existing organization to associate with the order. To get the ID of organizations in your account, use the List organizations endpoint.
*Not required if you are creating a new organization with your request. For details on how to create a new organization, see Create organization.
.. contactsrequiredarrayList of contacts for the organization.
When creating a new organization:
Providing a verified_contact is required for EU electronic eSeal certificates. You can add multiple verified contacts, with a maximum limit of fifteen.
For EU certificates, the verified contact is your organization’s Authorized Representative. The authorized representative must be included in the company registry, must represent the organization, and has the authority to approve your EU Qualified eSeal order.
Providing an organization_contact is conditional. An organization_contact is required if the request is from a service user. If omitted, the organization is created and the authenticated user is used as the organization contact.
Providing a technical_contact is optional. If omitted, the organization is created with no technical contact.
When using an existing organization ID:
Providing an organization_contact and technical_contact is optional. If provided, the new organization and technical contact replace the existing contacts stored on the organization.
Providing a verified_contact is optional if the organization has already been submitted while ordering an equivalent certificate.
Providing a verified_contact is required if the organization has never been submitted while ordering an equivalent certificate.
Note: By default, DigiCert creates the order with the organization contact and technical contact (if one exists) assigned to the organization on the request. To create the order with a different organization or technical contact than those assigned to the organization, include the organization_contact or technical_contact object at the root of the request payload.
.. .. first_nameoptionalstringFirst name of the new contact.
Note: Required when omitting user_id. If user_id is not omitted, the specified user’s information will be updated with the new value.
.. .. last_nameoptionalstringLast name of the new contact.
Note: Required when omitting user_id. If user_id is not omitted, the specified user’s information will be updated with the new value.
.. .. emailoptionalstringEmail address of the new contact.
Note: Required when omitting user_id. If user_id is not omitted, the specified user’s information will be updated with the new value.
.. .. job_titleoptionalstringJob title of the new contact.
Note: Required when omitting user_id. If user_id is not omitted, the specified user’s information will be updated with the new value.
.. .. telephoneoptionalstringTelephone number of the new contact.
Note: Required when omitting user_id. If user_id is not omitted, the specified user’s information will be updated with the new value.
.. .. contact_typerequiredstringContact type.
Allowed values: organization_contact, technical_contact, or verified_contact.
Note: This parameter is required when creating a new authorized representative or when using an existing verified contact as an authorized representative.
.. .. user_idrequired*integerID of existing user or contact for the account.
*Can be omitted if adding a new contact.
order_validityoptionalobjectDefines the validity period of certificates issued for this order. Cannot exceed order validity period.
If not provided, or if the certificate validity date is less than 365 days from the current date, the certificate’s validity period defaults to the validity period of the order or the maximum certificate validity period defined by CA/B Forum baseline requirements, whichever is shorter.
This object is not used for requests from accounts that do not have Multi-year Plans enabled.
.. yearsoptionalintNumber of years the certificate is valid after it is issued.
Can be replaced with cert_validity.days or cert_validity.custom_expiration_date.
Allowed value: 1, 2, or 3
.. daysoptionalintNumber of days the certificate is valid after it is issued. Overrides cert_validity.years.
Max: 397
.. .. custom_expiration_dateoptionalstringA custom expiration date for the certificate. Overrides cert_validity.days and cert_validity.years.
Format: dd MMM YYYY (for example, “09 JUN 2021”)
Range: Must be within 397 days of the date you request the certificate.
payment_methodrequiredstringPayment method for the order. Allowed values:
credit_cardrequired (if payment_method is card)objectObject with information about the credit card charged for the order. Required if payment_method is card.
.. numberrequiredstringCredit card number.
.. expiration_monthrequiredstringCredit card expiration month. Format as a two-digit number between 01 (Jan) and 12 (Dec).
.. expiration_yearrequiredstringCredit card expiration year. Format as a four-digit number. For example: 2026
.. cvvrequiredstringCard verification value (CVV). Format as a three- or four-digit number. For example: 333 or 4444
.. cardholder_namerequiredstringCardholder’s first and last name.
.. save_credit_cardoptionalnullSpecify whether to save the credit card details. true for saving the details, false for not saving the details, and null for not indicating the preference.
Allowed Values: true, false, or null.
.. set_as_defaultrequiredstringSet the card as the default payment option or method. To set this card as your default payment method, use 1. To keep your default payment method, use 0.
Allowed Values: 1 or 0.
billing_addressconditionalobjectObject with information about the billing address. Required if payment_method is card.
.. addressrequiredstringBilling street address.
.. address2optionalstringContinuation of street address.
.. cityrequiredstringBilling city.
.. stateconditionalstringBilling state or province. Optional for some countries.
.. countryrequiredstringBilling country.
.. zipconditionalstringBilling zip or postal code. Optional for some countries.

Response parameters

NameTypeDescription
idintOrder ID.
organizationobjectContainer for new organization details. Only returned if a new organization was created with the order.
.. idintOrganization ID for the new organization.
requestsarrayContains information about the request.
.. idintRequest ID.
.. statusstringRequest status.
Possible values:pending, submitted, approved, rejected
certificate_idintCertificate ID. Returned if request status is approved.