Skip to main content

Python modules for easier use of Kombit's serviceplatformen.

Project description

python_serviceplatformen

This project is made to make it easier to use Kombit's Serviceplatformen API.

Certificates and authentication

To use Kombit's Serviceplatformen you need a valid OCES3 certificate registered for your project. Ask your local Kombit systems architect for help with this.

You need specific access to each service on Serviceplatformen you want to use. One certificate can have access to multiple services.

This project needs your certificate to be in a unified PEM format. That is with the public and private key in a single file.

If your certificate is in P12-format you can convert it using openssl:

openssl pkcs12 -in Certificate.p12 -out Certificate.pem -nodes

Due to limitations in Python's implementation of SSL your certificate needs to exist as a file on the system while using this library.

When your certificate is registered and in PEM-format, you simply hand it to the KombitAccess class and it will handle the rest for you.

from python_serviceplatformen.authentication import KombitAccess
kombit_access = KombitAccess(cvr="12345678", cert_path="C:\something\Certificate.pem", test=False)

If you want to use the test system instead pass test=True to KombitAccess.

Digital Post

This library supports the full functionality of Digital Post including NemSMS.

Check registration

You can easily check if someone is registered for Digital Post or NemSMS:

digital_post.is_registered(cpr="1234567890", service="digitalpost", kombit_access=kombit_access)
digital_post.is_registered(cpr="1234567890", service="nemsms", kombit_access=kombit_access)

MeMo model

A detailed data class model has been defined to help define MeMo objects which are used in the api.

The entire model is located in the message module:

from python_serviceplatformen.models.message import Message

A detailed description of the model and all attributes can be found in the official documentation: MeMo - Digitaliser.dk

Note: The model doesn't follow the normal python naming conventions to follow the source names as close as possible.

Send Digital Post

To send a message construct a message object and then send it off to the send_message function:

import uuid
from datetime import datetime
import base64

from python_serviceplatformen.authentication import KombitAccess
from python_serviceplatformen import digital_post
from python_serviceplatformen.models.message import (
    Message, MessageHeader, Sender, Recipient, MessageBody, MainDocument, File
)

kombit_access = KombitAccess(cvr="55133018", cert_path=r"C:\Users\az68933\Desktop\SF1601\Certificate.pem")

m = Message(
    messageHeader=MessageHeader(
        messageType="DIGITALPOST",
        messageUUID=str(uuid.uuid4()),
        label="Digital Post test message",
        mandatory=False,
        legalNotification=False,
        sender=Sender(
            senderID="12345678",
            idType="CVR",
            label="Python Serviceplatformen"
        ),
        recipient=Recipient(
            recipientID="1234567890",
            idType="CPR"
        )
    ),
    messageBody=MessageBody(
        createdDateTime=datetime.now(),
        mainDocument=MainDocument(
            files=[
                File(
                    encodingFormat="text/plain",
                    filename="Besked.txt",
                    language="da",
                    content=base64.b64encode(b"Hello World").decode()
                )
            ]
        )
    )
)

digital_post.send_message("Digital Post", m, kombit_access)

Recipes

The message module also contains a few static helper functions to construct simple messages. These are not meant to be all encompassing but to help as a starting point.

Tests

This project contains automated tests in the "tests" folder. To run these test you need to install the developer dependecies:

pip install python_serviceplatformen[dev]

Environment variables

Create a .env file in the project folder and fill out these variables:

KOMBIT_TEST_CVR = "XXXXXXXX"  # The cvr of the organization who owns the certificate
KOMBIT_TEST_CERT_PATH = "C:\something\Certificate.pem"  # The path to the certificate file
DIGITAL_POST_TEST_CPR = "xxxxxxxxxx"  # The receiver of the test messages

Running the tests

To run all tests open a command line in the project folder and run:

python -m unittest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python_serviceplatformen-2.1.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_serviceplatformen-2.1.0-py3-none-any.whl (12.0 kB view details)

Uploaded Python 3

File details

Details for the file python_serviceplatformen-2.1.0.tar.gz.

File metadata

  • Download URL: python_serviceplatformen-2.1.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.22

File hashes

Hashes for python_serviceplatformen-2.1.0.tar.gz
Algorithm Hash digest
SHA256 83d49b1a2caf1d08ea36dcbd341773c7c08c1bd40c466b0f6d8ef04c06a07dac
MD5 64a923710813c844d00994b092c73ec4
BLAKE2b-256 92e6aed6d56456b046eb9ce62812bd89a26be11e217ec619ab532ed8dcf26821

See more details on using hashes here.

File details

Details for the file python_serviceplatformen-2.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_serviceplatformen-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9e77e7288869614e50c93cafb84bd42f5b212cbe0cd4e74bc9552e8a3395faf5
MD5 46f2d595349de347c709c6b6c44561ff
BLAKE2b-256 98ada989036f1b90bb963cf537fca39b7ffd4b6962fd9c2e8b3a72f6cb55f9a0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page