summaryrefslogtreecommitdiffstats
path: root/doc/gnutls-guile.info
diff options
context:
space:
mode:
Diffstat (limited to 'doc/gnutls-guile.info')
-rw-r--r--doc/gnutls-guile.info1659
1 files changed, 1659 insertions, 0 deletions
diff --git a/doc/gnutls-guile.info b/doc/gnutls-guile.info
new file mode 100644
index 0000000..9347284
--- /dev/null
+++ b/doc/gnutls-guile.info
@@ -0,0 +1,1659 @@
+This is gnutls-guile.info, produced by makeinfo version 6.8 from
+gnutls-guile.texi.
+
+This manual is last updated 9 February 2023 for version 3.7.9 of GnuTLS.
+
+Copyright (C) 2001-2012, 2014, 2016, 2019, 2022 Free Software
+Foundation, Inc.
+
+ Permission is granted to copy, distribute and/or modify this
+ document under the terms of the GNU Free Documentation License,
+ Version 1.3 or any later version published by the Free Software
+ Foundation; with no Invariant Sections, no Front-Cover Texts, and
+ no Back-Cover Texts. A copy of the license is included in the
+ section entitled "GNU Free Documentation License".
+INFO-DIR-SECTION Software libraries
+START-INFO-DIR-ENTRY
+* GnuTLS-Guile: (gnutls-guile). GNU Transport Layer Security Library. Guile bindings.
+END-INFO-DIR-ENTRY
+
+
+File: gnutls-guile.info, Node: Top, Next: Preface, Up: (dir)
+
+GnuTLS-Guile
+************
+
+This manual is last updated 9 February 2023 for version 3.7.9 of GnuTLS.
+
+Copyright (C) 2001-2012, 2014, 2016, 2019, 2022 Free Software
+Foundation, Inc.
+
+ Permission is granted to copy, distribute and/or modify this
+ document under the terms of the GNU Free Documentation License,
+ Version 1.3 or any later version published by the Free Software
+ Foundation; with no Invariant Sections, no Front-Cover Texts, and
+ no Back-Cover Texts. A copy of the license is included in the
+ section entitled "GNU Free Documentation License".
+
+* Menu:
+
+* Preface:: Preface.
+* Guile Preparations:: Note on installation and environment.
+* Guile API Conventions:: Naming conventions and other idiosyncrasies.
+* Guile Examples:: Quick start.
+* Guile Reference:: The Scheme GnuTLS programming interface.
+
+* Copying Information:: You can copy and modify this manual.
+* Procedure Index::
+* Concept Index::
+
+
+File: gnutls-guile.info, Node: Preface, Next: Guile Preparations, Prev: Top, Up: Top
+
+1 Preface
+*********
+
+This manual describes the GNU Guile
+(https://www.gnu.org/software/guile/) Scheme programming interface to
+GnuTLS, which is distributed as part of GnuTLS (https://gnutls.org).
+The reader is assumed to have basic knowledge of the protocol and
+library. Details missing from this chapter may be found in Function
+reference, of the C API reference.
+
+At this stage, not all the C functions are available from Scheme, but a
+large subset thereof is available.
+
+
+File: gnutls-guile.info, Node: Guile Preparations, Next: Guile API Conventions, Prev: Preface, Up: Top
+
+2 Guile Preparations
+********************
+
+The GnuTLS Guile bindings are available for the Guile 3.0 and 2.2
+series, as well as the legacy 2.0 series.
+
+By default they are installed under the GnuTLS installation directory,
+typically '/usr/local/share/guile/site/'). Normally Guile will not find
+the module there without help. You may experience something like this:
+
+ $ guile
+ ...
+ scheme@(guile-user)> (use-modules (gnutls))
+ ERROR: no code for module (gnutls)
+
+There are two ways to solve this. The first is to make sure that when
+building GnuTLS, the Guile bindings will be installed in the same place
+where Guile looks. You may do this by using the '--with-guile-site-dir'
+parameter as follows:
+
+ $ ./configure --with-guile-site-dir=no
+
+This will instruct GnuTLS to attempt to install the Guile bindings where
+Guile will look for them. It will use 'guile-config info pkgdatadir' to
+learn the path to use.
+
+If Guile was installed into '/usr', you may also install GnuTLS using
+the same prefix:
+
+ $ ./configure --prefix=/usr
+
+If you want to specify the path to install the Guile bindings you can
+also specify the path directly:
+
+ $ ./configure --with-guile-site-dir=/opt/guile/share/guile/site
+
+The second solution requires some more work but may be easier to use if
+you do not have system administrator rights to your machine. You need
+to instruct Guile so that it finds the GnuTLS Guile bindings. Either
+use the 'GUILE_LOAD_PATH' environment variable as follows:
+
+ $ GUILE_LOAD_PATH="/usr/local/share/guile/site:$GUILE_LOAD_PATH" guile
+ scheme@(guile-user)> (use-modules (gnutls))
+ scheme@(guile-user)>
+
+Alternatively, you can modify Guile's '%load-path' variable (*note
+Guile's run-time options: (guile)Build Config.).
+
+At this point, you might get an error regarding 'guile-gnutls-v-2'
+similar to:
+
+ gnutls.scm:361:1: In procedure dynamic-link in expression (load-extension "guile-gnutls-v-2" "scm_init_gnutls"):
+ gnutls.scm:361:1: file: "guile-gnutls-v-2", message: "guile-gnutls-v-2.so: cannot open shared object file: No such file or directory"
+
+In this case, you will need to modify the run-time linker path, for
+example as follows:
+
+ $ LD_LIBRARY_PATH=/usr/local/lib GUILE_LOAD_PATH=/usr/local/share/guile/site guile
+ scheme@(guile-user)> (use-modules (gnutls))
+ scheme@(guile-user)>
+
+To check that you got the intended GnuTLS library version, you may print
+the version number of the loaded library as follows:
+
+ $ guile
+ scheme@(guile-user)> (use-modules (gnutls))
+ scheme@(guile-user)> (gnutls-version)
+ "3.7.9"
+ scheme@(guile-user)>
+
+
+File: gnutls-guile.info, Node: Guile API Conventions, Next: Guile Examples, Prev: Guile Preparations, Up: Top
+
+3 Guile API Conventions
+***********************
+
+This chapter details the conventions used by Guile API, as well as
+specificities of the mapping of the C API to Scheme.
+
+* Menu:
+
+* Enumerates and Constants:: Representation of C-side constants.
+* Procedure Names:: Naming conventions.
+* Representation of Binary Data:: Binary data buffers.
+* Input and Output:: Input and output.
+* Exception Handling:: Exceptions.
+
+
+File: gnutls-guile.info, Node: Enumerates and Constants, Next: Procedure Names, Up: Guile API Conventions
+
+3.1 Enumerates and Constants
+============================
+
+Lots of enumerates and constants are used in the GnuTLS C API. For each
+C enumerate type, a disjoint Scheme type is used--thus, enumerate values
+and constants are not represented by Scheme symbols nor by integers.
+This makes it impossible to use an enumerate value of the wrong type on
+the Scheme side: such errors are automatically detected by
+type-checking.
+
+The enumerate values are bound to variables exported by the '(gnutls)'
+module. These variables are named according to the following
+convention:
+
+ * All variable names are lower-case; the underscore '_' character
+ used in the C API is replaced by hyphen '-'.
+ * All variable names are prepended by the name of the enumerate type
+ and the slash '/' character.
+ * In some cases, the variable name is made more explicit than the one
+ of the C API, e.g., by avoid abbreviations.
+
+Consider for instance this C-side enumerate:
+
+ typedef enum
+ {
+ GNUTLS_CRD_CERTIFICATE = 1,
+ GNUTLS_CRD_ANON,
+ GNUTLS_CRD_SRP,
+ GNUTLS_CRD_PSK
+ } gnutls_credentials_type_t;
+
+The corresponding Scheme values are bound to the following variables
+exported by the '(gnutls)' module:
+
+ credentials/certificate
+ credentials/anonymous
+ credentials/srp
+ credentials/psk
+
+Hopefully, most variable names can be deduced from this convention.
+
+Scheme-side "enumerate" values can be compared using 'eq?' (*note
+equality predicates: (guile)Equality.). Consider the following example:
+
+ (let ((session (make-session connection-end/client)))
+
+ ;;
+ ;; ...
+ ;;
+
+ ;; Check the ciphering algorithm currently used by SESSION.
+ (if (eq? cipher/arcfour (session-cipher session))
+ (format #t "We're using the ARCFOUR algorithm")))
+
+In addition, all enumerate values can be converted to a human-readable
+string, in a type-specific way. For instance, '(cipher->string
+cipher/arcfour)' yields '"ARCFOUR 128"', while '(key-usage->string
+key-usage/digital-signature)' yields '"digital-signature"'. Note that
+these strings may not be sufficient for use in a user interface since
+they are fairly concise and not internationalized.
+
+
+File: gnutls-guile.info, Node: Procedure Names, Next: Representation of Binary Data, Prev: Enumerates and Constants, Up: Guile API Conventions
+
+3.2 Procedure Names
+===================
+
+Unlike C functions in GnuTLS, the corresponding Scheme procedures are
+named in a way that is close to natural English. Abbreviations are also
+avoided. For instance, the Scheme procedure corresponding to
+'gnutls_certificate_set_dh_params' is named
+'set-certificate-credentials-dh-parameters!'. The 'gnutls_' prefix is
+always omitted from variable names since a similar effect can be
+achieved using Guile's nifty binding renaming facilities, should it be
+needed (*note (guile)Using Guile Modules::).
+
+Often Scheme procedure names differ from C function names in a way that
+makes it clearer what objects they operate on. For example, the Scheme
+procedure named 'set-session-transport-port!' corresponds to
+'gnutls_transport_set_ptr', making it clear that this procedure applies
+to session.
+
+
+File: gnutls-guile.info, Node: Representation of Binary Data, Next: Input and Output, Prev: Procedure Names, Up: Guile API Conventions
+
+3.3 Representation of Binary Data
+=================================
+
+Many procedures operate on binary data. For instance,
+'pkcs3-import-dh-parameters' expects binary data as input.
+
+Binary data is represented on the Scheme side using bytevectors (*note
+(guile)Bytevectors::). Homogeneous vectors such as SRFI-4 'u8vector's
+can also be used(1).
+
+As an example, generating and then exporting Diffie-Hellman parameters
+in the PEM format can be done as follows:
+
+ (let* ((dh (make-dh-parameters 1024))
+ (pem (pkcs3-export-dh-parameters dh
+ x509-certificate-format/pem)))
+ (call-with-output-file "some-file.pem"
+ (lambda (port)
+ (uniform-vector-write pem port))))
+
+ ---------- Footnotes ----------
+
+ (1) Historically, SRFI-4 'u8vector's are the closest thing to
+bytevectors that Guile 1.8 and earlier supported.
+
+
+File: gnutls-guile.info, Node: Input and Output, Next: Exception Handling, Prev: Representation of Binary Data, Up: Guile API Conventions
+
+3.4 Input and Output
+====================
+
+The underlying transport of a TLS session can be any Scheme input/output
+port (*note (guile)Ports and File Descriptors::). This has to be
+specified using 'set-session-transport-port!'.
+
+However, for better performance, a raw file descriptor can be specified,
+using 'set-session-transport-fd!'. For instance, if the transport layer
+is a socket port over an OS-provided socket, you can use the
+'port->fdes' or 'fileno' procedure to obtain the underlying file
+descriptor and pass it to 'set-session-transport-fd!' (*note
+'port->fdes' and 'fileno': (guile)Ports and File Descriptors.). This
+would work as follows:
+
+ (let ((socket (socket PF_INET SOCK_STREAM 0))
+ (session (make-session connection-end/client)))
+
+ ;;
+ ;; Establish a TCP connection...
+ ;;
+
+ ;; Use the file descriptor that underlies SOCKET.
+ (set-session-transport-fd! session (fileno socket)))
+
+Once a TLS session is established, data can be communicated through it
+(i.e., _via_ the TLS record layer) using the port returned by
+'session-record-port':
+
+ (let ((session (make-session connection-end/client)))
+
+ ;;
+ ;; Initialize the various parameters of SESSION, set up
+ ;; a network connection, etc.
+ ;;
+
+ (let ((i/o (session-record-port session)))
+ (display "Hello peer!" i/o)
+ (let ((greetings (read i/o)))
+
+ ;; ...
+
+ (bye session close-request/rdwr))))
+
+Note that each write to the session record port leads to the
+transmission of an encrypted TLS "Application Data" packet. In the
+above example, we create an Application Data packet for the 11 bytes for
+the string that we write. This is not efficient both in terms of CPU
+usage and bandwidth (each packet adds at least 5 bytes of overhead and
+can lead to one 'write' system call), so we recommend that applications
+do their own buffering.
+
+A lower-level I/O API is provided by 'record-send' and 'record-receive!'
+which take a bytevector (or a SRFI-4 vector) to represent the data sent
+or received. While it might improve performance, it is much less
+convenient than the session record port and should rarely be needed.
+
+
+File: gnutls-guile.info, Node: Exception Handling, Prev: Input and Output, Up: Guile API Conventions
+
+3.5 Exception Handling
+======================
+
+GnuTLS errors are implemented as Scheme exceptions (*note exceptions in
+Guile: (guile)Exceptions.). Each time a GnuTLS function returns an
+error, an exception with key 'gnutls-error' is raised. The additional
+arguments that are thrown include an error code and the name of the
+GnuTLS procedure that raised the exception. The error code is pretty
+much like an enumerate value: it is one of the 'error/' variables
+exported by the '(gnutls)' module (*note Enumerates and Constants::).
+Exceptions can be turned into error messages using the 'error->string'
+procedure.
+
+The following examples illustrates how GnuTLS exceptions can be handled:
+
+ (let ((session (make-session connection-end/server)))
+
+ ;;
+ ;; ...
+ ;;
+
+ (catch 'gnutls-error
+ (lambda ()
+ (handshake session))
+ (lambda (key err function . currently-unused)
+ (format (current-error-port)
+ "a GnuTLS error was raised by `~a': ~a~%"
+ function (error->string err)))))
+
+Again, error values can be compared using 'eq?':
+
+ ;; `gnutls-error' handler.
+ (lambda (key err function . currently-unused)
+ (if (eq? err error/fatal-alert-received)
+ (format (current-error-port)
+ "a fatal alert was caught!~%")
+ (format (current-error-port)
+ "something bad happened: ~a~%"
+ (error->string err))))
+
+Note that the 'catch' handler is currently passed only 3 arguments but
+future versions might provide it with additional arguments. Thus, it
+must be prepared to handle more than 3 arguments, as in this example.
+
+
+File: gnutls-guile.info, Node: Guile Examples, Next: Guile Reference, Prev: Guile API Conventions, Up: Top
+
+4 Guile Examples
+****************
+
+This chapter provides examples that illustrate common use cases.
+
+* Menu:
+
+* Anonymous Authentication Guile Example:: Simplest client and server.
+
+
+File: gnutls-guile.info, Node: Anonymous Authentication Guile Example, Up: Guile Examples
+
+4.1 Anonymous Authentication Guile Example
+==========================================
+
+"Anonymous authentication" is very easy to use. No certificates are
+needed by the communicating parties. Yet, it allows them to benefit
+from end-to-end encryption and integrity checks.
+
+The client-side code would look like this (assuming SOME-SOCKET is bound
+to an open socket port):
+
+ ;; Client-side.
+
+ (let ((client (make-session connection-end/client)))
+ ;; Use the default settings.
+ (set-session-default-priority! client)
+
+ ;; Don't use certificate-based authentication.
+ (set-session-certificate-type-priority! client '())
+
+ ;; Request the "anonymous Diffie-Hellman" key exchange method.
+ (set-session-kx-priority! client (list kx/anon-dh))
+
+ ;; Specify the underlying socket.
+ (set-session-transport-fd! client (fileno some-socket))
+
+ ;; Create anonymous credentials.
+ (set-session-credentials! client
+ (make-anonymous-client-credentials))
+
+ ;; Perform the TLS handshake with the server.
+ (handshake client)
+
+ ;; Send data over the TLS record layer.
+ (write "hello, world!" (session-record-port client))
+
+ ;; Terminate the TLS session.
+ (bye client close-request/rdwr))
+
+The corresponding server would look like this (again, assuming
+SOME-SOCKET is bound to a socket port):
+
+ ;; Server-side.
+
+ (let ((server (make-session connection-end/server)))
+ (set-session-default-priority! server)
+ (set-session-certificate-type-priority! server '())
+ (set-session-kx-priority! server (list kx/anon-dh))
+
+ ;; Specify the underlying transport socket.
+ (set-session-transport-fd! server (fileno some-socket))
+
+ ;; Create anonymous credentials.
+ (let ((cred (make-anonymous-server-credentials))
+ (dh-params (make-dh-parameters 1024)))
+ ;; Note: DH parameter generation can take some time.
+ (set-anonymous-server-dh-parameters! cred dh-params)
+ (set-session-credentials! server cred))
+
+ ;; Perform the TLS handshake with the client.
+ (handshake server)
+
+ ;; Receive data over the TLS record layer.
+ (let ((message (read (session-record-port server))))
+ (format #t "received the following message: ~a~%"
+ message)
+
+ (bye server close-request/rdwr)))
+
+This is it!
+
+
+File: gnutls-guile.info, Node: Guile Reference, Next: Copying Information, Prev: Guile Examples, Up: Top
+
+5 Guile Reference
+*****************
+
+This chapter lists the GnuTLS Scheme procedures exported by the
+'(gnutls)' module (*note (guile)The Guile module system::).
+
+ -- Scheme Procedure: set-log-level! level
+ Enable GnuTLS logging up to LEVEL (an integer).
+
+ -- Scheme Procedure: set-log-procedure! proc
+ Use PROC (a two-argument procedure) as the global GnuTLS log
+ procedure.
+
+ -- Scheme Procedure: %set-certificate-credentials-openpgp-keys! cred
+ pub sec
+ Use certificate PUB and secret key SEC in certificate credentials
+ CRED.
+
+ -- Scheme Procedure: %openpgp-keyring-contains-key-id? keyring id
+ Return '#f' if key ID ID is in KEYRING, '#f' otherwise.
+
+ -- Scheme Procedure: import-openpgp-keyring data format
+ Import DATA (a u8vector) according to FORMAT and return the
+ imported keyring.
+
+ -- Scheme Procedure: %openpgp-certificate-usage key
+ Return a list of values denoting the key usage of KEY.
+
+ -- Scheme Procedure: %openpgp-certificate-version key
+ Return the version of the OpenPGP message format (RFC2440) honored
+ by KEY.
+
+ -- Scheme Procedure: %openpgp-certificate-algorithm key
+ Return two values: the certificate algorithm used by KEY and the
+ number of bits used.
+
+ -- Scheme Procedure: %openpgp-certificate-names key
+ Return the list of names for KEY.
+
+ -- Scheme Procedure: %openpgp-certificate-name key index
+ Return the INDEXth name of KEY.
+
+ -- Scheme Procedure: %openpgp-certificate-fingerprint key
+ Return a new u8vector denoting the fingerprint of KEY.
+
+ -- Scheme Procedure: %openpgp-certificate-fingerprint! key fpr
+ Store in FPR (a u8vector) the fingerprint of KEY. Return the
+ number of bytes stored in FPR.
+
+ -- Scheme Procedure: %openpgp-certificate-id! key id
+ Store the ID (an 8 byte sequence) of certificate KEY in ID (a
+ u8vector).
+
+ -- Scheme Procedure: %openpgp-certificate-id key
+ Return the ID (an 8-element u8vector) of certificate KEY.
+
+ -- Scheme Procedure: %import-openpgp-private-key data format [pass]
+ Return a new OpenPGP private key object resulting from the import
+ of DATA (a uniform array) according to FORMAT. Optionally, a
+ passphrase may be provided.
+
+ -- Scheme Procedure: %import-openpgp-certificate data format
+ Return a new OpenPGP certificate object resulting from the import
+ of DATA (a uniform array) according to FORMAT.
+
+ -- Scheme Procedure: x509-certificate-fingerprint cert algo
+ Return the fingerprint (a u8vector) of the certificate CERT,
+ computed using the digest algorithm ALGO.
+
+ -- Scheme Procedure: x509-certificate-subject-alternative-name cert
+ index
+ Return two values: the alternative name type for CERT (i.e., one of
+ the 'x509-subject-alternative-name/' values) and the actual subject
+ alternative name (a string) at INDEX. Both values are '#f' if no
+ alternative name is available at INDEX.
+
+ -- Scheme Procedure: x509-certificate-subject-key-id cert
+ Return the subject key ID (a u8vector) for CERT.
+
+ -- Scheme Procedure: x509-certificate-authority-key-id cert
+ Return the key ID (a u8vector) of the X.509 certificate authority
+ of CERT.
+
+ -- Scheme Procedure: x509-certificate-key-id cert
+ Return a statistically unique ID (a u8vector) for CERT that depends
+ on its public key parameters. This is normally a 20-byte SHA-1
+ hash.
+
+ -- Scheme Procedure: x509-certificate-version cert
+ Return the version of CERT.
+
+ -- Scheme Procedure: x509-certificate-key-usage cert
+ Return the key usage of CERT (i.e., a list of 'key-usage/' values),
+ or the empty list if CERT does not contain such information.
+
+ -- Scheme Procedure: x509-certificate-public-key-algorithm cert
+ Return two values: the public key algorithm (i.e., one of the
+ 'pk-algorithm/' values) of CERT and the number of bits used.
+
+ -- Scheme Procedure: x509-certificate-signature-algorithm cert
+ Return the signature algorithm used by CERT (i.e., one of the
+ 'sign-algorithm/' values).
+
+ -- Scheme Procedure: x509-certificate-matches-hostname? cert hostname
+ Return true if CERT matches HOSTNAME, a string denoting a DNS host
+ name. This is the basic implementation of RFC 2818
+ (https://tools.ietf.org/html/rfc2818) (aka. HTTPS).
+
+ -- Scheme Procedure: x509-certificate-issuer-dn-oid cert index
+ Return the OID (a string) at INDEX from CERT's issuer DN. Return
+ '#f' if no OID is available at INDEX.
+
+ -- Scheme Procedure: x509-certificate-dn-oid cert index
+ Return OID (a string) at INDEX from CERT. Return '#f' if no OID is
+ available at INDEX.
+
+ -- Scheme Procedure: x509-certificate-issuer-dn cert
+ Return the distinguished name (DN) of X.509 certificate CERT.
+
+ -- Scheme Procedure: x509-certificate-dn cert
+ Return the distinguished name (DN) of X.509 certificate CERT. The
+ form of the DN is as described in RFC 2253
+ (https://tools.ietf.org/html/rfc2253).
+
+ -- Scheme Procedure: pkcs8-import-x509-private-key data format [pass
+ [encrypted]]
+ Return a new X.509 private key object resulting from the import of
+ DATA (a uniform array) according to FORMAT. Optionally, if PASS is
+ not '#f', it should be a string denoting a passphrase. ENCRYPTED
+ tells whether the private key is encrypted ('#t' by default).
+
+ -- Scheme Procedure: import-x509-private-key data format
+ Return a new X.509 private key object resulting from the import of
+ DATA (a uniform array) according to FORMAT.
+
+ -- Scheme Procedure: import-x509-certificate data format
+ Return a new X.509 certificate object resulting from the import of
+ DATA (a uniform array) according to FORMAT.
+
+ -- Scheme Procedure: server-session-psk-username session
+ Return the username associated with PSK server session SESSION.
+
+ -- Scheme Procedure: set-psk-client-credentials! cred username key
+ key-format
+ Set the client credentials for CRED, a PSK client credentials
+ object.
+
+ -- Scheme Procedure: make-psk-client-credentials
+ Return a new PSK client credentials object.
+
+ -- Scheme Procedure: set-psk-server-credentials-file! cred file
+ Use FILE as the password file for PSK server credentials CRED.
+
+ -- Scheme Procedure: make-psk-server-credentials
+ Return new PSK server credentials.
+
+ -- Scheme Procedure: peer-certificate-status session
+ Verify the peer certificate for SESSION and return a list of
+ 'certificate-status' values (such as 'certificate-status/revoked'),
+ or the empty list if the certificate is valid.
+
+ -- Scheme Procedure: set-certificate-credentials-verify-flags! cred
+ [flags...]
+ Set the certificate verification flags to FLAGS, a series of
+ 'certificate-verify' values.
+
+ -- Scheme Procedure: set-certificate-credentials-verify-limits! cred
+ max-bits max-depth
+ Set the verification limits of 'peer-certificate-status' for
+ certificate credentials CRED to MAX_BITS bits for an acceptable
+ certificate and MAX_DEPTH as the maximum depth of a certificate
+ chain.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-keys! cred certs
+ privkey
+ Have certificate credentials CRED use the X.509 certificates listed
+ in CERTS and X.509 private key PRIVKEY.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-key-data! cred
+ cert key format
+ Use X.509 certificate CERT and private key KEY, both uniform arrays
+ containing the X.509 certificate and key in format FORMAT, for
+ certificate credentials CRED.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-crl-data! cred
+ data format
+ Use DATA (a uniform array) as the X.509 CRL (certificate revocation
+ list) database for CRED. On success, return the number of CRLs
+ processed.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-trust-data! cred
+ data format
+ Use DATA (a uniform array) as the X.509 trust database for CRED.
+ On success, return the number of certificates processed.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-crl-file! cred
+ file format
+ Use FILE as the X.509 CRL (certificate revocation list) file for
+ certificate credentials CRED. On success, return the number of
+ CRLs processed.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-trust-file! cred
+ file format
+ Use FILE as the X.509 trust file for certificate credentials CRED.
+ On success, return the number of certificates processed.
+
+ -- Scheme Procedure: set-certificate-credentials-x509-key-files! cred
+ cert-file key-file format
+ Use FILE as the password file for PSK server credentials CRED.
+
+ -- Scheme Procedure: set-certificate-credentials-dh-parameters! cred
+ dh-params
+ Use Diffie-Hellman parameters DH_PARAMS for certificate credentials
+ CRED.
+
+ -- Scheme Procedure: make-certificate-credentials
+ Return new certificate credentials (i.e., for use with either X.509
+ or OpenPGP certificates.
+
+ -- Scheme Procedure: set-anonymous-server-dh-parameters! cred dh-params
+ Set the Diffie-Hellman parameters of anonymous server credentials
+ CRED.
+
+ -- Scheme Procedure: make-anonymous-client-credentials
+ Return anonymous client credentials.
+
+ -- Scheme Procedure: make-anonymous-server-credentials
+ Return anonymous server credentials.
+
+ -- Scheme Procedure: set-session-dh-prime-bits! session bits
+ Use BITS DH prime bits for SESSION.
+
+ -- Scheme Procedure: pkcs3-export-dh-parameters dh-params format
+ Export Diffie-Hellman parameters DH_PARAMS in PKCS3 format
+ according for FORMAT (an 'x509-certificate-format' value). Return
+ a 'u8vector' containing the result.
+
+ -- Scheme Procedure: pkcs3-import-dh-parameters array format
+ Import Diffie-Hellman parameters in PKCS3 format (further specified
+ by FORMAT, an 'x509-certificate-format' value) from ARRAY (a
+ homogeneous array) and return a new 'dh-params' object.
+
+ -- Scheme Procedure: make-dh-parameters bits
+ Return new Diffie-Hellman parameters.
+
+ -- Scheme Procedure: set-session-transport-port! session port
+ Use PORT as the input/output port for SESSION.
+
+ -- Scheme Procedure: set-session-transport-fd! session fd
+ Use file descriptor FD as the underlying transport for SESSION.
+
+ -- Scheme Procedure: set-session-record-port-close! port close
+ Set CLOSE, a one-argument procedure, as the procedure called when
+ PORT is closed. CLOSE will be passed PORT. It may be called when
+ 'close-port' is called on PORT, or when PORT is garbage-collected.
+ It is a useful way to free resources associated with PORT such as
+ the session's transport file descriptor or port.
+
+ -- Scheme Procedure: session-record-port session [close]
+ Return a read-write port that may be used to communicate over
+ SESSION. All invocations of 'session-port' on a given session
+ return the same object (in the sense of 'eq?').
+
+ If CLOSE is provided, it must be a one-argument procedure, and it
+ will be called when the returned port is closed. This is
+ equivalent to setting it by calling
+ 'set-session-record-port-close!'.
+
+ -- Scheme Procedure: record-receive! session array
+ Receive data from SESSION into ARRAY, a uniform homogeneous array.
+ Return the number of bytes actually received.
+
+ -- Scheme Procedure: record-send session array
+ Send the record constituted by ARRAY through SESSION.
+
+ -- Scheme Procedure: set-session-server-name! session type name
+ For a client, this procedure provides a way to inform the server
+ that it is known under NAME, via the 'SERVER NAME' TLS extension.
+ TYPE must be a 'server-name-type' value, SERVER-NAME-TYPE/DNS for
+ DNS names.
+
+ -- Scheme Procedure: set-session-credentials! session cred
+ Use CRED as SESSION's credentials.
+
+ -- Scheme Procedure: cipher-suite->string kx cipher mac
+ Return the name of the given cipher suite.
+
+ -- Scheme Procedure: set-session-priorities! session priorities
+ Have SESSION use the given PRIORITIES for the ciphers, key exchange
+ methods, MACs and compression methods. PRIORITIES must be a string
+ (*note (gnutls)Priority Strings::). When PRIORITIES cannot be
+ parsed, an 'error/invalid-request' error is raised, with an extra
+ argument indication the position of the error.
+
+ -- Scheme Procedure: set-session-default-priority! session
+ Have SESSION use the default priorities.
+
+ -- Scheme Procedure: set-server-session-certificate-request! session
+ request
+ Tell how SESSION, a server-side session, should deal with
+ certificate requests. REQUEST should be either
+ 'certificate-request/request' or 'certificate-request/require'.
+
+ -- Scheme Procedure: session-our-certificate-chain session
+ Return our certificate chain for SESSION (as sent to the peer) in
+ raw format (a u8vector). In the case of OpenPGP there is exactly
+ one certificate. Return the empty list if no certificate was used.
+
+ -- Scheme Procedure: session-peer-certificate-chain session
+ Return the a list of certificates in raw format (u8vectors) where
+ the first one is the peer's certificate. In the case of OpenPGP,
+ there is always exactly one certificate. In the case of X.509,
+ subsequent certificates indicate form a certificate chain. Return
+ the empty list if no certificate was sent.
+
+ -- Scheme Procedure: session-client-authentication-type session
+ Return the client authentication type (a 'credential-type' value)
+ used in SESSION.
+
+ -- Scheme Procedure: session-server-authentication-type session
+ Return the server authentication type (a 'credential-type' value)
+ used in SESSION.
+
+ -- Scheme Procedure: session-authentication-type session
+ Return the authentication type (a 'credential-type' value) used by
+ SESSION.
+
+ -- Scheme Procedure: session-protocol session
+ Return the protocol used by SESSION.
+
+ -- Scheme Procedure: session-certificate-type session
+ Return SESSION's certificate type.
+
+ -- Scheme Procedure: session-compression-method session
+ Return SESSION's compression method.
+
+ -- Scheme Procedure: session-mac session
+ Return SESSION's MAC.
+
+ -- Scheme Procedure: session-kx session
+ Return SESSION's kx.
+
+ -- Scheme Procedure: session-cipher session
+ Return SESSION's cipher.
+
+ -- Scheme Procedure: alert-send session level alert
+ Send ALERT via SESSION.
+
+ -- Scheme Procedure: alert-get session
+ Get an aleter from SESSION.
+
+ -- Scheme Procedure: reauthenticate session
+ Perform a re-authentication step for SESSION.
+
+ -- Scheme Procedure: rehandshake session
+ Perform a re-handshaking for SESSION.
+
+ -- Scheme Procedure: handshake session
+ Perform a handshake for SESSION.
+
+ -- Scheme Procedure: bye session how
+ Close SESSION according to HOW.
+
+ -- Scheme Procedure: make-session end [flags...]
+ Return a new session for connection end END, either
+ 'connection-end/server' or 'connection-end/client'. The optional
+ FLAGS arguments are 'connection-flag' values such as
+ 'connection-flag/auto-reauth'.
+
+ -- Scheme Procedure: gnutls-version
+ Return a string denoting the version number of the underlying
+ GnuTLS library, e.g., '"1.7.2"'.
+
+ -- Scheme Procedure: openpgp-keyring? obj
+ Return true if OBJ is of type 'openpgp-keyring'.
+
+ -- Scheme Procedure: openpgp-private-key? obj
+ Return true if OBJ is of type 'openpgp-private-key'.
+
+ -- Scheme Procedure: openpgp-certificate? obj
+ Return true if OBJ is of type 'openpgp-certificate'.
+
+ -- Scheme Procedure: x509-private-key? obj
+ Return true if OBJ is of type 'x509-private-key'.
+
+ -- Scheme Procedure: x509-certificate? obj
+ Return true if OBJ is of type 'x509-certificate'.
+
+ -- Scheme Procedure: psk-client-credentials? obj
+ Return true if OBJ is of type 'psk-client-credentials'.
+
+ -- Scheme Procedure: psk-server-credentials? obj
+ Return true if OBJ is of type 'psk-server-credentials'.
+
+ -- Scheme Procedure: srp-client-credentials? obj
+ Return true if OBJ is of type 'srp-client-credentials'.
+
+ -- Scheme Procedure: srp-server-credentials? obj
+ Return true if OBJ is of type 'srp-server-credentials'.
+
+ -- Scheme Procedure: certificate-credentials? obj
+ Return true if OBJ is of type 'certificate-credentials'.
+
+ -- Scheme Procedure: dh-parameters? obj
+ Return true if OBJ is of type 'dh-parameters'.
+
+ -- Scheme Procedure: anonymous-server-credentials? obj
+ Return true if OBJ is of type 'anonymous-server-credentials'.
+
+ -- Scheme Procedure: anonymous-client-credentials? obj
+ Return true if OBJ is of type 'anonymous-client-credentials'.
+
+ -- Scheme Procedure: session? obj
+ Return true if OBJ is of type 'session'.
+
+ -- Scheme Procedure: openpgp-certificate-format->string enumval
+ Return a string describing ENUMVAL, a 'openpgp-certificate-format'
+ value.
+
+ -- Scheme Procedure: error->string enumval
+ Return a string describing ENUMVAL, a 'error' value.
+
+ -- Scheme Procedure: certificate-verify->string enumval
+ Return a string describing ENUMVAL, a 'certificate-verify' value.
+
+ -- Scheme Procedure: key-usage->string enumval
+ Return a string describing ENUMVAL, a 'key-usage' value.
+
+ -- Scheme Procedure: psk-key-format->string enumval
+ Return a string describing ENUMVAL, a 'psk-key-format' value.
+
+ -- Scheme Procedure: server-name-type->string enumval
+ Return a string describing ENUMVAL, a 'server-name-type' value.
+
+ -- Scheme Procedure: sign-algorithm->string enumval
+ Return a string describing ENUMVAL, a 'sign-algorithm' value.
+
+ -- Scheme Procedure: pk-algorithm->string enumval
+ Return a string describing ENUMVAL, a 'pk-algorithm' value.
+
+ -- Scheme Procedure: x509-subject-alternative-name->string enumval
+ Return a string describing ENUMVAL, a
+ 'x509-subject-alternative-name' value.
+
+ -- Scheme Procedure: x509-certificate-format->string enumval
+ Return a string describing ENUMVAL, a 'x509-certificate-format'
+ value.
+
+ -- Scheme Procedure: certificate-type->string enumval
+ Return a string describing ENUMVAL, a 'certificate-type' value.
+
+ -- Scheme Procedure: protocol->string enumval
+ Return a string describing ENUMVAL, a 'protocol' value.
+
+ -- Scheme Procedure: close-request->string enumval
+ Return a string describing ENUMVAL, a 'close-request' value.
+
+ -- Scheme Procedure: certificate-request->string enumval
+ Return a string describing ENUMVAL, a 'certificate-request' value.
+
+ -- Scheme Procedure: certificate-status->string enumval
+ Return a string describing ENUMVAL, a 'certificate-status' value.
+
+ -- Scheme Procedure: handshake-description->string enumval
+ Return a string describing ENUMVAL, a 'handshake-description'
+ value.
+
+ -- Scheme Procedure: alert-description->string enumval
+ Return a string describing ENUMVAL, a 'alert-description' value.
+
+ -- Scheme Procedure: alert-level->string enumval
+ Return a string describing ENUMVAL, a 'alert-level' value.
+
+ -- Scheme Procedure: connection-flag->string enumval
+ Return a string describing ENUMVAL, a 'connection-flag' value.
+
+ -- Scheme Procedure: connection-end->string enumval
+ Return a string describing ENUMVAL, a 'connection-end' value.
+
+ -- Scheme Procedure: compression-method->string enumval
+ Return a string describing ENUMVAL, a 'compression-method' value.
+
+ -- Scheme Procedure: digest->string enumval
+ Return a string describing ENUMVAL, a 'digest' value.
+
+ -- Scheme Procedure: mac->string enumval
+ Return a string describing ENUMVAL, a 'mac' value.
+
+ -- Scheme Procedure: credentials->string enumval
+ Return a string describing ENUMVAL, a 'credentials' value.
+
+ -- Scheme Procedure: params->string enumval
+ Return a string describing ENUMVAL, a 'params' value.
+
+ -- Scheme Procedure: kx->string enumval
+ Return a string describing ENUMVAL, a 'kx' value.
+
+ -- Scheme Procedure: cipher->string enumval
+ Return a string describing ENUMVAL, a 'cipher' value.
+
+
+File: gnutls-guile.info, Node: Copying Information, Next: Procedure Index, Prev: Guile Reference, Up: Top
+
+Appendix A Copying Information
+******************************
+
+GNU Free Documentation License
+==============================
+
+ Version 1.3, 3 November 2008
+
+ Copyright (C) 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
+ <https://fsf.org/>
+
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ 0. PREAMBLE
+
+ The purpose of this License is to make a manual, textbook, or other
+ functional and useful document "free" in the sense of freedom: to
+ assure everyone the effective freedom to copy and redistribute it,
+ with or without modifying it, either commercially or
+ noncommercially. Secondarily, this License preserves for the
+ author and publisher a way to get credit for their work, while not
+ being considered responsible for modifications made by others.
+
+ This License is a kind of "copyleft", which means that derivative
+ works of the document must themselves be free in the same sense.
+ It complements the GNU General Public License, which is a copyleft
+ license designed for free software.
+
+ We have designed this License in order to use it for manuals for
+ free software, because free software needs free documentation: a
+ free program should come with manuals providing the same freedoms
+ that the software does. But this License is not limited to
+ software manuals; it can be used for any textual work, regardless
+ of subject matter or whether it is published as a printed book. We
+ recommend this License principally for works whose purpose is
+ instruction or reference.
+
+ 1. APPLICABILITY AND DEFINITIONS
+
+ This License applies to any manual or other work, in any medium,
+ that contains a notice placed by the copyright holder saying it can
+ be distributed under the terms of this License. Such a notice
+ grants a world-wide, royalty-free license, unlimited in duration,
+ to use that work under the conditions stated herein. The
+ "Document", below, refers to any such manual or work. Any member
+ of the public is a licensee, and is addressed as "you". You accept
+ the license if you copy, modify or distribute the work in a way
+ requiring permission under copyright law.
+
+ A "Modified Version" of the Document means any work containing the
+ Document or a portion of it, either copied verbatim, or with
+ modifications and/or translated into another language.
+
+ A "Secondary Section" is a named appendix or a front-matter section
+ of the Document that deals exclusively with the relationship of the
+ publishers or authors of the Document to the Document's overall
+ subject (or to related matters) and contains nothing that could
+ fall directly within that overall subject. (Thus, if the Document
+ is in part a textbook of mathematics, a Secondary Section may not
+ explain any mathematics.) The relationship could be a matter of
+ historical connection with the subject or with related matters, or
+ of legal, commercial, philosophical, ethical or political position
+ regarding them.
+
+ The "Invariant Sections" are certain Secondary Sections whose
+ titles are designated, as being those of Invariant Sections, in the
+ notice that says that the Document is released under this License.
+ If a section does not fit the above definition of Secondary then it
+ is not allowed to be designated as Invariant. The Document may
+ contain zero Invariant Sections. If the Document does not identify
+ any Invariant Sections then there are none.
+
+ The "Cover Texts" are certain short passages of text that are
+ listed, as Front-Cover Texts or Back-Cover Texts, in the notice
+ that says that the Document is released under this License. A
+ Front-Cover Text may be at most 5 words, and a Back-Cover Text may
+ be at most 25 words.
+
+ A "Transparent" copy of the Document means a machine-readable copy,
+ represented in a format whose specification is available to the
+ general public, that is suitable for revising the document
+ straightforwardly with generic text editors or (for images composed
+ of pixels) generic paint programs or (for drawings) some widely
+ available drawing editor, and that is suitable for input to text
+ formatters or for automatic translation to a variety of formats
+ suitable for input to text formatters. A copy made in an otherwise
+ Transparent file format whose markup, or absence of markup, has
+ been arranged to thwart or discourage subsequent modification by
+ readers is not Transparent. An image format is not Transparent if
+ used for any substantial amount of text. A copy that is not
+ "Transparent" is called "Opaque".
+
+ Examples of suitable formats for Transparent copies include plain
+ ASCII without markup, Texinfo input format, LaTeX input format,
+ SGML or XML using a publicly available DTD, and standard-conforming
+ simple HTML, PostScript or PDF designed for human modification.
+ Examples of transparent image formats include PNG, XCF and JPG.
+ Opaque formats include proprietary formats that can be read and
+ edited only by proprietary word processors, SGML or XML for which
+ the DTD and/or processing tools are not generally available, and
+ the machine-generated HTML, PostScript or PDF produced by some word
+ processors for output purposes only.
+
+ The "Title Page" means, for a printed book, the title page itself,
+ plus such following pages as are needed to hold, legibly, the
+ material this License requires to appear in the title page. For
+ works in formats which do not have any title page as such, "Title
+ Page" means the text near the most prominent appearance of the
+ work's title, preceding the beginning of the body of the text.
+
+ The "publisher" means any person or entity that distributes copies
+ of the Document to the public.
+
+ A section "Entitled XYZ" means a named subunit of the Document
+ whose title either is precisely XYZ or contains XYZ in parentheses
+ following text that translates XYZ in another language. (Here XYZ
+ stands for a specific section name mentioned below, such as
+ "Acknowledgements", "Dedications", "Endorsements", or "History".)
+ To "Preserve the Title" of such a section when you modify the
+ Document means that it remains a section "Entitled XYZ" according
+ to this definition.
+
+ The Document may include Warranty Disclaimers next to the notice
+ which states that this License applies to the Document. These
+ Warranty Disclaimers are considered to be included by reference in
+ this License, but only as regards disclaiming warranties: any other
+ implication that these Warranty Disclaimers may have is void and
+ has no effect on the meaning of this License.
+
+ 2. VERBATIM COPYING
+
+ You may copy and distribute the Document in any medium, either
+ commercially or noncommercially, provided that this License, the
+ copyright notices, and the license notice saying this License
+ applies to the Document are reproduced in all copies, and that you
+ add no other conditions whatsoever to those of this License. You
+ may not use technical measures to obstruct or control the reading
+ or further copying of the copies you make or distribute. However,
+ you may accept compensation in exchange for copies. If you
+ distribute a large enough number of copies you must also follow the
+ conditions in section 3.
+
+ You may also lend copies, under the same conditions stated above,
+ and you may publicly display copies.
+
+ 3. COPYING IN QUANTITY
+
+ If you publish printed copies (or copies in media that commonly
+ have printed covers) of the Document, numbering more than 100, and
+ the Document's license notice requires Cover Texts, you must
+ enclose the copies in covers that carry, clearly and legibly, all
+ these Cover Texts: Front-Cover Texts on the front cover, and
+ Back-Cover Texts on the back cover. Both covers must also clearly
+ and legibly identify you as the publisher of these copies. The
+ front cover must present the full title with all words of the title
+ equally prominent and visible. You may add other material on the
+ covers in addition. Copying with changes limited to the covers, as
+ long as they preserve the title of the Document and satisfy these
+ conditions, can be treated as verbatim copying in other respects.
+
+ If the required texts for either cover are too voluminous to fit
+ legibly, you should put the first ones listed (as many as fit
+ reasonably) on the actual cover, and continue the rest onto
+ adjacent pages.
+
+ If you publish or distribute Opaque copies of the Document
+ numbering more than 100, you must either include a machine-readable
+ Transparent copy along with each Opaque copy, or state in or with
+ each Opaque copy a computer-network location from which the general
+ network-using public has access to download using public-standard
+ network protocols a complete Transparent copy of the Document, free
+ of added material. If you use the latter option, you must take
+ reasonably prudent steps, when you begin distribution of Opaque
+ copies in quantity, to ensure that this Transparent copy will
+ remain thus accessible at the stated location until at least one
+ year after the last time you distribute an Opaque copy (directly or
+ through your agents or retailers) of that edition to the public.
+
+ It is requested, but not required, that you contact the authors of
+ the Document well before redistributing any large number of copies,
+ to give them a chance to provide you with an updated version of the
+ Document.
+
+ 4. MODIFICATIONS
+
+ You may copy and distribute a Modified Version of the Document
+ under the conditions of sections 2 and 3 above, provided that you
+ release the Modified Version under precisely this License, with the
+ Modified Version filling the role of the Document, thus licensing
+ distribution and modification of the Modified Version to whoever
+ possesses a copy of it. In addition, you must do these things in
+ the Modified Version:
+
+ A. Use in the Title Page (and on the covers, if any) a title
+ distinct from that of the Document, and from those of previous
+ versions (which should, if there were any, be listed in the
+ History section of the Document). You may use the same title
+ as a previous version if the original publisher of that
+ version gives permission.
+
+ B. List on the Title Page, as authors, one or more persons or
+ entities responsible for authorship of the modifications in
+ the Modified Version, together with at least five of the
+ principal authors of the Document (all of its principal
+ authors, if it has fewer than five), unless they release you
+ from this requirement.
+
+ C. State on the Title page the name of the publisher of the
+ Modified Version, as the publisher.
+
+ D. Preserve all the copyright notices of the Document.
+
+ E. Add an appropriate copyright notice for your modifications
+ adjacent to the other copyright notices.
+
+ F. Include, immediately after the copyright notices, a license
+ notice giving the public permission to use the Modified
+ Version under the terms of this License, in the form shown in
+ the Addendum below.
+
+ G. Preserve in that license notice the full lists of Invariant
+ Sections and required Cover Texts given in the Document's
+ license notice.
+
+ H. Include an unaltered copy of this License.
+
+ I. Preserve the section Entitled "History", Preserve its Title,
+ and add to it an item stating at least the title, year, new
+ authors, and publisher of the Modified Version as given on the
+ Title Page. If there is no section Entitled "History" in the
+ Document, create one stating the title, year, authors, and
+ publisher of the Document as given on its Title Page, then add
+ an item describing the Modified Version as stated in the
+ previous sentence.
+
+ J. Preserve the network location, if any, given in the Document
+ for public access to a Transparent copy of the Document, and
+ likewise the network locations given in the Document for
+ previous versions it was based on. These may be placed in the
+ "History" section. You may omit a network location for a work
+ that was published at least four years before the Document
+ itself, or if the original publisher of the version it refers
+ to gives permission.
+
+ K. For any section Entitled "Acknowledgements" or "Dedications",
+ Preserve the Title of the section, and preserve in the section
+ all the substance and tone of each of the contributor
+ acknowledgements and/or dedications given therein.
+
+ L. Preserve all the Invariant Sections of the Document, unaltered
+ in their text and in their titles. Section numbers or the
+ equivalent are not considered part of the section titles.
+
+ M. Delete any section Entitled "Endorsements". Such a section
+ may not be included in the Modified Version.
+
+ N. Do not retitle any existing section to be Entitled
+ "Endorsements" or to conflict in title with any Invariant
+ Section.
+
+ O. Preserve any Warranty Disclaimers.
+
+ If the Modified Version includes new front-matter sections or
+ appendices that qualify as Secondary Sections and contain no
+ material copied from the Document, you may at your option designate
+ some or all of these sections as invariant. To do this, add their
+ titles to the list of Invariant Sections in the Modified Version's
+ license notice. These titles must be distinct from any other
+ section titles.
+
+ You may add a section Entitled "Endorsements", provided it contains
+ nothing but endorsements of your Modified Version by various
+ parties--for example, statements of peer review or that the text
+ has been approved by an organization as the authoritative
+ definition of a standard.
+
+ You may add a passage of up to five words as a Front-Cover Text,
+ and a passage of up to 25 words as a Back-Cover Text, to the end of
+ the list of Cover Texts in the Modified Version. Only one passage
+ of Front-Cover Text and one of Back-Cover Text may be added by (or
+ through arrangements made by) any one entity. If the Document
+ already includes a cover text for the same cover, previously added
+ by you or by arrangement made by the same entity you are acting on
+ behalf of, you may not add another; but you may replace the old
+ one, on explicit permission from the previous publisher that added
+ the old one.
+
+ The author(s) and publisher(s) of the Document do not by this
+ License give permission to use their names for publicity for or to
+ assert or imply endorsement of any Modified Version.
+
+ 5. COMBINING DOCUMENTS
+
+ You may combine the Document with other documents released under
+ this License, under the terms defined in section 4 above for
+ modified versions, provided that you include in the combination all
+ of the Invariant Sections of all of the original documents,
+ unmodified, and list them all as Invariant Sections of your
+ combined work in its license notice, and that you preserve all
+ their Warranty Disclaimers.
+
+ The combined work need only contain one copy of this License, and
+ multiple identical Invariant Sections may be replaced with a single
+ copy. If there are multiple Invariant Sections with the same name
+ but different contents, make the title of each such section unique
+ by adding at the end of it, in parentheses, the name of the
+ original author or publisher of that section if known, or else a
+ unique number. Make the same adjustment to the section titles in
+ the list of Invariant Sections in the license notice of the
+ combined work.
+
+ In the combination, you must combine any sections Entitled
+ "History" in the various original documents, forming one section
+ Entitled "History"; likewise combine any sections Entitled
+ "Acknowledgements", and any sections Entitled "Dedications". You
+ must delete all sections Entitled "Endorsements."
+
+ 6. COLLECTIONS OF DOCUMENTS
+
+ You may make a collection consisting of the Document and other
+ documents released under this License, and replace the individual
+ copies of this License in the various documents with a single copy
+ that is included in the collection, provided that you follow the
+ rules of this License for verbatim copying of each of the documents
+ in all other respects.
+
+ You may extract a single document from such a collection, and
+ distribute it individually under this License, provided you insert
+ a copy of this License into the extracted document, and follow this
+ License in all other respects regarding verbatim copying of that
+ document.
+
+ 7. AGGREGATION WITH INDEPENDENT WORKS
+
+ A compilation of the Document or its derivatives with other
+ separate and independent documents or works, in or on a volume of a
+ storage or distribution medium, is called an "aggregate" if the
+ copyright resulting from the compilation is not used to limit the
+ legal rights of the compilation's users beyond what the individual
+ works permit. When the Document is included in an aggregate, this
+ License does not apply to the other works in the aggregate which
+ are not themselves derivative works of the Document.
+
+ If the Cover Text requirement of section 3 is applicable to these
+ copies of the Document, then if the Document is less than one half
+ of the entire aggregate, the Document's Cover Texts may be placed
+ on covers that bracket the Document within the aggregate, or the
+ electronic equivalent of covers if the Document is in electronic
+ form. Otherwise they must appear on printed covers that bracket
+ the whole aggregate.
+
+ 8. TRANSLATION
+
+ Translation is considered a kind of modification, so you may
+ distribute translations of the Document under the terms of section
+ 4. Replacing Invariant Sections with translations requires special
+ permission from their copyright holders, but you may include
+ translations of some or all Invariant Sections in addition to the
+ original versions of these Invariant Sections. You may include a
+ translation of this License, and all the license notices in the
+ Document, and any Warranty Disclaimers, provided that you also
+ include the original English version of this License and the
+ original versions of those notices and disclaimers. In case of a
+ disagreement between the translation and the original version of
+ this License or a notice or disclaimer, the original version will
+ prevail.
+
+ If a section in the Document is Entitled "Acknowledgements",
+ "Dedications", or "History", the requirement (section 4) to
+ Preserve its Title (section 1) will typically require changing the
+ actual title.
+
+ 9. TERMINATION
+
+ You may not copy, modify, sublicense, or distribute the Document
+ except as expressly provided under this License. Any attempt
+ otherwise to copy, modify, sublicense, or distribute it is void,
+ and will automatically terminate your rights under this License.
+
+ However, if you cease all violation of this License, then your
+ license from a particular copyright holder is reinstated (a)
+ provisionally, unless and until the copyright holder explicitly and
+ finally terminates your license, and (b) permanently, if the
+ copyright holder fails to notify you of the violation by some
+ reasonable means prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+ reinstated permanently if the copyright holder notifies you of the
+ violation by some reasonable means, this is the first time you have
+ received notice of violation of this License (for any work) from
+ that copyright holder, and you cure the violation prior to 30 days
+ after your receipt of the notice.
+
+ Termination of your rights under this section does not terminate
+ the licenses of parties who have received copies or rights from you
+ under this License. If your rights have been terminated and not
+ permanently reinstated, receipt of a copy of some or all of the
+ same material does not give you any rights to use it.
+
+ 10. FUTURE REVISIONS OF THIS LICENSE
+
+ The Free Software Foundation may publish new, revised versions of
+ the GNU Free Documentation License from time to time. Such new
+ versions will be similar in spirit to the present version, but may
+ differ in detail to address new problems or concerns. See
+ <https://www.gnu.org/licenses/>.
+
+ Each version of the License is given a distinguishing version
+ number. If the Document specifies that a particular numbered
+ version of this License "or any later version" applies to it, you
+ have the option of following the terms and conditions either of
+ that specified version or of any later version that has been
+ published (not as a draft) by the Free Software Foundation. If the
+ Document does not specify a version number of this License, you may
+ choose any version ever published (not as a draft) by the Free
+ Software Foundation. If the Document specifies that a proxy can
+ decide which future versions of this License can be used, that
+ proxy's public statement of acceptance of a version permanently
+ authorizes you to choose that version for the Document.
+
+ 11. RELICENSING
+
+ "Massive Multiauthor Collaboration Site" (or "MMC Site") means any
+ World Wide Web server that publishes copyrightable works and also
+ provides prominent facilities for anybody to edit those works. A
+ public wiki that anybody can edit is an example of such a server.
+ A "Massive Multiauthor Collaboration" (or "MMC") contained in the
+ site means any set of copyrightable works thus published on the MMC
+ site.
+
+ "CC-BY-SA" means the Creative Commons Attribution-Share Alike 3.0
+ license published by Creative Commons Corporation, a not-for-profit
+ corporation with a principal place of business in San Francisco,
+ California, as well as future copyleft versions of that license
+ published by that same organization.
+
+ "Incorporate" means to publish or republish a Document, in whole or
+ in part, as part of another Document.
+
+ An MMC is "eligible for relicensing" if it is licensed under this
+ License, and if all works that were first published under this
+ License somewhere other than this MMC, and subsequently
+ incorporated in whole or in part into the MMC, (1) had no cover
+ texts or invariant sections, and (2) were thus incorporated prior
+ to November 1, 2008.
+
+ The operator of an MMC Site may republish an MMC contained in the
+ site under CC-BY-SA on the same site at any time before August 1,
+ 2009, provided the MMC is eligible for relicensing.
+
+ADDENDUM: How to use this License for your documents
+====================================================
+
+To use this License in a document you have written, include a copy of
+the License in the document and put the following copyright and license
+notices just after the title page:
+
+ Copyright (C) YEAR YOUR NAME.
+ Permission is granted to copy, distribute and/or modify this document
+ under the terms of the GNU Free Documentation License, Version 1.3
+ or any later version published by the Free Software Foundation;
+ with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
+ Texts. A copy of the license is included in the section entitled ``GNU
+ Free Documentation License''.
+
+If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts,
+replace the "with...Texts." line with this:
+
+ with the Invariant Sections being LIST THEIR TITLES, with
+ the Front-Cover Texts being LIST, and with the Back-Cover Texts
+ being LIST.
+
+If you have Invariant Sections without Cover Texts, or some other
+combination of the three, merge those two alternatives to suit the
+situation.
+
+If your document contains nontrivial examples of program code, we
+recommend releasing these examples in parallel under your choice of free
+software license, such as the GNU General Public License, to permit
+their use in free software.
+
+
+File: gnutls-guile.info, Node: Procedure Index, Next: Concept Index, Prev: Copying Information, Up: Top
+
+Procedure Index
+***************
+
+
+* Menu:
+
+* %import-openpgp-certificate: Guile Reference. (line 64)
+* %import-openpgp-private-key: Guile Reference. (line 59)
+* %openpgp-certificate-algorithm: Guile Reference. (line 35)
+* %openpgp-certificate-fingerprint: Guile Reference. (line 45)
+* %openpgp-certificate-fingerprint!: Guile Reference. (line 48)
+* %openpgp-certificate-id: Guile Reference. (line 56)
+* %openpgp-certificate-id!: Guile Reference. (line 52)
+* %openpgp-certificate-name: Guile Reference. (line 42)
+* %openpgp-certificate-names: Guile Reference. (line 39)
+* %openpgp-certificate-usage: Guile Reference. (line 28)
+* %openpgp-certificate-version: Guile Reference. (line 31)
+* %openpgp-keyring-contains-key-id?: Guile Reference. (line 21)
+* %set-certificate-credentials-openpgp-keys!: Guile Reference.
+ (line 16)
+* alert-description->string: Guile Reference. (line 470)
+* alert-get: Guile Reference. (line 351)
+* alert-level->string: Guile Reference. (line 473)
+* alert-send: Guile Reference. (line 348)
+* anonymous-client-credentials?: Guile Reference. (line 412)
+* anonymous-server-credentials?: Guile Reference. (line 409)
+* bye: Guile Reference. (line 363)
+* certificate-credentials?: Guile Reference. (line 403)
+* certificate-request->string: Guile Reference. (line 460)
+* certificate-status->string: Guile Reference. (line 463)
+* certificate-type->string: Guile Reference. (line 451)
+* certificate-verify->string: Guile Reference. (line 425)
+* cipher->string: Guile Reference. (line 500)
+* cipher-suite->string: Guile Reference. (line 287)
+* close-request->string: Guile Reference. (line 457)
+* compression-method->string: Guile Reference. (line 482)
+* connection-end->string: Guile Reference. (line 479)
+* connection-flag->string: Guile Reference. (line 476)
+* credentials->string: Guile Reference. (line 491)
+* dh-parameters?: Guile Reference. (line 406)
+* digest->string: Guile Reference. (line 485)
+* error->string: Exception Handling. (line 6)
+* error->string <1>: Guile Reference. (line 422)
+* gnutls-version: Guile Reference. (line 372)
+* handshake: Guile Reference. (line 360)
+* handshake-description->string: Guile Reference. (line 466)
+* import-openpgp-keyring: Guile Reference. (line 24)
+* import-x509-certificate: Guile Reference. (line 138)
+* import-x509-private-key: Guile Reference. (line 134)
+* key-usage->string: Guile Reference. (line 428)
+* kx->string: Guile Reference. (line 497)
+* mac->string: Guile Reference. (line 488)
+* make-anonymous-client-credentials: Guile Reference. (line 226)
+* make-anonymous-server-credentials: Guile Reference. (line 229)
+* make-certificate-credentials: Guile Reference. (line 218)
+* make-dh-parameters: Representation of Binary Data.
+ (line 16)
+* make-dh-parameters <1>: Guile Reference. (line 245)
+* make-psk-client-credentials: Guile Reference. (line 150)
+* make-psk-server-credentials: Guile Reference. (line 156)
+* make-session: Guile Reference. (line 366)
+* openpgp-certificate-format->string: Guile Reference. (line 418)
+* openpgp-certificate?: Guile Reference. (line 382)
+* openpgp-keyring?: Guile Reference. (line 376)
+* openpgp-private-key?: Guile Reference. (line 379)
+* params->string: Guile Reference. (line 494)
+* peer-certificate-status: Guile Reference. (line 159)
+* pk-algorithm->string: Guile Reference. (line 440)
+* pkcs3-export-dh-parameters: Representation of Binary Data.
+ (line 16)
+* pkcs3-export-dh-parameters <1>: Guile Reference. (line 235)
+* pkcs3-import-dh-parameters: Guile Reference. (line 240)
+* pkcs8-import-x509-private-key: Guile Reference. (line 127)
+* protocol->string: Guile Reference. (line 454)
+* psk-client-credentials?: Guile Reference. (line 391)
+* psk-key-format->string: Guile Reference. (line 431)
+* psk-server-credentials?: Guile Reference. (line 394)
+* reauthenticate: Guile Reference. (line 354)
+* record-receive!: Input and Output. (line 55)
+* record-receive! <1>: Guile Reference. (line 271)
+* record-send: Input and Output. (line 55)
+* record-send <1>: Guile Reference. (line 275)
+* rehandshake: Guile Reference. (line 357)
+* server-name-type->string: Guile Reference. (line 434)
+* server-session-psk-username: Guile Reference. (line 142)
+* session-authentication-type: Guile Reference. (line 326)
+* session-certificate-type: Guile Reference. (line 333)
+* session-cipher: Enumerates and Constants.
+ (line 47)
+* session-cipher <1>: Guile Reference. (line 345)
+* session-client-authentication-type: Guile Reference. (line 318)
+* session-compression-method: Guile Reference. (line 336)
+* session-kx: Guile Reference. (line 342)
+* session-mac: Guile Reference. (line 339)
+* session-our-certificate-chain: Guile Reference. (line 306)
+* session-peer-certificate-chain: Guile Reference. (line 311)
+* session-protocol: Guile Reference. (line 330)
+* session-record-port: Input and Output. (line 28)
+* session-record-port <1>: Guile Reference. (line 261)
+* session-server-authentication-type: Guile Reference. (line 322)
+* session?: Guile Reference. (line 415)
+* set-anonymous-server-dh-parameters!: Guile Reference. (line 222)
+* set-certificate-credentials-dh-parameters!: Guile Reference.
+ (line 213)
+* set-certificate-credentials-verify-flags!: Guile Reference. (line 164)
+* set-certificate-credentials-verify-limits!: Guile Reference.
+ (line 169)
+* set-certificate-credentials-x509-crl-data!: Guile Reference.
+ (line 187)
+* set-certificate-credentials-x509-crl-file!: Guile Reference.
+ (line 198)
+* set-certificate-credentials-x509-key-data!: Guile Reference.
+ (line 181)
+* set-certificate-credentials-x509-key-files!: Guile Reference.
+ (line 209)
+* set-certificate-credentials-x509-keys!: Guile Reference. (line 176)
+* set-certificate-credentials-x509-trust-data!: Guile Reference.
+ (line 193)
+* set-certificate-credentials-x509-trust-file!: Guile Reference.
+ (line 204)
+* set-log-level!: Guile Reference. (line 9)
+* set-log-procedure!: Guile Reference. (line 12)
+* set-psk-client-credentials!: Guile Reference. (line 145)
+* set-psk-server-credentials-file!: Guile Reference. (line 153)
+* set-server-session-certificate-request!: Guile Reference. (line 300)
+* set-session-credentials!: Guile Reference. (line 284)
+* set-session-default-priority!: Guile Reference. (line 297)
+* set-session-dh-prime-bits!: Guile Reference. (line 232)
+* set-session-priorities!: Guile Reference. (line 290)
+* set-session-record-port-close!: Guile Reference. (line 254)
+* set-session-server-name!: Guile Reference. (line 278)
+* set-session-transport-fd!: Input and Output. (line 6)
+* set-session-transport-fd! <1>: Guile Reference. (line 251)
+* set-session-transport-port!: Input and Output. (line 6)
+* set-session-transport-port! <1>: Guile Reference. (line 248)
+* sign-algorithm->string: Guile Reference. (line 437)
+* srp-client-credentials?: Guile Reference. (line 397)
+* srp-server-credentials?: Guile Reference. (line 400)
+* x509-certificate-authority-key-id: Guile Reference. (line 82)
+* x509-certificate-dn: Guile Reference. (line 122)
+* x509-certificate-dn-oid: Guile Reference. (line 115)
+* x509-certificate-fingerprint: Guile Reference. (line 68)
+* x509-certificate-format->string: Guile Reference. (line 447)
+* x509-certificate-issuer-dn: Guile Reference. (line 119)
+* x509-certificate-issuer-dn-oid: Guile Reference. (line 111)
+* x509-certificate-key-id: Guile Reference. (line 86)
+* x509-certificate-key-usage: Guile Reference. (line 94)
+* x509-certificate-matches-hostname?: Guile Reference. (line 106)
+* x509-certificate-public-key-algorithm: Guile Reference. (line 98)
+* x509-certificate-signature-algorithm: Guile Reference. (line 102)
+* x509-certificate-subject-alternative-name: Guile Reference. (line 72)
+* x509-certificate-subject-key-id: Guile Reference. (line 79)
+* x509-certificate-version: Guile Reference. (line 91)
+* x509-certificate?: Guile Reference. (line 388)
+* x509-private-key?: Guile Reference. (line 385)
+* x509-subject-alternative-name->string: Guile Reference. (line 443)
+
+
+File: gnutls-guile.info, Node: Concept Index, Prev: Procedure Index, Up: Top
+
+Concept Index
+*************
+
+
+* Menu:
+
+* buffering: Input and Output. (line 47)
+* bytevectors: Representation of Binary Data.
+ (line 9)
+* constant: Enumerates and Constants.
+ (line 6)
+* enumerate: Enumerates and Constants.
+ (line 6)
+* errors: Exception Handling. (line 6)
+* exceptions: Exception Handling. (line 6)
+* FDL, GNU Free Documentation License: Copying Information. (line 6)
+* gnutls-error: Exception Handling. (line 6)
+* homogeneous vector: Representation of Binary Data.
+ (line 9)
+* SRFI-4: Representation of Binary Data.
+ (line 9)
+
+
+
+Tag Table:
+Node: Top802
+Node: Preface1874
+Node: Guile Preparations2441
+Node: Guile API Conventions5186
+Node: Enumerates and Constants5760
+Node: Procedure Names8085
+Node: Representation of Binary Data9068
+Ref: Representation of Binary Data-Footnote-19993
+Node: Input and Output10109
+Node: Exception Handling12454
+Node: Guile Examples14282
+Node: Anonymous Authentication Guile Example14581
+Node: Guile Reference17098
+Node: Copying Information37275
+Node: Procedure Index62463
+Node: Concept Index73486
+
+End Tag Table
+
+
+Local Variables:
+coding: utf-8
+End: