2006-02-13 07:11:56 +08:00
|
|
|
=pod
|
2019-10-31 11:35:08 +08:00
|
|
|
{- OpenSSL::safe::output_do_not_edit_headers(); -}
|
2019-10-13 05:45:56 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=head1 NAME
|
|
|
|
|
2020-02-19 00:52:12 +08:00
|
|
|
openssl-ts - Time Stamping Authority command
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
Document most missing options
Add cmd-nits make target.
Listing options should stop when it hits the "parameters" separator.
Add missing .pod.in files to doc/man1/build.info
Tweak find-doc-nits to try openssl-XXX before XXX for POD files and
change an error messavge to be more useful.
Fix the following pages: ca, cms, crl, dgst, enc,
engine, errstr, gendsa, genrsa, list, ocsp, passwd, pkcs7, pkcs12, rand,
rehash, req, rsautil, s_server, speed, s_time,
sess_id, smime, srp, ts, x509.
Reviewed-by: Matt Caswell <matt@openssl.org>
Reviewed-by: Dmitry Belyavskiy <beldmit@gmail.com>
Reviewed-by: Matthias St. Pierre <Matthias.St.Pierre@ncp-e.com>
(Merged from https://github.com/openssl/openssl/pull/10873)
2020-01-17 02:40:52 +08:00
|
|
|
B<openssl> B<ts>
|
|
|
|
B<-help>
|
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
B<openssl> B<ts>
|
|
|
|
B<-query>
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-config> I<configfile>]
|
|
|
|
[B<-data> I<file_to_hash>]
|
|
|
|
[B<-digest> I<digest_bytes>]
|
2019-10-02 23:13:03 +08:00
|
|
|
[B<-I<digest>>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-tspolicy> I<object_id>]
|
2006-02-13 07:11:56 +08:00
|
|
|
[B<-no_nonce>]
|
|
|
|
[B<-cert>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-in> I<request.tsq>]
|
|
|
|
[B<-out> I<request.tsq>]
|
2006-02-13 07:11:56 +08:00
|
|
|
[B<-text>]
|
2019-10-13 05:45:56 +08:00
|
|
|
{- $OpenSSL::safe::opt_r_synopsis -}
|
2020-02-25 12:29:30 +08:00
|
|
|
{- $OpenSSL::safe::opt_provider_synopsis -}
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
B<openssl> B<ts>
|
|
|
|
B<-reply>
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-config> I<configfile>]
|
|
|
|
[B<-section> I<tsa_section>]
|
|
|
|
[B<-queryfile> I<request.tsq>]
|
|
|
|
[B<-passin> I<password_src>]
|
|
|
|
[B<-signer> I<tsa_cert.pem>]
|
2020-11-30 14:25:46 +08:00
|
|
|
[B<-inkey> I<filename>|I<uri>]
|
2019-10-02 23:13:03 +08:00
|
|
|
[B<-I<digest>>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-chain> I<certs_file.pem>]
|
|
|
|
[B<-tspolicy> I<object_id>]
|
|
|
|
[B<-in> I<response.tsr>]
|
2006-02-13 07:11:56 +08:00
|
|
|
[B<-token_in>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-out> I<response.tsr>]
|
2006-02-13 07:11:56 +08:00
|
|
|
[B<-token_out>]
|
|
|
|
[B<-text>]
|
2020-09-21 17:56:01 +08:00
|
|
|
{- $OpenSSL::safe::opt_engine_synopsis -}{- $OpenSSL::safe::opt_provider_synopsis -}
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
B<openssl> B<ts>
|
|
|
|
B<-verify>
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-data> I<file_to_hash>]
|
|
|
|
[B<-digest> I<digest_bytes>]
|
|
|
|
[B<-queryfile> I<request.tsq>]
|
|
|
|
[B<-in> I<response.tsr>]
|
2006-02-13 07:11:56 +08:00
|
|
|
[B<-token_in>]
|
2021-03-11 00:27:13 +08:00
|
|
|
[B<-untrusted> I<files>|I<uris>]
|
2020-01-25 01:33:05 +08:00
|
|
|
[B<-CAfile> I<file>]
|
|
|
|
[B<-CApath> I<dir>]
|
|
|
|
[B<-CAstore> I<uri>]
|
2019-10-13 05:45:56 +08:00
|
|
|
{- $OpenSSL::safe::opt_v_synopsis -}
|
2020-02-25 12:29:30 +08:00
|
|
|
{- $OpenSSL::safe::opt_provider_synopsis -}
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
Command docs: fix up command references
Almost all OpenSSL commands are in reality 'openssl cmd', so make sure
they are refered to like that and not just as the sub-command.
Self-references are avoided as much as is possible, and replaced with
"this command". In some cases, we even avoid that with a slight
rewrite of the sentence or paragrah they were in. However, in the few
cases where a self-reference is still admissible, they are done in
bold, i.e. openssl-speed.pod references itself like this:
B<openssl speed>
References to other commands are done as manual links, i.e. CA.pl.pod
references 'openssl req' like this: L<openssl-req(1)>
Some commands are examples rather than references; we enclose those in
C<>.
While we are it, we abolish "utility", replacing it with "command", or
remove it entirely in some cases.
Reviewed-by: Tomas Mraz <tmraz@fedoraproject.org>
(Merged from https://github.com/openssl/openssl/pull/10065)
2019-10-02 01:43:36 +08:00
|
|
|
This command is a basic Time Stamping Authority (TSA) client and
|
|
|
|
server application as specified in RFC 3161 (Time-Stamp Protocol, TSP). A
|
2006-02-13 07:11:56 +08:00
|
|
|
TSA can be part of a PKI deployment and its role is to provide long
|
|
|
|
term proof of the existence of a certain datum before a particular
|
|
|
|
time. Here is a brief description of the protocol:
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item 1.
|
|
|
|
|
|
|
|
The TSA client computes a one-way hash value for a data file and sends
|
|
|
|
the hash to the TSA.
|
|
|
|
|
|
|
|
=item 2.
|
|
|
|
|
|
|
|
The TSA attaches the current date and time to the received hash value,
|
2019-09-28 01:17:09 +08:00
|
|
|
signs them and sends the timestamp token back to the client. By
|
2006-02-13 07:11:56 +08:00
|
|
|
creating this token the TSA certifies the existence of the original
|
|
|
|
data file at the time of response generation.
|
|
|
|
|
|
|
|
=item 3.
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The TSA client receives the timestamp token and verifies the
|
2006-02-13 07:11:56 +08:00
|
|
|
signature on it. It also checks if the token contains the same hash
|
|
|
|
value that it had sent to the TSA.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
There is one DER encoded protocol data unit defined for transporting a
|
|
|
|
timestamp request to the TSA and one for sending the timestamp response
|
Command docs: fix up command references
Almost all OpenSSL commands are in reality 'openssl cmd', so make sure
they are refered to like that and not just as the sub-command.
Self-references are avoided as much as is possible, and replaced with
"this command". In some cases, we even avoid that with a slight
rewrite of the sentence or paragrah they were in. However, in the few
cases where a self-reference is still admissible, they are done in
bold, i.e. openssl-speed.pod references itself like this:
B<openssl speed>
References to other commands are done as manual links, i.e. CA.pl.pod
references 'openssl req' like this: L<openssl-req(1)>
Some commands are examples rather than references; we enclose those in
C<>.
While we are it, we abolish "utility", replacing it with "command", or
remove it entirely in some cases.
Reviewed-by: Tomas Mraz <tmraz@fedoraproject.org>
(Merged from https://github.com/openssl/openssl/pull/10065)
2019-10-02 01:43:36 +08:00
|
|
|
back to the client. This command has three main functions:
|
2019-09-28 01:17:09 +08:00
|
|
|
creating a timestamp request based on a data file,
|
|
|
|
creating a timestamp response based on a request, verifying if a
|
2006-02-13 07:11:56 +08:00
|
|
|
response corresponds to a particular request or a data file.
|
|
|
|
|
|
|
|
There is no support for sending the requests/responses automatically
|
|
|
|
over HTTP or TCP yet as suggested in RFC 3161. The users must send the
|
|
|
|
requests either by ftp or e-mail.
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
Document most missing options
Add cmd-nits make target.
Listing options should stop when it hits the "parameters" separator.
Add missing .pod.in files to doc/man1/build.info
Tweak find-doc-nits to try openssl-XXX before XXX for POD files and
change an error messavge to be more useful.
Fix the following pages: ca, cms, crl, dgst, enc,
engine, errstr, gendsa, genrsa, list, ocsp, passwd, pkcs7, pkcs12, rand,
rehash, req, rsautil, s_server, speed, s_time,
sess_id, smime, srp, ts, x509.
Reviewed-by: Matt Caswell <matt@openssl.org>
Reviewed-by: Dmitry Belyavskiy <beldmit@gmail.com>
Reviewed-by: Matthias St. Pierre <Matthias.St.Pierre@ncp-e.com>
(Merged from https://github.com/openssl/openssl/pull/10873)
2020-01-17 02:40:52 +08:00
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item B<-help>
|
|
|
|
|
|
|
|
Print out a usage message.
|
|
|
|
|
2021-05-17 17:04:40 +08:00
|
|
|
=item B<-query>
|
|
|
|
|
|
|
|
Generate a TS query. For details see L</Timestamp Request generation>.
|
|
|
|
|
|
|
|
=item B<-reply>
|
|
|
|
|
|
|
|
Generate a TS reply. For details see L</Timestamp Response generation>.
|
|
|
|
|
|
|
|
=item B<-verify>
|
|
|
|
|
|
|
|
Verify a TS response. For details see L</Timestamp Response verification>.
|
|
|
|
|
Document most missing options
Add cmd-nits make target.
Listing options should stop when it hits the "parameters" separator.
Add missing .pod.in files to doc/man1/build.info
Tweak find-doc-nits to try openssl-XXX before XXX for POD files and
change an error messavge to be more useful.
Fix the following pages: ca, cms, crl, dgst, enc,
engine, errstr, gendsa, genrsa, list, ocsp, passwd, pkcs7, pkcs12, rand,
rehash, req, rsautil, s_server, speed, s_time,
sess_id, smime, srp, ts, x509.
Reviewed-by: Matt Caswell <matt@openssl.org>
Reviewed-by: Dmitry Belyavskiy <beldmit@gmail.com>
Reviewed-by: Matthias St. Pierre <Matthias.St.Pierre@ncp-e.com>
(Merged from https://github.com/openssl/openssl/pull/10873)
2020-01-17 02:40:52 +08:00
|
|
|
=back
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Request generation
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2021-05-17 17:04:40 +08:00
|
|
|
The B<-query> command can be used for creating and printing a timestamp
|
2006-02-13 07:11:56 +08:00
|
|
|
request with the following options:
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-config> I<configfile>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2017-02-08 00:33:21 +08:00
|
|
|
The configuration file to use.
|
|
|
|
Optional; for a description of the default value,
|
|
|
|
see L<openssl(1)/COMMAND SUMMARY>.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-data> I<file_to_hash>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The data file for which the timestamp request needs to be
|
2006-02-13 07:11:56 +08:00
|
|
|
created. stdin is the default if neither the B<-data> nor the B<-digest>
|
|
|
|
parameter is specified. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-digest> I<digest_bytes>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
It is possible to specify the message imprint explicitly without the data
|
|
|
|
file. The imprint must be specified in a hexadecimal format, two characters
|
|
|
|
per byte, the bytes optionally separated by colons (e.g. 1A:F6:01:... or
|
2015-04-14 00:29:52 +08:00
|
|
|
1AF601...). The number of bytes must match the message digest algorithm
|
2006-02-13 07:11:56 +08:00
|
|
|
in use. (Optional)
|
|
|
|
|
2019-10-02 23:13:03 +08:00
|
|
|
=item B<-I<digest>>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2015-08-28 00:28:08 +08:00
|
|
|
The message digest to apply to the data file.
|
Command docs: fix up command references
Almost all OpenSSL commands are in reality 'openssl cmd', so make sure
they are refered to like that and not just as the sub-command.
Self-references are avoided as much as is possible, and replaced with
"this command". In some cases, we even avoid that with a slight
rewrite of the sentence or paragrah they were in. However, in the few
cases where a self-reference is still admissible, they are done in
bold, i.e. openssl-speed.pod references itself like this:
B<openssl speed>
References to other commands are done as manual links, i.e. CA.pl.pod
references 'openssl req' like this: L<openssl-req(1)>
Some commands are examples rather than references; we enclose those in
C<>.
While we are it, we abolish "utility", replacing it with "command", or
remove it entirely in some cases.
Reviewed-by: Tomas Mraz <tmraz@fedoraproject.org>
(Merged from https://github.com/openssl/openssl/pull/10065)
2019-10-02 01:43:36 +08:00
|
|
|
Any digest supported by the L<openssl-dgst(1)> command can be used.
|
2019-06-12 18:01:19 +08:00
|
|
|
The default is SHA-256. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-tspolicy> I<object_id>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The policy that the client expects the TSA to use for creating the
|
2019-09-28 01:17:09 +08:00
|
|
|
timestamp token. Either the dotted OID notation or OID names defined
|
2006-02-13 07:11:56 +08:00
|
|
|
in the config file can be used. If no policy is requested the TSA will
|
|
|
|
use its own default policy. (Optional)
|
|
|
|
|
|
|
|
=item B<-no_nonce>
|
|
|
|
|
|
|
|
No nonce is specified in the request if this option is
|
2024-03-21 18:10:04 +08:00
|
|
|
given. Otherwise, a 64-bit long pseudo-random nonce is
|
|
|
|
included in the request. It is recommended to use a nonce to
|
|
|
|
protect against replay attacks. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<-cert>
|
|
|
|
|
|
|
|
The TSA is expected to include its signing certificate in the
|
|
|
|
response. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-in> I<request.tsq>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
This option specifies a previously created timestamp request in DER
|
2006-02-13 07:11:56 +08:00
|
|
|
format that will be printed into the output file. Useful when you need
|
|
|
|
to examine the content of a request in human-readable
|
|
|
|
format. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-out> I<request.tsq>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
Name of the output file to which the request will be written. Default
|
|
|
|
is stdout. (Optional)
|
|
|
|
|
|
|
|
=item B<-text>
|
|
|
|
|
|
|
|
If this option is specified the output is human-readable text format
|
|
|
|
instead of DER. (Optional)
|
|
|
|
|
2019-10-13 05:45:56 +08:00
|
|
|
{- $OpenSSL::safe::opt_r_item -}
|
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=back
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Response generation
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
A timestamp response (TimeStampResp) consists of a response status
|
|
|
|
and the timestamp token itself (ContentInfo), if the token generation was
|
|
|
|
successful. The B<-reply> command is for creating a timestamp
|
|
|
|
response or timestamp token based on a request and printing the
|
2006-02-13 07:11:56 +08:00
|
|
|
response/token in human-readable format. If B<-token_out> is not
|
2019-09-28 01:17:09 +08:00
|
|
|
specified the output is always a timestamp response (TimeStampResp),
|
|
|
|
otherwise it is a timestamp token (ContentInfo).
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-config> I<configfile>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2017-02-08 00:33:21 +08:00
|
|
|
The configuration file to use.
|
|
|
|
Optional; for a description of the default value,
|
|
|
|
see L<openssl(1)/COMMAND SUMMARY>.
|
2019-09-26 03:20:11 +08:00
|
|
|
See L</CONFIGURATION FILE OPTIONS> for configurable variables.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-section> I<tsa_section>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2015-04-14 00:29:52 +08:00
|
|
|
The name of the config file section containing the settings for the
|
2006-02-13 07:11:56 +08:00
|
|
|
response generation. If not specified the default TSA section is
|
2019-09-26 03:20:11 +08:00
|
|
|
used, see L</CONFIGURATION FILE OPTIONS> for details. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-queryfile> I<request.tsq>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The name of the file containing a DER encoded timestamp request. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-passin> I<password_src>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
Specifies the password source for the private key of the TSA. See
|
2019-09-26 03:20:11 +08:00
|
|
|
description in L<openssl(1)>. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-signer> I<tsa_cert.pem>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The signer certificate of the TSA in PEM format. The TSA signing
|
|
|
|
certificate must have exactly one extended key usage assigned to it:
|
|
|
|
timeStamping. The extended key usage must also be critical, otherwise
|
|
|
|
the certificate is going to be refused. Overrides the B<signer_cert>
|
|
|
|
variable of the config file. (Optional)
|
|
|
|
|
2020-11-30 14:25:46 +08:00
|
|
|
=item B<-inkey> I<filename>|I<uri>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The signer private key of the TSA in PEM format. Overrides the
|
|
|
|
B<signer_key> config file option. (Optional)
|
|
|
|
|
2019-10-02 23:13:03 +08:00
|
|
|
=item B<-I<digest>>
|
2015-09-11 23:58:57 +08:00
|
|
|
|
|
|
|
Signing digest to use. Overrides the B<signer_digest> config file
|
2019-03-06 23:51:49 +08:00
|
|
|
option. (Mandatory unless specified in the config file)
|
2015-09-11 23:58:57 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-chain> I<certs_file.pem>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The collection of certificates in PEM format that will all
|
|
|
|
be included in the response in addition to the signer certificate if
|
|
|
|
the B<-cert> option was used for the request. This file is supposed to
|
|
|
|
contain the certificate chain for the signer certificate from its
|
|
|
|
issuer upwards. The B<-reply> command does not build a certificate
|
|
|
|
chain automatically. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-tspolicy> I<object_id>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The default policy to use for the response unless the client
|
|
|
|
explicitly requires a particular TSA policy. The OID can be specified
|
|
|
|
either in dotted notation or with its name. Overrides the
|
|
|
|
B<default_policy> config file option. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-in> I<response.tsr>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
Specifies a previously created timestamp response or timestamp token
|
2006-02-13 07:11:56 +08:00
|
|
|
(if B<-token_in> is also specified) in DER format that will be written
|
|
|
|
to the output file. This option does not require a request, it is
|
|
|
|
useful e.g. when you need to examine the content of a response or
|
2019-09-28 01:17:09 +08:00
|
|
|
token or you want to extract the timestamp token from a response. If
|
|
|
|
the input is a token and the output is a timestamp response a default
|
2006-02-13 07:11:56 +08:00
|
|
|
'granted' status info is added to the token. (Optional)
|
|
|
|
|
|
|
|
=item B<-token_in>
|
|
|
|
|
|
|
|
This flag can be used together with the B<-in> option and indicates
|
2019-09-28 01:17:09 +08:00
|
|
|
that the input is a DER encoded timestamp token (ContentInfo) instead
|
|
|
|
of a timestamp response (TimeStampResp). (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-out> I<response.tsr>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The response is written to this file. The format and content of the
|
|
|
|
file depends on other options (see B<-text>, B<-token_out>). The default is
|
|
|
|
stdout. (Optional)
|
|
|
|
|
|
|
|
=item B<-token_out>
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The output is a timestamp token (ContentInfo) instead of timestamp
|
2006-02-13 07:11:56 +08:00
|
|
|
response (TimeStampResp). (Optional)
|
|
|
|
|
|
|
|
=item B<-text>
|
|
|
|
|
|
|
|
If this option is specified the output is human-readable text format
|
|
|
|
instead of DER. (Optional)
|
|
|
|
|
2019-10-13 05:45:56 +08:00
|
|
|
{- $OpenSSL::safe::opt_engine_item -}
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2020-02-25 12:29:30 +08:00
|
|
|
{- $OpenSSL::safe::opt_provider_item -}
|
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=back
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Response verification
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
The B<-verify> command is for verifying if a timestamp response or
|
|
|
|
timestamp token is valid and matches a particular timestamp request or
|
2006-02-13 07:11:56 +08:00
|
|
|
data file. The B<-verify> command does not use the configuration file.
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-data> I<file_to_hash>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The response or token must be verified against file_to_hash. The file
|
2015-04-14 00:29:52 +08:00
|
|
|
is hashed with the message digest algorithm specified in the token.
|
2006-02-13 07:11:56 +08:00
|
|
|
The B<-digest> and B<-queryfile> options must not be specified with this one.
|
|
|
|
(Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-digest> I<digest_bytes>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
The response or token must be verified against the message digest specified
|
|
|
|
with this option. The number of bytes must match the message digest algorithm
|
|
|
|
specified in the token. The B<-data> and B<-queryfile> options must not be
|
|
|
|
specified with this one. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-queryfile> I<request.tsq>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The original timestamp request in DER format. The B<-data> and B<-digest>
|
2006-02-13 07:11:56 +08:00
|
|
|
options must not be specified with this one. (Optional)
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-in> I<response.tsr>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
The timestamp response that needs to be verified in DER format. (Mandatory)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<-token_in>
|
|
|
|
|
|
|
|
This flag can be used together with the B<-in> option and indicates
|
2019-09-28 01:17:09 +08:00
|
|
|
that the input is a DER encoded timestamp token (ContentInfo) instead
|
|
|
|
of a timestamp response (TimeStampResp). (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2021-03-11 00:27:13 +08:00
|
|
|
=item B<-untrusted> I<files>|I<uris>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2021-03-11 00:21:37 +08:00
|
|
|
A set of additional untrusted certificates which may be
|
|
|
|
needed when building the certificate chain for the TSA's signing certificate.
|
|
|
|
These do not need to contain the TSA signing certificate and intermediate CA
|
|
|
|
certificates as far as the response already includes them.
|
2006-02-13 07:11:56 +08:00
|
|
|
(Optional)
|
|
|
|
|
2021-03-11 00:27:13 +08:00
|
|
|
Multiple sources may be given, separated by commas and/or whitespace.
|
|
|
|
Each file may contain multiple certificates.
|
|
|
|
|
2020-01-25 01:33:05 +08:00
|
|
|
=item B<-CAfile> I<file>, B<-CApath> I<dir>, B<-CAstore> I<uri>
|
2019-10-13 05:45:56 +08:00
|
|
|
|
2020-11-28 00:05:30 +08:00
|
|
|
See L<openssl-verification-options(1)/Trusted Certificate Options> for details.
|
|
|
|
At least one of B<-CAfile>, B<-CApath> or B<-CAstore> must be specified.
|
2019-10-13 05:45:56 +08:00
|
|
|
|
|
|
|
{- $OpenSSL::safe::opt_v_item -}
|
|
|
|
|
|
|
|
Any verification errors cause the command to exit.
|
2016-03-15 17:08:49 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 CONFIGURATION FILE OPTIONS
|
|
|
|
|
2017-02-08 00:33:21 +08:00
|
|
|
The B<-query> and B<-reply> commands make use of a configuration file.
|
|
|
|
See L<config(5)>
|
2006-02-13 07:11:56 +08:00
|
|
|
for a general description of the syntax of the config file. The
|
|
|
|
B<-query> command uses only the symbolic OID names section
|
|
|
|
and it can work without it. However, the B<-reply> command needs the
|
|
|
|
config file for its operation.
|
|
|
|
|
|
|
|
When there is a command line switch equivalent of a variable the
|
|
|
|
switch always overrides the settings in the config file.
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2015-04-14 00:29:52 +08:00
|
|
|
=item B<tsa> section, B<default_tsa>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
This is the main section and it specifies the name of another section
|
|
|
|
that contains all the options for the B<-reply> command. This default
|
2013-12-24 02:28:30 +08:00
|
|
|
section can be overridden with the B<-section> command line switch. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<oid_file>
|
|
|
|
|
2019-11-13 23:02:09 +08:00
|
|
|
This specifies a file containing additional B<OBJECT IDENTIFIERS>.
|
|
|
|
Each line of the file should consist of the numerical form of the
|
2020-06-16 04:17:15 +08:00
|
|
|
object identifier followed by whitespace then the short name followed
|
|
|
|
by whitespace and finally the long name. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<oid_section>
|
|
|
|
|
2019-11-13 23:02:09 +08:00
|
|
|
This specifies a section in the configuration file containing extra
|
|
|
|
object identifiers. Each line should consist of the short name of the
|
|
|
|
object identifier followed by B<=> and the numerical form. The short
|
|
|
|
and long names are the same when this option is used. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<RANDFILE>
|
|
|
|
|
2019-11-13 23:02:09 +08:00
|
|
|
At startup the specified file is loaded into the random number generator,
|
|
|
|
and at exit 256 bytes will be written to it. (Note: Using a RANDFILE is
|
|
|
|
not necessary anymore, see the L</HISTORY> section.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<serial>
|
|
|
|
|
|
|
|
The name of the file containing the hexadecimal serial number of the
|
2019-09-28 01:17:09 +08:00
|
|
|
last timestamp response created. This number is incremented by 1 for
|
2007-12-03 17:02:29 +08:00
|
|
|
each response. If the file does not exist at the time of response
|
2006-02-13 07:11:56 +08:00
|
|
|
generation a new file is created with serial number 1. (Mandatory)
|
|
|
|
|
|
|
|
=item B<crypto_device>
|
|
|
|
|
2015-04-14 00:29:52 +08:00
|
|
|
Specifies the OpenSSL engine that will be set as the default for
|
2019-09-28 01:17:09 +08:00
|
|
|
all available algorithms. The default value is built-in, you can specify
|
2006-02-13 07:11:56 +08:00
|
|
|
any other engines supported by OpenSSL (e.g. use chil for the NCipher HSM).
|
|
|
|
(Optional)
|
|
|
|
|
|
|
|
=item B<signer_cert>
|
|
|
|
|
|
|
|
TSA signing certificate in PEM format. The same as the B<-signer>
|
|
|
|
command line option. (Optional)
|
|
|
|
|
|
|
|
=item B<certs>
|
|
|
|
|
|
|
|
A file containing a set of PEM encoded certificates that need to be
|
|
|
|
included in the response. The same as the B<-chain> command line
|
|
|
|
option. (Optional)
|
|
|
|
|
|
|
|
=item B<signer_key>
|
|
|
|
|
|
|
|
The private key of the TSA in PEM format. The same as the B<-inkey>
|
|
|
|
command line option. (Optional)
|
|
|
|
|
2015-09-11 23:58:57 +08:00
|
|
|
=item B<signer_digest>
|
|
|
|
|
|
|
|
Signing digest to use. The same as the
|
2019-10-02 23:13:03 +08:00
|
|
|
B<-I<digest>> command line option. (Mandatory unless specified on the command
|
2019-03-06 23:51:49 +08:00
|
|
|
line)
|
2015-09-11 23:58:57 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=item B<default_policy>
|
|
|
|
|
|
|
|
The default policy to use when the request does not mandate any
|
2016-03-15 17:08:49 +08:00
|
|
|
policy. The same as the B<-tspolicy> command line option. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
=item B<other_policies>
|
|
|
|
|
|
|
|
Comma separated list of policies that are also acceptable by the TSA
|
|
|
|
and used only if the request explicitly specifies one of them. (Optional)
|
|
|
|
|
|
|
|
=item B<digests>
|
|
|
|
|
|
|
|
The list of message digest algorithms that the TSA accepts. At least
|
|
|
|
one algorithm must be specified. (Mandatory)
|
|
|
|
|
|
|
|
=item B<accuracy>
|
|
|
|
|
|
|
|
The accuracy of the time source of the TSA in seconds, milliseconds
|
|
|
|
and microseconds. E.g. secs:1, millisecs:500, microsecs:100. If any of
|
|
|
|
the components is missing zero is assumed for that field. (Optional)
|
|
|
|
|
|
|
|
=item B<clock_precision_digits>
|
|
|
|
|
2015-04-14 00:29:52 +08:00
|
|
|
Specifies the maximum number of digits, which represent the fraction of
|
2019-09-28 01:17:09 +08:00
|
|
|
seconds, that need to be included in the time field. The trailing zeros
|
2006-02-13 07:11:56 +08:00
|
|
|
must be removed from the time, so there might actually be fewer digits,
|
|
|
|
or no fraction of seconds at all. Supported only on UNIX platforms.
|
|
|
|
The maximum value is 6, default is 0.
|
|
|
|
(Optional)
|
|
|
|
|
|
|
|
=item B<ordering>
|
|
|
|
|
|
|
|
If this option is yes the responses generated by this TSA can always
|
|
|
|
be ordered, even if the time difference between two responses is less
|
|
|
|
than the sum of their accuracies. Default is no. (Optional)
|
|
|
|
|
|
|
|
=item B<tsa_name>
|
|
|
|
|
|
|
|
Set this option to yes if the subject name of the TSA must be included in
|
|
|
|
the TSA name field of the response. Default is no. (Optional)
|
|
|
|
|
|
|
|
=item B<ess_cert_id_chain>
|
|
|
|
|
|
|
|
The SignedData objects created by the TSA always contain the
|
|
|
|
certificate identifier of the signing certificate in a signed
|
2021-03-13 02:45:40 +08:00
|
|
|
attribute (see RFC 2634, Enhanced Security Services).
|
|
|
|
If this variable is set to no, only this signing certificate identifier
|
|
|
|
is included in the SigningCertificate signed attribute.
|
|
|
|
If this variable is set to yes and the B<certs> variable or the B<-chain> option
|
2006-02-13 07:11:56 +08:00
|
|
|
is specified then the certificate identifiers of the chain will also
|
2021-03-13 02:45:40 +08:00
|
|
|
be included, where the B<-chain> option overrides the B<certs> variable.
|
|
|
|
Default is no. (Optional)
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2016-03-02 00:32:10 +08:00
|
|
|
=item B<ess_cert_id_alg>
|
|
|
|
|
|
|
|
This option specifies the hash function to be used to calculate the TSA's
|
2023-08-21 15:29:28 +08:00
|
|
|
public key certificate identifier. Default is sha256. (Optional)
|
2016-03-02 00:32:10 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 EXAMPLES
|
|
|
|
|
|
|
|
All the examples below presume that B<OPENSSL_CONF> is set to a proper
|
2015-04-14 00:29:52 +08:00
|
|
|
configuration file, e.g. the example configuration file
|
2019-10-02 02:19:45 +08:00
|
|
|
F<openssl/apps/openssl.cnf> will do.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Request
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-10-02 02:19:45 +08:00
|
|
|
To create a timestamp request for F<design1.txt> with SHA-256 digest,
|
2019-06-12 18:01:19 +08:00
|
|
|
without nonce and policy, and without requirement for a certificate
|
|
|
|
in the response:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -query -data design1.txt -no_nonce \
|
2016-05-20 20:11:46 +08:00
|
|
|
-out design1.tsq
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To create a similar timestamp request with specifying the message imprint
|
2006-02-13 07:11:56 +08:00
|
|
|
explicitly:
|
|
|
|
|
|
|
|
openssl ts -query -digest b7e5d3f93198b38379852f2c04e78d73abdd0f4b \
|
2016-05-20 20:11:46 +08:00
|
|
|
-no_nonce -out design1.tsq
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
To print the content of the previous request in human readable format:
|
|
|
|
|
|
|
|
openssl ts -query -in design1.tsq -text
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To create a timestamp request which includes the SHA-512 digest
|
2019-10-02 02:19:45 +08:00
|
|
|
of F<design2.txt>, requests the signer certificate and nonce, and
|
2006-02-13 07:11:56 +08:00
|
|
|
specifies a policy id (assuming the tsa_policy1 name is defined in the
|
|
|
|
OID section of the config file):
|
|
|
|
|
2018-12-14 19:10:58 +08:00
|
|
|
openssl ts -query -data design2.txt -sha512 \
|
2016-05-20 20:11:46 +08:00
|
|
|
-tspolicy tsa_policy1 -cert -out design2.tsq
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Response
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
Before generating a response a signing certificate must be created for
|
|
|
|
the TSA that contains the B<timeStamping> critical extended key usage extension
|
2018-07-04 00:45:14 +08:00
|
|
|
without any other key usage extensions. You can add this line to the
|
|
|
|
user certificate section of the config file to generate a proper certificate;
|
|
|
|
|
|
|
|
extendedKeyUsage = critical,timeStamping
|
|
|
|
|
2019-10-02 03:57:00 +08:00
|
|
|
See L<openssl-req(1)>, L<openssl-ca(1)>, and L<openssl-x509(1)> for
|
|
|
|
instructions. The examples below assume that F<cacert.pem> contains the
|
|
|
|
certificate of the CA, F<tsacert.pem> is the signing certificate issued
|
|
|
|
by F<cacert.pem> and F<tsakey.pem> is the private key of the TSA.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To create a timestamp response for a request:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -reply -queryfile design1.tsq -inkey tsakey.pem \
|
2016-05-20 20:11:46 +08:00
|
|
|
-signer tsacert.pem -out design1.tsr
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
If you want to use the settings in the config file you could just write:
|
|
|
|
|
|
|
|
openssl ts -reply -queryfile design1.tsq -out design1.tsr
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To print a timestamp reply to stdout in human readable format:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -reply -in design1.tsr -text
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To create a timestamp token instead of timestamp response:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -reply -queryfile design1.tsq -out design1_token.der -token_out
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To print a timestamp token to stdout in human readable format:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -reply -in design1_token.der -token_in -text -token_out
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To extract the timestamp token from a response:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -reply -in design1.tsr -out design1_token.der -token_out
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To add 'granted' status info to a timestamp token thereby creating a
|
2006-02-13 07:11:56 +08:00
|
|
|
valid response:
|
|
|
|
|
|
|
|
openssl ts -reply -in design1_token.der -token_in -out design1.tsr
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
=head2 Timestamp Verification
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To verify a timestamp reply against a request:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -verify -queryfile design1.tsq -in design1.tsr \
|
2016-05-20 20:11:46 +08:00
|
|
|
-CAfile cacert.pem -untrusted tsacert.pem
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To verify a timestamp reply that includes the certificate chain:
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
openssl ts -verify -queryfile design2.tsq -in design2.tsr \
|
2016-05-20 20:11:46 +08:00
|
|
|
-CAfile cacert.pem
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To verify a timestamp token against the original data file:
|
2024-08-30 22:56:03 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
openssl ts -verify -data design2.txt -in design2.tsr \
|
2016-05-20 20:11:46 +08:00
|
|
|
-CAfile cacert.pem
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
To verify a timestamp token against a message imprint:
|
2024-08-30 22:56:03 +08:00
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
openssl ts -verify -digest b7e5d3f93198b38379852f2c04e78d73abdd0f4b \
|
2016-05-20 20:11:46 +08:00
|
|
|
-in design2.tsr -CAfile cacert.pem
|
2006-02-13 07:11:56 +08:00
|
|
|
|
|
|
|
You could also look at the 'test' directory for more examples.
|
|
|
|
|
|
|
|
=head1 BUGS
|
|
|
|
|
2019-10-25 04:40:11 +08:00
|
|
|
=for openssl foreign manual procmail(1) perl(1)
|
2016-11-11 16:33:47 +08:00
|
|
|
|
2017-04-08 01:37:47 +08:00
|
|
|
=over 2
|
|
|
|
|
|
|
|
=item *
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
No support for timestamps over SMTP, though it is quite easy
|
2015-08-18 03:21:33 +08:00
|
|
|
to implement an automatic e-mail based TSA with L<procmail(1)>
|
|
|
|
and L<perl(1)>. HTTP server support is provided in the form of
|
2006-02-13 07:11:56 +08:00
|
|
|
a separate apache module. HTTP client support is provided by
|
2015-08-18 03:21:33 +08:00
|
|
|
L<tsget(1)>. Pure TCP/IP protocol is not supported.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2017-04-08 01:37:47 +08:00
|
|
|
=item *
|
|
|
|
|
|
|
|
The file containing the last serial number of the TSA is not
|
2006-02-13 07:11:56 +08:00
|
|
|
locked when being read or written. This is a problem if more than one
|
2019-09-28 01:17:09 +08:00
|
|
|
instance of L<openssl(1)> is trying to create a timestamp
|
2006-02-13 07:11:56 +08:00
|
|
|
response at the same time. This is not an issue when using the apache
|
|
|
|
server module, it does proper locking.
|
|
|
|
|
2017-04-08 01:37:47 +08:00
|
|
|
=item *
|
|
|
|
|
|
|
|
Look for the FIXME word in the source files.
|
|
|
|
|
|
|
|
=item *
|
|
|
|
|
|
|
|
The source code should really be reviewed by somebody else, too.
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2017-04-08 01:37:47 +08:00
|
|
|
=item *
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2017-04-08 01:37:47 +08:00
|
|
|
More testing is needed, I have done only some basic tests (see
|
2006-02-13 07:11:56 +08:00
|
|
|
test/testtsa).
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
2019-11-13 23:02:09 +08:00
|
|
|
=head1 HISTORY
|
|
|
|
|
|
|
|
OpenSSL 1.1.1 introduced a new random generator (CSPRNG) with an improved
|
|
|
|
seeding mechanism. The new seeding mechanism makes it unnecessary to
|
|
|
|
define a RANDFILE for saving and restoring randomness. This option is
|
|
|
|
retained mainly for compatibility reasons.
|
|
|
|
|
2020-06-25 09:27:51 +08:00
|
|
|
The B<-engine> option was deprecated in OpenSSL 3.0.
|
|
|
|
|
2006-02-13 07:11:56 +08:00
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2019-08-22 07:04:41 +08:00
|
|
|
L<openssl(1)>,
|
2019-10-25 04:40:11 +08:00
|
|
|
L<tsget(1)>,
|
2019-08-22 07:04:41 +08:00
|
|
|
L<openssl-req(1)>,
|
|
|
|
L<openssl-x509(1)>,
|
|
|
|
L<openssl-ca(1)>,
|
|
|
|
L<openssl-genrsa(1)>,
|
2019-03-07 22:26:34 +08:00
|
|
|
L<config(5)>,
|
|
|
|
L<ossl_store-file(7)>
|
2006-02-13 07:11:56 +08:00
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2024-03-29 22:05:51 +08:00
|
|
|
Copyright 2006-2024 The OpenSSL Project Authors. All Rights Reserved.
|
2016-05-18 23:44:05 +08:00
|
|
|
|
2018-12-06 21:04:11 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-05-18 23:44:05 +08:00
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|