Skip to main content

A Certomancer-based demo CSC server for integration tests

Project description

Certomancer-based dummy CSC server implementation

Overview

This package contains a minimal implementation of the Cloud Signature Consortium (CSC) API for remote signing. It's intended for use in integration tests and demonstrations. Most of the heavy lifting is actually done by Certomancer. This package merely wraps calls to Certomancer in an aiohttp-based web interface that exposes (a subset of) the CSC API.

This is a testing tool, and it omits all sorts of essential security features:

  • Requests are not authenticated
  • No SAD replay prevention of any sort, other than the standard hash pinning supported by the CSC protocol
  • All keys in the Certomancer config can be used to sign hashes in CSC calls

It goes without saying that you should never use this implementation, or any derivative thereof, with production keys.

Missing features

Besides most authentication-related endpoints, the credentials/extendTransaction endpoint is currently also unavailable. Support for this endpoint may be implemented in the future.

The other obvious missing feature is "anything resembling a decent user interface". This code was essentially isolated from pyHanko's integration tests in the hope that it might be useful for others to play around with, and the primitive CLI reflects that.

Invocation

The package is on PyPI and can be installed via pip:

pip install certomancer-csc-dummy

This is the command syntax. All parameters are required.

certomancer-csc CERTOMANCER_CONFIG PORT SCAL

The meaning of the parameters is as follows:

  • CERTOMANCER_CONFIG is the path to your Certomancer config file, usually called certomancer.yml
  • PORT is the port on which you want the dummy server to listen
  • SCAL indicates whether SAD data is required to be bound to hashes (1=no, 2=yes) — see the CSC specification for details.

The credentials exposed in the CSC API are in one-to-one correspondence with certificates in Certomancer (assuming Certomancer has access to all the private keys). The naming convention for credentials is <arch>/<cert-label>, where <arch> is the name of the Certomancer PKI architecture you're trying to access, and <cert-label> is the label of the certificate that will be treated as the signer's certificate. Example: testing-ca/signer1 would access the certificate signer1 in the architecture labelled testing-ca. Signatures will be produced by the corresponding private key.

Again, note that all credentials are always available without any form of authentication, although the caller is still required to go through the motions of requesting a SAD token before any signatures will be returned.

Note: The CSC dummy server currently does not launch Certomancer Animator or otherwise expose access to trust services managed by Certomancer. For now, you need to launch Certomancer Animator in a separate process if you need those.

(The reason is that Certomancer doesn't (yet) natively integrate with aiohttp, it currently only does WSGI. That may change in the future.)

Example usage

See here:

License

MIT license.

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

certomancer_csc_dummy-0.4.1.tar.gz (10.6 kB view details)

Uploaded Source

Built Distribution

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

certomancer_csc_dummy-0.4.1-py3-none-any.whl (11.5 kB view details)

Uploaded Python 3

File details

Details for the file certomancer_csc_dummy-0.4.1.tar.gz.

File metadata

  • Download URL: certomancer_csc_dummy-0.4.1.tar.gz
  • Upload date:
  • Size: 10.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.4

File hashes

Hashes for certomancer_csc_dummy-0.4.1.tar.gz
Algorithm Hash digest
SHA256 a6bb7adfad9f54a733e9f0f0f26ec3f636126fdd3ed39b4e97f9b0ad03d62398
MD5 ca3a24a67198d2badb9086084f6d7546
BLAKE2b-256 b675c959df9f3a8b6374836a780cef1cc3d1adb8a9b628d31ccd393a28f2a791

See more details on using hashes here.

File details

Details for the file certomancer_csc_dummy-0.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for certomancer_csc_dummy-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1aea3af43cfe05a462992896eeeafcc314a76a699a88527d93127ab2ff290359
MD5 a87e25bff741d6215d692d1987b9b717
BLAKE2b-256 00ce6c2b48b835cac3578ece16f7c7b07a6f5914c808da3211f1f28e675e5939

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