KEYRING-CERTTOSTR(2)                         KEYRING-CERTTOSTR(2)

     NAME
          keyring: certtostr, pktostr, sktostr, strtocert, strtopk,
          strtosk - encryption key conversion functions

     SYNOPSIS
          include "keyring.m"
          keyring:= load Keyring Keyring->PATH;

          strtocert: fn(s: string)         : ref Certificate;
          certtostr: fn(c: ref Certificate): string;
          strtopk:   fn(s: string)         : ref PK;
          pktostr:   fn(pk: ref PK)        : string;
          strtosk:   fn(s: string)         : ref SK;
          sktostr:   fn(sk: ref SK)        : string;

     DESCRIPTION
          Certificates, public keys, and private keys are passed over
          networks and between applications using a Unicode
          representation. This collection of functions provide a means
          to convert adts supplied by the system to and from their
          portable textual representation. These routines are
          typically used as part of an I/O package for implementing
          security.

          Strtocert takes a string argument containing a user name, a
          hash algorithm, a certifying authority and an expiration
          time. Fields are separated by a newline. The return value is
          a Certificate.  If the string is of improper format, the
          result is nil.

          Certtostr performs the inverse operation: takes the
          Certificate c and produces a text string suitable for commu-
          nication over a network.

          Strtopk and strtosk take as their arguments a string s rep-
          resenting the public and private keys respectively.  S must
          contain an algorithm name, a user name and the key. Fields
          are separated by a newline.  Strtopk returns a reference to
          the resulting PK; strtosk returns a reference to the result-
          ing SK.  If the format of s is invalid, the result is nil.

          Pktostr and sktostr perform the inverse operations: they
          take a public key (secret key) and produce a printable rep-
          resentation as a string.

     SOURCE
          /libinterp/keyring.c

     Page 1                       Plan 9            (printed 11/23/24)