Home Applications PKI-Script

PKI-Script

This application is not supported by InterSystems Corporation. Please be notified that you use it at your own risk.
5
1 reviews
0
Awards
749
Views
156
IPM installs
2
0
Details
Releases (3)
Reviews (1)
Issues
Articles (1)
IRIS Public Key Infrastructure helper

What's new in this version

Fix an issue with the method SignAllRequest (host filter does not work).

PKI-Script

This lib allow to perform steps related to Public Key Infrastructure described in this community article without manual intervention. Could be useful for scripting certificate generation.

Prerequisites

Make sure you have git and Docker desktop installed.

Installation

Clone/git pull the repo into any local directory

$ git clone https://github.com/lscalese/PKI-Script.git

Open the terminal in this directory and run:

$ docker-compose build
  1. Run the IRIS container with your project:
$ docker-compose up -d

How to Test it

Configure the server instance

Open IRIS terminal:

docker exec -it pki-script_iris_1 irissession iris
Set sc = ##class(lscalese.pki.Server).MinimalServerConfig("$server_password$", "US", "CASrv", 365)
Do:'sc $SYSTEM.Status.DisplayError(sc)
; Sign all requested certificate from "client" hostname for 15 minutes : 
Do ##class(lscalese.pki.Server).SignAllRequestWhile("$server_password$",900,"caclient") ; could be started with Job command instead "Do"

SignAllRequestWhile method could be used for auto accept requested certificate from an hostname for a time period (default 15 minutes).
This is an helper to avoid manual processing on the server portal when executing scripts on client instance.

Configure the client instance

Open IRIS terminal:

docker exec -it pki-script_client_1 irissession iris
Set sc = ##class(lscalese.pki.Client).MinimalClientConfig("iris:52773","Contact Name")
Do:'sc $SYSTEM.Status.DisplayError(sc)

Request and get a new certificate

Set sc = ##class(lscalese.pki.Client).RequestCertificate("$private_key$","US",,##class(lscalese.pki.Client).GenerateFilename()) ; request certificate
Do:'sc $SYSTEM.Status.DisplayError(sc)
Set sc = ##class(lscalese.pki.Client).WaitSigning(,,.number) ; Wait Authority server validation...
Do:'sc $SYSTEM.Status.DisplayError(sc)
Set sc = ##class(lscalese.pki.Client).GetRequestedCertificate(number)
Do:'sc $SYSTEM.Status.DisplayError(sc)

Helper for mirroring setup

If you use KPI-Script to generate certificate in order to setup a mirror, basically we need to perform these steps on “master” instance :

  • Configure PKI Server.
  • Configure PKI Client.
  • Request a certificate.
  • Wait validation.
  • Getting certificate.
  • Auto accept certificates requested by futur mirror instances.

These steps could be resovled with this line :

Set sc = ##class(lscalese.pki.Utils).MirrorMaster("$server_password$", "$private_key$", "Contact Person", $lb("US",,,,,$Piece($system,":",1)), 365,"caclient")

Arguments :

  1. PKI Server Password.
  2. Local certificate private key.
  3. Name of the contact person.
  4. Listbuild with certifcate attributes (position 1 is the country code and the 6th the common name)
  5. Validity in day.
  6. List of hostname (other mirror members) to auto accept requested certificates for a period of 1 hour (star “*” could be used to accept all).

On other mirror instances, we need to :

  • Configure PKI Client.
  • Request a certificate.
  • Wait validation.
  • Getting certificate.
Set sc = ##class(lscalese.pki.Utils).MirrorBackup("iris:52773", "$private_key$", "Contact Person", $lb("US",,,,,$Piece($system,":",1)) )

Arguments :

  1. PKI Server hostname:port.
  2. Local certificate private key.
  3. Name of the contact person.
  4. Listbuild with certifcate attributes (position 1 is the country code and the 6th the common name).

How to start coding

This repository is ready to code in VSCode with ObjectScript plugin.
Install VSCode, Docker and ObjectScript plugin and open the folder in VSCode.
Open /src/cls/PackageSample/ObjectScript.cls class and try to make changes - it will be compiled in running IRIS docker container.
docker_compose

Feel free to delete PackageSample folder and place your ObjectScript classes in a form
/src/Package/Classname.cls
Read more about folder setup for InterSystems ObjectScript

The script in Installer.cls will import everything you place under /src into IRIS.

What’s inside the repository

Dockerfile

The simplest dockerfile which starts IRIS and imports code from /src folder into it.
Use the related docker-compose.yml to easily setup additional parametes like port number and where you map keys and host folders.

.vscode/settings.json

Settings file to let you immedietly code in VSCode with VSCode ObjectScript plugin)

.vscode/launch.json

Config file if you want to debug with VSCode ObjectScript

Read about all the files in this artilce

Made with
Install
zpm install PKI-Script download archive
Version
1.1.115 Jan, 2022
ObjectScript quality test
Category
Solutions
Works with
InterSystems IRISInterSystems IRIS for Health
First published
19 Sep, 2021
Last checked by moderator
25 Aug, 2024Works