[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
PGG introduces the notion of a "scheme of PGP implementation" (used interchangeably with "scheme" in this document). This term refers to a singleton object wrapped with the luna object system.
Since PGG was designed for accessing and developing PGP functionality, the architecture had to be designed not just for interoperability but also for extensiblity. In this chapter we explore the architecture while finding out how to write the PGG backend.
4.1 Initializing | ||
4.2 Backend methods | ||
4.3 Getting output |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
A scheme must be initialized before it is used. It had better guarantee to keep only one instance of a scheme.
The following code is snipped out of `pgg-gpg.el'. Once an
instance of pgg-gpg
scheme is initialized, it's stored to the
variable pgg-scheme-gpg-instance
and will be reused from now on.
(defvar pgg-scheme-gpg-instance nil) (defun pgg-make-scheme-gpg () (or pgg-scheme-gpg-instance (setq pgg-scheme-gpg-instance (luna-make-entity 'pgg-scheme-gpg)))) |
The name of the function must follow the
regulation---pgg-make-scheme-
follows the backend name.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
In each backend, these methods must be present. The output of these methods is stored in special buffers (4.3 Getting output), so that these methods must tell the status of the execution.
nil
, it searches from the secret
keyrings.
nil
, do a combined sign
and encrypt. If encryption is successful, it returns t
,
otherwise nil
.
t
, otherwise nil
.
nil
, it does not
create a detached signature. If signing is successful, it returns
t
, otherwise nil
.
nil
, it is treated
as the detached signature of the current region. If the signature is
successfully verified, it returns t
, otherwise nil
.
t
, otherwise nil
.
t
, otherwise nil
.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The output of the backend methods (4.2 Backend methods) is stored in special buffers, so that these methods must tell the status of the execution.
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |