1*e71b7053SJung-uk Kim=pod 2*e71b7053SJung-uk Kim 3*e71b7053SJung-uk Kim=head1 NAME 4*e71b7053SJung-uk Kim 5*e71b7053SJung-uk KimSMIME_write_PKCS7 - convert PKCS#7 structure to S/MIME format 6*e71b7053SJung-uk Kim 7*e71b7053SJung-uk Kim=head1 SYNOPSIS 8*e71b7053SJung-uk Kim 9*e71b7053SJung-uk Kim #include <openssl/pkcs7.h> 10*e71b7053SJung-uk Kim 11*e71b7053SJung-uk Kim int SMIME_write_PKCS7(BIO *out, PKCS7 *p7, BIO *data, int flags); 12*e71b7053SJung-uk Kim 13*e71b7053SJung-uk Kim=head1 DESCRIPTION 14*e71b7053SJung-uk Kim 15*e71b7053SJung-uk KimSMIME_write_PKCS7() adds the appropriate MIME headers to a PKCS#7 16*e71b7053SJung-uk Kimstructure to produce an S/MIME message. 17*e71b7053SJung-uk Kim 18*e71b7053SJung-uk KimB<out> is the BIO to write the data to. B<p7> is the appropriate B<PKCS7> 19*e71b7053SJung-uk Kimstructure. If streaming is enabled then the content must be supplied in the 20*e71b7053SJung-uk KimB<data> argument. B<flags> is an optional set of flags. 21*e71b7053SJung-uk Kim 22*e71b7053SJung-uk Kim=head1 NOTES 23*e71b7053SJung-uk Kim 24*e71b7053SJung-uk KimThe following flags can be passed in the B<flags> parameter. 25*e71b7053SJung-uk Kim 26*e71b7053SJung-uk KimIf B<PKCS7_DETACHED> is set then cleartext signing will be used, 27*e71b7053SJung-uk Kimthis option only makes sense for signedData where B<PKCS7_DETACHED> 28*e71b7053SJung-uk Kimis also set when PKCS7_sign() is also called. 29*e71b7053SJung-uk Kim 30*e71b7053SJung-uk KimIf the B<PKCS7_TEXT> flag is set MIME headers for type B<text/plain> 31*e71b7053SJung-uk Kimare added to the content, this only makes sense if B<PKCS7_DETACHED> 32*e71b7053SJung-uk Kimis also set. 33*e71b7053SJung-uk Kim 34*e71b7053SJung-uk KimIf the B<PKCS7_STREAM> flag is set streaming is performed. This flag should 35*e71b7053SJung-uk Kimonly be set if B<PKCS7_STREAM> was also set in the previous call to 36*e71b7053SJung-uk KimPKCS7_sign() or PKCS7_encrypt(). 37*e71b7053SJung-uk Kim 38*e71b7053SJung-uk KimIf cleartext signing is being used and B<PKCS7_STREAM> not set then 39*e71b7053SJung-uk Kimthe data must be read twice: once to compute the signature in PKCS7_sign() 40*e71b7053SJung-uk Kimand once to output the S/MIME message. 41*e71b7053SJung-uk Kim 42*e71b7053SJung-uk KimIf streaming is performed the content is output in BER format using indefinite 43*e71b7053SJung-uk Kimlength constructed encoding except in the case of signed data with detached 44*e71b7053SJung-uk Kimcontent where the content is absent and DER format is used. 45*e71b7053SJung-uk Kim 46*e71b7053SJung-uk Kim=head1 BUGS 47*e71b7053SJung-uk Kim 48*e71b7053SJung-uk KimSMIME_write_PKCS7() always base64 encodes PKCS#7 structures, there 49*e71b7053SJung-uk Kimshould be an option to disable this. 50*e71b7053SJung-uk Kim 51*e71b7053SJung-uk Kim=head1 RETURN VALUES 52*e71b7053SJung-uk Kim 53*e71b7053SJung-uk KimSMIME_write_PKCS7() returns 1 for success or 0 for failure. 54*e71b7053SJung-uk Kim 55*e71b7053SJung-uk Kim=head1 SEE ALSO 56*e71b7053SJung-uk Kim 57*e71b7053SJung-uk KimL<ERR_get_error(3)>, L<PKCS7_sign(3)>, 58*e71b7053SJung-uk KimL<PKCS7_verify(3)>, L<PKCS7_encrypt(3)> 59*e71b7053SJung-uk KimL<PKCS7_decrypt(3)> 60*e71b7053SJung-uk Kim 61*e71b7053SJung-uk Kim=head1 COPYRIGHT 62*e71b7053SJung-uk Kim 63*e71b7053SJung-uk KimCopyright 2002-2016 The OpenSSL Project Authors. All Rights Reserved. 64*e71b7053SJung-uk Kim 65*e71b7053SJung-uk KimLicensed under the OpenSSL license (the "License"). You may not use 66*e71b7053SJung-uk Kimthis file except in compliance with the License. You can obtain a copy 67*e71b7053SJung-uk Kimin the file LICENSE in the source distribution or at 68*e71b7053SJung-uk KimL<https://www.openssl.org/source/license.html>. 69*e71b7053SJung-uk Kim 70*e71b7053SJung-uk Kim=cut 71