From 6469a1fda3d850c8a73c69269b50147e3285581a Mon Sep 17 00:00:00 2001 From: "Dr. Stephen Henson" Date: Wed, 9 Apr 2008 23:13:49 +0000 Subject: [PATCH] Signed receipt request function documentation. --- doc/crypto/CMS_get1_ReceiptRequest.pod | 68 ++++++++++++++++++++++++++ doc/crypto/CMS_sign_add1_signer.pod | 3 +- 2 files changed, 70 insertions(+), 1 deletion(-) create mode 100644 doc/crypto/CMS_get1_ReceiptRequest.pod diff --git a/doc/crypto/CMS_get1_ReceiptRequest.pod b/doc/crypto/CMS_get1_ReceiptRequest.pod new file mode 100644 index 0000000000..ba9ff9f022 --- /dev/null +++ b/doc/crypto/CMS_get1_ReceiptRequest.pod @@ -0,0 +1,68 @@ +=pod + +=head1 NAME + + CMS_ReceiptRequest_create0, CMS_add1_ReceiptRequest, CMS_get1_ReceiptRequest, CMS_ReceiptRequest_get0_values - CMS signed receipt request functions. + +=head1 SYNOPSIS + + #include + +CMS_ReceiptRequest *CMS_ReceiptRequest_create0(unsigned char *id, int idlen, int allorfirst, STACK_OF(GENERAL_NAMES) *receiptList, STACK_OF(GENERAL_NAMES) *receiptsTo); +int CMS_add1_ReceiptRequest(CMS_SignerInfo *si, CMS_ReceiptRequest *rr); +int CMS_get1_ReceiptRequest(CMS_SignerInfo *si, CMS_ReceiptRequest **prr); +void CMS_ReceiptRequest_get0_values(CMS_ReceiptRequest *rr, ASN1_STRING **pcid, int *pallorfirst, STACK_OF(GENERAL_NAMES) **plist, STACK_OF(GENERAL_NAMES) **prto); + +=head1 DESCRIPTION + +CMS_ReceiptRequest_create0() creates a signed receipt request structure. The +B field is set using B and B, or it is set +to 32 bytes of pseudo random data if B is NULL. If B is NULL +the allOrFirstTier option in B is used and set to the value of +the B parameter. If B is not NULL the B +option in B is used. The B parameter specifies the +B field value. + +The CMS_add1_ReceiptRequest() function adds a signed receipt request B +to SignerInfo strutucre B. + +int CMS_get1_ReceiptRequest() looks for a signed receipt request in B, if +any is found it is decoded and written to B. + +CMS_ReceiptRequest_get0_values() retrieves the values of a receipt request. +The signedContentIdentifier is copied to B. If the B +option of B is used its value is copied to B +otherwise the B field is copied to B. The B +parameter is copied to B. + +=head1 NOTES + +For more details of the meaning of the fields see RFC2634. + +The contents of a signed receipt should only be considered meaningful if the +corresponding CMS_ContentInfo structure can be successfully verified using +CMS_verify(). + +=head1 RETURN VALUES + +CMS_ReceiptRequest_create0() returns a signed receipt request structure or +NULL if an error occurred. + +CMS_add1_ReceiptRequest() returns 1 for success or 0 is an error occurred. + +CMS_get1_ReceiptRequest() returns 1 is a signed receipt request is found and +decoded. It returns 0 if a signed receipt request is not present and -1 if +it is present but malformed. + +=head1 SEE ALSO + +L, L, +L, L +L + +=head1 HISTORY + +CMS_ReceiptRequest_create0(), CMS_add1_ReceiptRequest(), CMS_get1_ReceiptRequest() and CMS_ReceiptRequest_get0_values() were +added to OpenSSL 0.9.8 + +=cut diff --git a/doc/crypto/CMS_sign_add1_signer.pod b/doc/crypto/CMS_sign_add1_signer.pod index ee2f93a8ae..ea49bdca1b 100644 --- a/doc/crypto/CMS_sign_add1_signer.pod +++ b/doc/crypto/CMS_sign_add1_signer.pod @@ -40,7 +40,8 @@ The main purpose of this CMS_sign_add1_signer() is to provide finer control over a CMS signed data structure where the simpler CMS_sign() function defaults are not appropriate. For example if multiple signers or non default digest algorithms are needed. New attributes can also be added using the returned -CMS_SignerInfo struture and the CMS attribute utility functions. +CMS_SignerInfo struture and the CMS attribute utility functions or the +CMS signed receipt request functions. Any of the following flags (ored together) can be passed in the B parameter.