comparison nss/lib/pki/nsspki.h @ 0:1e5118fa0cb1

This is NSS with a Cmake Buildsyste To compile a static NSS library for Windows we've used the Chromium-NSS fork and added a Cmake buildsystem to compile it statically for Windows. See README.chromium for chromium changes and README.trustbridge for our modifications.
author Andre Heinecke <andre.heinecke@intevation.de>
date Mon, 28 Jul 2014 10:47:06 +0200
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:1e5118fa0cb1
1 /* This Source Code Form is subject to the terms of the Mozilla Public
2 * License, v. 2.0. If a copy of the MPL was not distributed with this
3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
4
5 #ifndef NSSPKI_H
6 #define NSSPKI_H
7
8 /*
9 * nsspki.h
10 *
11 * This file prototypes the methods of the top-level PKI objects.
12 */
13
14 #ifndef NSSDEVT_H
15 #include "nssdevt.h"
16 #endif /* NSSDEVT_H */
17
18 #ifndef NSSPKIT_H
19 #include "nsspkit.h"
20 #endif /* NSSPKIT_H */
21
22 #ifndef BASE_H
23 #include "base.h"
24 #endif /* BASE_H */
25
26 PR_BEGIN_EXTERN_C
27
28 /*
29 * A note about interfaces
30 *
31 * Although these APIs are specified in C, a language which does
32 * not have fancy support for abstract interfaces, this library
33 * was designed from an object-oriented perspective. It may be
34 * useful to consider the standard interfaces which went into
35 * the writing of these APIs.
36 *
37 * Basic operations on all objects:
38 * Destroy -- free a pointer to an object
39 * DeleteStoredObject -- delete an object permanently
40 *
41 * Public Key cryptographic operations:
42 * Encrypt
43 * Verify
44 * VerifyRecover
45 * Wrap
46 * Derive
47 *
48 * Private Key cryptographic operations:
49 * IsStillPresent
50 * Decrypt
51 * Sign
52 * SignRecover
53 * Unwrap
54 * Derive
55 *
56 * Symmetric Key cryptographic operations:
57 * IsStillPresent
58 * Encrypt
59 * Decrypt
60 * Sign
61 * SignRecover
62 * Verify
63 * VerifyRecover
64 * Wrap
65 * Unwrap
66 * Derive
67 *
68 */
69
70 /*
71 * NSSCertificate
72 *
73 * These things can do crypto ops like public keys, except that the trust,
74 * usage, and other constraints are checked. These objects are "high-level,"
75 * so trust, usages, etc. are in the form we throw around (client auth,
76 * email signing, etc.). Remember that theoretically another implementation
77 * (think PGP) could be beneath this object.
78 */
79
80 /*
81 * NSSCertificate_Destroy
82 *
83 * Free a pointer to a certificate object.
84 */
85
86 NSS_EXTERN PRStatus
87 NSSCertificate_Destroy
88 (
89 NSSCertificate *c
90 );
91
92 /*
93 * NSSCertificate_DeleteStoredObject
94 *
95 * Permanently remove this certificate from storage. If this is the
96 * only (remaining) certificate corresponding to a private key,
97 * public key, and/or other object; then that object (those objects)
98 * are deleted too.
99 */
100
101 NSS_EXTERN PRStatus
102 NSSCertificate_DeleteStoredObject
103 (
104 NSSCertificate *c,
105 NSSCallback *uhh
106 );
107
108 /*
109 * NSSCertificate_Validate
110 *
111 * Verify that this certificate is trusted, for the specified usage(s),
112 * at the specified time, {word word} the specified policies.
113 */
114
115 NSS_EXTERN PRStatus
116 NSSCertificate_Validate
117 (
118 NSSCertificate *c,
119 NSSTime *timeOpt, /* NULL for "now" */
120 NSSUsage *usage,
121 NSSPolicies *policiesOpt /* NULL for none */
122 );
123
124 /*
125 * NSSCertificate_ValidateCompletely
126 *
127 * Verify that this certificate is trusted. The difference between
128 * this and the previous call is that NSSCertificate_Validate merely
129 * returns success or failure with an appropriate error stack.
130 * However, there may be (and often are) multiple problems with a
131 * certificate. This routine returns an array of errors, specifying
132 * every problem.
133 */
134
135 /*
136 * Return value must be an array of objects, each of which has
137 * an NSSError, and any corresponding certificate (in the chain)
138 * and/or policy.
139 */
140
141 NSS_EXTERN void ** /* void *[] */
142 NSSCertificate_ValidateCompletely
143 (
144 NSSCertificate *c,
145 NSSTime *timeOpt, /* NULL for "now" */
146 NSSUsage *usage,
147 NSSPolicies *policiesOpt, /* NULL for none */
148 void **rvOpt, /* NULL for allocate */
149 PRUint32 rvLimit, /* zero for no limit */
150 NSSArena *arenaOpt /* NULL for heap */
151 );
152
153 /*
154 * NSSCertificate_ValidateAndDiscoverUsagesAndPolicies
155 *
156 * Returns PR_SUCCESS if the certificate is valid for at least something.
157 */
158
159 NSS_EXTERN PRStatus
160 NSSCertificate_ValidateAndDiscoverUsagesAndPolicies
161 (
162 NSSCertificate *c,
163 NSSTime **notBeforeOutOpt,
164 NSSTime **notAfterOutOpt,
165 void *allowedUsages,
166 void *disallowedUsages,
167 void *allowedPolicies,
168 void *disallowedPolicies,
169 /* more args.. work on this fgmr */
170 NSSArena *arenaOpt
171 );
172
173 /*
174 * NSSCertificate_Encode
175 *
176 */
177
178 NSS_EXTERN NSSDER *
179 NSSCertificate_Encode
180 (
181 NSSCertificate *c,
182 NSSDER *rvOpt,
183 NSSArena *arenaOpt
184 );
185
186 /*
187 * NSSCertificate_BuildChain
188 *
189 * This routine returns NSSCertificate *'s for each certificate
190 * in the "chain" starting from the specified one up to and
191 * including the root. The zeroth element in the array is the
192 * specified ("leaf") certificate.
193 *
194 * If statusOpt is supplied, and is returned as PR_FAILURE, possible
195 * error values are:
196 *
197 * NSS_ERROR_CERTIFICATE_ISSUER_NOT_FOUND - the chain is incomplete
198 *
199 */
200
201 extern const NSSError NSS_ERROR_CERTIFICATE_ISSUER_NOT_FOUND;
202
203 NSS_EXTERN NSSCertificate **
204 NSSCertificate_BuildChain
205 (
206 NSSCertificate *c,
207 NSSTime *timeOpt,
208 NSSUsage *usage,
209 NSSPolicies *policiesOpt,
210 NSSCertificate **rvOpt,
211 PRUint32 rvLimit, /* zero for no limit */
212 NSSArena *arenaOpt,
213 PRStatus *statusOpt,
214 NSSTrustDomain *td,
215 NSSCryptoContext *cc
216 );
217
218 /*
219 * NSSCertificate_GetTrustDomain
220 *
221 */
222
223 NSS_EXTERN NSSTrustDomain *
224 NSSCertificate_GetTrustDomain
225 (
226 NSSCertificate *c
227 );
228
229 /*
230 * NSSCertificate_GetToken
231 *
232 * There doesn't have to be one.
233 */
234
235 NSS_EXTERN NSSToken *
236 NSSCertificate_GetToken
237 (
238 NSSCertificate *c,
239 PRStatus *statusOpt
240 );
241
242 /*
243 * NSSCertificate_GetSlot
244 *
245 * There doesn't have to be one.
246 */
247
248 NSS_EXTERN NSSSlot *
249 NSSCertificate_GetSlot
250 (
251 NSSCertificate *c,
252 PRStatus *statusOpt
253 );
254
255 /*
256 * NSSCertificate_GetModule
257 *
258 * There doesn't have to be one.
259 */
260
261 NSS_EXTERN NSSModule *
262 NSSCertificate_GetModule
263 (
264 NSSCertificate *c,
265 PRStatus *statusOpt
266 );
267
268 /*
269 * NSSCertificate_Encrypt
270 *
271 * Encrypt a single chunk of data with the public key corresponding to
272 * this certificate.
273 */
274
275 NSS_EXTERN NSSItem *
276 NSSCertificate_Encrypt
277 (
278 NSSCertificate *c,
279 NSSAlgorithmAndParameters *apOpt,
280 NSSItem *data,
281 NSSTime *timeOpt,
282 NSSUsage *usage,
283 NSSPolicies *policiesOpt,
284 NSSCallback *uhh,
285 NSSItem *rvOpt,
286 NSSArena *arenaOpt
287 );
288
289 /*
290 * NSSCertificate_Verify
291 *
292 */
293
294 NSS_EXTERN PRStatus
295 NSSCertificate_Verify
296 (
297 NSSCertificate *c,
298 NSSAlgorithmAndParameters *apOpt,
299 NSSItem *data,
300 NSSItem *signature,
301 NSSTime *timeOpt,
302 NSSUsage *usage,
303 NSSPolicies *policiesOpt,
304 NSSCallback *uhh
305 );
306
307 /*
308 * NSSCertificate_VerifyRecover
309 *
310 */
311
312 NSS_EXTERN NSSItem *
313 NSSCertificate_VerifyRecover
314 (
315 NSSCertificate *c,
316 NSSAlgorithmAndParameters *apOpt,
317 NSSItem *signature,
318 NSSTime *timeOpt,
319 NSSUsage *usage,
320 NSSPolicies *policiesOpt,
321 NSSCallback *uhh,
322 NSSItem *rvOpt,
323 NSSArena *arenaOpt
324 );
325
326 /*
327 * NSSCertificate_WrapSymmetricKey
328 *
329 * This method tries very hard to to succeed, even in situations
330 * involving sensitive keys and multiple modules.
331 * { relyea: want to add verbiage? }
332 */
333
334 NSS_EXTERN NSSItem *
335 NSSCertificate_WrapSymmetricKey
336 (
337 NSSCertificate *c,
338 NSSAlgorithmAndParameters *apOpt,
339 NSSSymmetricKey *keyToWrap,
340 NSSTime *timeOpt,
341 NSSUsage *usage,
342 NSSPolicies *policiesOpt,
343 NSSCallback *uhh,
344 NSSItem *rvOpt,
345 NSSArena *arenaOpt
346 );
347
348 /*
349 * NSSCertificate_CreateCryptoContext
350 *
351 * Create a crypto context, in this certificate's trust domain, with this
352 * as the distinguished certificate.
353 */
354
355 NSS_EXTERN NSSCryptoContext *
356 NSSCertificate_CreateCryptoContext
357 (
358 NSSCertificate *c,
359 NSSAlgorithmAndParameters *apOpt,
360 NSSTime *timeOpt,
361 NSSUsage *usage,
362 NSSPolicies *policiesOpt,
363 NSSCallback *uhh
364 );
365
366 /*
367 * NSSCertificate_GetPublicKey
368 *
369 * Returns the public key corresponding to this certificate.
370 */
371
372 NSS_EXTERN NSSPublicKey *
373 NSSCertificate_GetPublicKey
374 (
375 NSSCertificate *c
376 );
377
378 /*
379 * NSSCertificate_FindPrivateKey
380 *
381 * Finds and returns the private key corresponding to this certificate,
382 * if it is available.
383 *
384 * { Should this hang off of NSSUserCertificate? }
385 */
386
387 NSS_EXTERN NSSPrivateKey *
388 NSSCertificate_FindPrivateKey
389 (
390 NSSCertificate *c,
391 NSSCallback *uhh
392 );
393
394 /*
395 * NSSCertificate_IsPrivateKeyAvailable
396 *
397 * Returns success if the private key corresponding to this certificate
398 * is available to be used.
399 *
400 * { Should *this* hang off of NSSUserCertificate?? }
401 */
402
403 NSS_EXTERN PRBool
404 NSSCertificate_IsPrivateKeyAvailable
405 (
406 NSSCertificate *c,
407 NSSCallback *uhh,
408 PRStatus *statusOpt
409 );
410
411 /*
412 * If we make NSSUserCertificate not a typedef of NSSCertificate,
413 * then we'll need implementations of the following:
414 *
415 * NSSUserCertificate_Destroy
416 * NSSUserCertificate_DeleteStoredObject
417 * NSSUserCertificate_Validate
418 * NSSUserCertificate_ValidateCompletely
419 * NSSUserCertificate_ValidateAndDiscoverUsagesAndPolicies
420 * NSSUserCertificate_Encode
421 * NSSUserCertificate_BuildChain
422 * NSSUserCertificate_GetTrustDomain
423 * NSSUserCertificate_GetToken
424 * NSSUserCertificate_GetSlot
425 * NSSUserCertificate_GetModule
426 * NSSUserCertificate_GetCryptoContext
427 * NSSUserCertificate_GetPublicKey
428 */
429
430 /*
431 * NSSUserCertificate_IsStillPresent
432 *
433 * Verify that if this certificate lives on a token, that the token
434 * is still present and the certificate still exists. This is a
435 * lightweight call which should be used whenever it should be
436 * verified that the user hasn't perhaps popped out his or her
437 * token and strolled away.
438 */
439
440 NSS_EXTERN PRBool
441 NSSUserCertificate_IsStillPresent
442 (
443 NSSUserCertificate *uc,
444 PRStatus *statusOpt
445 );
446
447 /*
448 * NSSUserCertificate_Decrypt
449 *
450 * Decrypt a single chunk of data with the private key corresponding
451 * to this certificate.
452 */
453
454 NSS_EXTERN NSSItem *
455 NSSUserCertificate_Decrypt
456 (
457 NSSUserCertificate *uc,
458 NSSAlgorithmAndParameters *apOpt,
459 NSSItem *data,
460 NSSTime *timeOpt,
461 NSSUsage *usage,
462 NSSPolicies *policiesOpt,
463 NSSCallback *uhh,
464 NSSItem *rvOpt,
465 NSSArena *arenaOpt
466 );
467
468 /*
469 * NSSUserCertificate_Sign
470 *
471 */
472
473 NSS_EXTERN NSSItem *
474 NSSUserCertificate_Sign
475 (
476 NSSUserCertificate *uc,
477 NSSAlgorithmAndParameters *apOpt,
478 NSSItem *data,
479 NSSTime *timeOpt,
480 NSSUsage *usage,
481 NSSPolicies *policiesOpt,
482 NSSCallback *uhh,
483 NSSItem *rvOpt,
484 NSSArena *arenaOpt
485 );
486
487 /*
488 * NSSUserCertificate_SignRecover
489 *
490 */
491
492 NSS_EXTERN NSSItem *
493 NSSUserCertificate_SignRecover
494 (
495 NSSUserCertificate *uc,
496 NSSAlgorithmAndParameters *apOpt,
497 NSSItem *data,
498 NSSTime *timeOpt,
499 NSSUsage *usage,
500 NSSPolicies *policiesOpt,
501 NSSCallback *uhh,
502 NSSItem *rvOpt,
503 NSSArena *arenaOpt
504 );
505
506 /*
507 * NSSUserCertificate_UnwrapSymmetricKey
508 *
509 */
510
511 NSS_EXTERN NSSSymmetricKey *
512 NSSUserCertificate_UnwrapSymmetricKey
513 (
514 NSSUserCertificate *uc,
515 NSSAlgorithmAndParameters *apOpt,
516 NSSItem *wrappedKey,
517 NSSTime *timeOpt,
518 NSSUsage *usage,
519 NSSPolicies *policiesOpt,
520 NSSCallback *uhh,
521 NSSItem *rvOpt,
522 NSSArena *arenaOpt
523 );
524
525 /*
526 * NSSUserCertificate_DeriveSymmetricKey
527 *
528 */
529
530 NSS_EXTERN NSSSymmetricKey *
531 NSSUserCertificate_DeriveSymmetricKey
532 (
533 NSSUserCertificate *uc, /* provides private key */
534 NSSCertificate *c, /* provides public key */
535 NSSAlgorithmAndParameters *apOpt,
536 NSSOID *target,
537 PRUint32 keySizeOpt, /* zero for best allowed */
538 NSSOperations operations,
539 NSSCallback *uhh
540 );
541
542 /* filter-certs function(s) */
543
544 /**
545 ** fgmr -- trust objects
546 **/
547
548 /*
549 * NSSPrivateKey
550 *
551 */
552
553 /*
554 * NSSPrivateKey_Destroy
555 *
556 * Free a pointer to a private key object.
557 */
558
559 NSS_EXTERN PRStatus
560 NSSPrivateKey_Destroy
561 (
562 NSSPrivateKey *vk
563 );
564
565 /*
566 * NSSPrivateKey_DeleteStoredObject
567 *
568 * Permanently remove this object, and any related objects (such as the
569 * certificates corresponding to this key).
570 */
571
572 NSS_EXTERN PRStatus
573 NSSPrivateKey_DeleteStoredObject
574 (
575 NSSPrivateKey *vk,
576 NSSCallback *uhh
577 );
578
579 /*
580 * NSSPrivateKey_GetSignatureLength
581 *
582 */
583
584 NSS_EXTERN PRUint32
585 NSSPrivateKey_GetSignatureLength
586 (
587 NSSPrivateKey *vk
588 );
589
590 /*
591 * NSSPrivateKey_GetPrivateModulusLength
592 *
593 */
594
595 NSS_EXTERN PRUint32
596 NSSPrivateKey_GetPrivateModulusLength
597 (
598 NSSPrivateKey *vk
599 );
600
601 /*
602 * NSSPrivateKey_IsStillPresent
603 *
604 */
605
606 NSS_EXTERN PRBool
607 NSSPrivateKey_IsStillPresent
608 (
609 NSSPrivateKey *vk,
610 PRStatus *statusOpt
611 );
612
613 /*
614 * NSSPrivateKey_Encode
615 *
616 */
617
618 NSS_EXTERN NSSItem *
619 NSSPrivateKey_Encode
620 (
621 NSSPrivateKey *vk,
622 NSSAlgorithmAndParameters *ap,
623 NSSItem *passwordOpt, /* NULL will cause a callback; "" for no password */
624 NSSCallback *uhhOpt,
625 NSSItem *rvOpt,
626 NSSArena *arenaOpt
627 );
628
629 /*
630 * NSSPrivateKey_GetTrustDomain
631 *
632 * There doesn't have to be one.
633 */
634
635 NSS_EXTERN NSSTrustDomain *
636 NSSPrivateKey_GetTrustDomain
637 (
638 NSSPrivateKey *vk,
639 PRStatus *statusOpt
640 );
641
642 /*
643 * NSSPrivateKey_GetToken
644 *
645 */
646
647 NSS_EXTERN NSSToken *
648 NSSPrivateKey_GetToken
649 (
650 NSSPrivateKey *vk
651 );
652
653 /*
654 * NSSPrivateKey_GetSlot
655 *
656 */
657
658 NSS_EXTERN NSSSlot *
659 NSSPrivateKey_GetSlot
660 (
661 NSSPrivateKey *vk
662 );
663
664 /*
665 * NSSPrivateKey_GetModule
666 *
667 */
668
669 NSS_EXTERN NSSModule *
670 NSSPrivateKey_GetModule
671 (
672 NSSPrivateKey *vk
673 );
674
675 /*
676 * NSSPrivateKey_Decrypt
677 *
678 */
679
680 NSS_EXTERN NSSItem *
681 NSSPrivateKey_Decrypt
682 (
683 NSSPrivateKey *vk,
684 NSSAlgorithmAndParameters *apOpt,
685 NSSItem *encryptedData,
686 NSSCallback *uhh,
687 NSSItem *rvOpt,
688 NSSArena *arenaOpt
689 );
690
691 /*
692 * NSSPrivateKey_Sign
693 *
694 */
695
696 NSS_EXTERN NSSItem *
697 NSSPrivateKey_Sign
698 (
699 NSSPrivateKey *vk,
700 NSSAlgorithmAndParameters *apOpt,
701 NSSItem *data,
702 NSSCallback *uhh,
703 NSSItem *rvOpt,
704 NSSArena *arenaOpt
705 );
706
707 /*
708 * NSSPrivateKey_SignRecover
709 *
710 */
711
712 NSS_EXTERN NSSItem *
713 NSSPrivateKey_SignRecover
714 (
715 NSSPrivateKey *vk,
716 NSSAlgorithmAndParameters *apOpt,
717 NSSItem *data,
718 NSSCallback *uhh,
719 NSSItem *rvOpt,
720 NSSArena *arenaOpt
721 );
722
723 /*
724 * NSSPrivateKey_UnwrapSymmetricKey
725 *
726 */
727
728 NSS_EXTERN NSSSymmetricKey *
729 NSSPrivateKey_UnwrapSymmetricKey
730 (
731 NSSPrivateKey *vk,
732 NSSAlgorithmAndParameters *apOpt,
733 NSSItem *wrappedKey,
734 NSSCallback *uhh
735 );
736
737 /*
738 * NSSPrivateKey_DeriveSymmetricKey
739 *
740 */
741
742 NSS_EXTERN NSSSymmetricKey *
743 NSSPrivateKey_DeriveSymmetricKey
744 (
745 NSSPrivateKey *vk,
746 NSSPublicKey *bk,
747 NSSAlgorithmAndParameters *apOpt,
748 NSSOID *target,
749 PRUint32 keySizeOpt, /* zero for best allowed */
750 NSSOperations operations,
751 NSSCallback *uhh
752 );
753
754 /*
755 * NSSPrivateKey_FindPublicKey
756 *
757 */
758
759 NSS_EXTERN NSSPublicKey *
760 NSSPrivateKey_FindPublicKey
761 (
762 NSSPrivateKey *vk
763 /* { don't need the callback here, right? } */
764 );
765
766 /*
767 * NSSPrivateKey_CreateCryptoContext
768 *
769 * Create a crypto context, in this key's trust domain,
770 * with this as the distinguished private key.
771 */
772
773 NSS_EXTERN NSSCryptoContext *
774 NSSPrivateKey_CreateCryptoContext
775 (
776 NSSPrivateKey *vk,
777 NSSAlgorithmAndParameters *apOpt,
778 NSSCallback *uhh
779 );
780
781 /*
782 * NSSPrivateKey_FindCertificates
783 *
784 * Note that there may be more than one certificate for this
785 * private key. { FilterCertificates function to further
786 * reduce the list. }
787 */
788
789 NSS_EXTERN NSSCertificate **
790 NSSPrivateKey_FindCertificates
791 (
792 NSSPrivateKey *vk,
793 NSSCertificate *rvOpt[],
794 PRUint32 maximumOpt, /* 0 for no max */
795 NSSArena *arenaOpt
796 );
797
798 /*
799 * NSSPrivateKey_FindBestCertificate
800 *
801 * The parameters for this function will depend on what the users
802 * need. This is just a starting point.
803 */
804
805 NSS_EXTERN NSSCertificate *
806 NSSPrivateKey_FindBestCertificate
807 (
808 NSSPrivateKey *vk,
809 NSSTime *timeOpt,
810 NSSUsage *usageOpt,
811 NSSPolicies *policiesOpt
812 );
813
814 /*
815 * NSSPublicKey
816 *
817 * Once you generate, find, or derive one of these, you can use it
818 * to perform (simple) cryptographic operations. Though there may
819 * be certificates associated with these public keys, they are not
820 * verified.
821 */
822
823 /*
824 * NSSPublicKey_Destroy
825 *
826 * Free a pointer to a public key object.
827 */
828
829 NSS_EXTERN PRStatus
830 NSSPublicKey_Destroy
831 (
832 NSSPublicKey *bk
833 );
834
835 /*
836 * NSSPublicKey_DeleteStoredObject
837 *
838 * Permanently remove this object, and any related objects (such as the
839 * corresponding private keys and certificates).
840 */
841
842 NSS_EXTERN PRStatus
843 NSSPublicKey_DeleteStoredObject
844 (
845 NSSPublicKey *bk,
846 NSSCallback *uhh
847 );
848
849 /*
850 * NSSPublicKey_Encode
851 *
852 */
853
854 NSS_EXTERN NSSItem *
855 NSSPublicKey_Encode
856 (
857 NSSPublicKey *bk,
858 NSSAlgorithmAndParameters *ap,
859 NSSCallback *uhhOpt,
860 NSSItem *rvOpt,
861 NSSArena *arenaOpt
862 );
863
864 /*
865 * NSSPublicKey_GetTrustDomain
866 *
867 * There doesn't have to be one.
868 */
869
870 NSS_EXTERN NSSTrustDomain *
871 NSSPublicKey_GetTrustDomain
872 (
873 NSSPublicKey *bk,
874 PRStatus *statusOpt
875 );
876
877 /*
878 * NSSPublicKey_GetToken
879 *
880 * There doesn't have to be one.
881 */
882
883 NSS_EXTERN NSSToken *
884 NSSPublicKey_GetToken
885 (
886 NSSPublicKey *bk,
887 PRStatus *statusOpt
888 );
889
890 /*
891 * NSSPublicKey_GetSlot
892 *
893 * There doesn't have to be one.
894 */
895
896 NSS_EXTERN NSSSlot *
897 NSSPublicKey_GetSlot
898 (
899 NSSPublicKey *bk,
900 PRStatus *statusOpt
901 );
902
903 /*
904 * NSSPublicKey_GetModule
905 *
906 * There doesn't have to be one.
907 */
908
909 NSS_EXTERN NSSModule *
910 NSSPublicKey_GetModule
911 (
912 NSSPublicKey *bk,
913 PRStatus *statusOpt
914 );
915
916 /*
917 * NSSPublicKey_Encrypt
918 *
919 * Encrypt a single chunk of data with the public key corresponding to
920 * this certificate.
921 */
922
923 NSS_EXTERN NSSItem *
924 NSSPublicKey_Encrypt
925 (
926 NSSPublicKey *bk,
927 NSSAlgorithmAndParameters *apOpt,
928 NSSItem *data,
929 NSSCallback *uhh,
930 NSSItem *rvOpt,
931 NSSArena *arenaOpt
932 );
933
934 /*
935 * NSSPublicKey_Verify
936 *
937 */
938
939 NSS_EXTERN PRStatus
940 NSSPublicKey_Verify
941 (
942 NSSPublicKey *bk,
943 NSSAlgorithmAndParameters *apOpt,
944 NSSItem *data,
945 NSSItem *signature,
946 NSSCallback *uhh
947 );
948
949 /*
950 * NSSPublicKey_VerifyRecover
951 *
952 */
953
954 NSS_EXTERN NSSItem *
955 NSSPublicKey_VerifyRecover
956 (
957 NSSPublicKey *bk,
958 NSSAlgorithmAndParameters *apOpt,
959 NSSItem *signature,
960 NSSCallback *uhh,
961 NSSItem *rvOpt,
962 NSSArena *arenaOpt
963 );
964
965 /*
966 * NSSPublicKey_WrapSymmetricKey
967 *
968 */
969
970 NSS_EXTERN NSSItem *
971 NSSPublicKey_WrapSymmetricKey
972 (
973 NSSPublicKey *bk,
974 NSSAlgorithmAndParameters *apOpt,
975 NSSSymmetricKey *keyToWrap,
976 NSSCallback *uhh,
977 NSSItem *rvOpt,
978 NSSArena *arenaOpt
979 );
980
981 /*
982 * NSSPublicKey_CreateCryptoContext
983 *
984 * Create a crypto context, in this key's trust domain, with this
985 * as the distinguished public key.
986 */
987
988 NSS_EXTERN NSSCryptoContext *
989 NSSPublicKey_CreateCryptoContext
990 (
991 NSSPublicKey *bk,
992 NSSAlgorithmAndParameters *apOpt,
993 NSSCallback *uhh
994 );
995
996 /*
997 * NSSPublicKey_FindCertificates
998 *
999 * Note that there may be more than one certificate for this
1000 * public key. The current implementation may not find every
1001 * last certificate available for this public key: that would
1002 * involve trolling e.g. huge ldap databases, which will be
1003 * grossly inefficient and not generally useful.
1004 * { FilterCertificates function to further reduce the list }
1005 */
1006
1007 NSS_EXTERN NSSCertificate **
1008 NSSPublicKey_FindCertificates
1009 (
1010 NSSPublicKey *bk,
1011 NSSCertificate *rvOpt[],
1012 PRUint32 maximumOpt, /* 0 for no max */
1013 NSSArena *arenaOpt
1014 );
1015
1016 /*
1017 * NSSPrivateKey_FindBestCertificate
1018 *
1019 * The parameters for this function will depend on what the users
1020 * need. This is just a starting point.
1021 */
1022
1023 NSS_EXTERN NSSCertificate *
1024 NSSPublicKey_FindBestCertificate
1025 (
1026 NSSPublicKey *bk,
1027 NSSTime *timeOpt,
1028 NSSUsage *usageOpt,
1029 NSSPolicies *policiesOpt
1030 );
1031
1032 /*
1033 * NSSPublicKey_FindPrivateKey
1034 *
1035 */
1036
1037 NSS_EXTERN NSSPrivateKey *
1038 NSSPublicKey_FindPrivateKey
1039 (
1040 NSSPublicKey *bk,
1041 NSSCallback *uhh
1042 );
1043
1044 /*
1045 * NSSSymmetricKey
1046 *
1047 */
1048
1049 /*
1050 * NSSSymmetricKey_Destroy
1051 *
1052 * Free a pointer to a symmetric key object.
1053 */
1054
1055 NSS_EXTERN PRStatus
1056 NSSSymmetricKey_Destroy
1057 (
1058 NSSSymmetricKey *mk
1059 );
1060
1061 /*
1062 * NSSSymmetricKey_DeleteStoredObject
1063 *
1064 * Permanently remove this object.
1065 */
1066
1067 NSS_EXTERN PRStatus
1068 NSSSymmetricKey_DeleteStoredObject
1069 (
1070 NSSSymmetricKey *mk,
1071 NSSCallback *uhh
1072 );
1073
1074 /*
1075 * NSSSymmetricKey_GetKeyLength
1076 *
1077 */
1078
1079 NSS_EXTERN PRUint32
1080 NSSSymmetricKey_GetKeyLength
1081 (
1082 NSSSymmetricKey *mk
1083 );
1084
1085 /*
1086 * NSSSymmetricKey_GetKeyStrength
1087 *
1088 */
1089
1090 NSS_EXTERN PRUint32
1091 NSSSymmetricKey_GetKeyStrength
1092 (
1093 NSSSymmetricKey *mk
1094 );
1095
1096 /*
1097 * NSSSymmetricKey_IsStillPresent
1098 *
1099 */
1100
1101 NSS_EXTERN PRStatus
1102 NSSSymmetricKey_IsStillPresent
1103 (
1104 NSSSymmetricKey *mk
1105 );
1106
1107 /*
1108 * NSSSymmetricKey_GetTrustDomain
1109 *
1110 * There doesn't have to be one.
1111 */
1112
1113 NSS_EXTERN NSSTrustDomain *
1114 NSSSymmetricKey_GetTrustDomain
1115 (
1116 NSSSymmetricKey *mk,
1117 PRStatus *statusOpt
1118 );
1119
1120 /*
1121 * NSSSymmetricKey_GetToken
1122 *
1123 * There doesn't have to be one.
1124 */
1125
1126 NSS_EXTERN NSSToken *
1127 NSSSymmetricKey_GetToken
1128 (
1129 NSSSymmetricKey *mk,
1130 PRStatus *statusOpt
1131 );
1132
1133 /*
1134 * NSSSymmetricKey_GetSlot
1135 *
1136 * There doesn't have to be one.
1137 */
1138
1139 NSS_EXTERN NSSSlot *
1140 NSSSymmetricKey_GetSlot
1141 (
1142 NSSSymmetricKey *mk,
1143 PRStatus *statusOpt
1144 );
1145
1146 /*
1147 * NSSSymmetricKey_GetModule
1148 *
1149 * There doesn't have to be one.
1150 */
1151
1152 NSS_EXTERN NSSModule *
1153 NSSSymmetricKey_GetModule
1154 (
1155 NSSSymmetricKey *mk,
1156 PRStatus *statusOpt
1157 );
1158
1159 /*
1160 * NSSSymmetricKey_Encrypt
1161 *
1162 */
1163
1164 NSS_EXTERN NSSItem *
1165 NSSSymmetricKey_Encrypt
1166 (
1167 NSSSymmetricKey *mk,
1168 NSSAlgorithmAndParameters *apOpt,
1169 NSSItem *data,
1170 NSSCallback *uhh,
1171 NSSItem *rvOpt,
1172 NSSArena *arenaOpt
1173 );
1174
1175 /*
1176 * NSSSymmetricKey_Decrypt
1177 *
1178 */
1179
1180 NSS_EXTERN NSSItem *
1181 NSSSymmetricKey_Decrypt
1182 (
1183 NSSSymmetricKey *mk,
1184 NSSAlgorithmAndParameters *apOpt,
1185 NSSItem *encryptedData,
1186 NSSCallback *uhh,
1187 NSSItem *rvOpt,
1188 NSSArena *arenaOpt
1189 );
1190
1191 /*
1192 * NSSSymmetricKey_Sign
1193 *
1194 */
1195
1196 NSS_EXTERN NSSItem *
1197 NSSSymmetricKey_Sign
1198 (
1199 NSSSymmetricKey *mk,
1200 NSSAlgorithmAndParameters *apOpt,
1201 NSSItem *data,
1202 NSSCallback *uhh,
1203 NSSItem *rvOpt,
1204 NSSArena *arenaOpt
1205 );
1206
1207 /*
1208 * NSSSymmetricKey_SignRecover
1209 *
1210 */
1211
1212 NSS_EXTERN NSSItem *
1213 NSSSymmetricKey_SignRecover
1214 (
1215 NSSSymmetricKey *mk,
1216 NSSAlgorithmAndParameters *apOpt,
1217 NSSItem *data,
1218 NSSCallback *uhh,
1219 NSSItem *rvOpt,
1220 NSSArena *arenaOpt
1221 );
1222
1223 /*
1224 * NSSSymmetricKey_Verify
1225 *
1226 */
1227
1228 NSS_EXTERN PRStatus
1229 NSSSymmetricKey_Verify
1230 (
1231 NSSSymmetricKey *mk,
1232 NSSAlgorithmAndParameters *apOpt,
1233 NSSItem *data,
1234 NSSItem *signature,
1235 NSSCallback *uhh
1236 );
1237
1238 /*
1239 * NSSSymmetricKey_VerifyRecover
1240 *
1241 */
1242
1243 NSS_EXTERN NSSItem *
1244 NSSSymmetricKey_VerifyRecover
1245 (
1246 NSSSymmetricKey *mk,
1247 NSSAlgorithmAndParameters *apOpt,
1248 NSSItem *signature,
1249 NSSCallback *uhh,
1250 NSSItem *rvOpt,
1251 NSSArena *arenaOpt
1252 );
1253
1254 /*
1255 * NSSSymmetricKey_WrapSymmetricKey
1256 *
1257 */
1258
1259 NSS_EXTERN NSSItem *
1260 NSSSymmetricKey_WrapSymmetricKey
1261 (
1262 NSSSymmetricKey *wrappingKey,
1263 NSSAlgorithmAndParameters *apOpt,
1264 NSSSymmetricKey *keyToWrap,
1265 NSSCallback *uhh,
1266 NSSItem *rvOpt,
1267 NSSArena *arenaOpt
1268 );
1269
1270 /*
1271 * NSSSymmetricKey_WrapPrivateKey
1272 *
1273 */
1274
1275 NSS_EXTERN NSSItem *
1276 NSSSymmetricKey_WrapPrivateKey
1277 (
1278 NSSSymmetricKey *wrappingKey,
1279 NSSAlgorithmAndParameters *apOpt,
1280 NSSPrivateKey *keyToWrap,
1281 NSSCallback *uhh,
1282 NSSItem *rvOpt,
1283 NSSArena *arenaOpt
1284 );
1285
1286 /*
1287 * NSSSymmetricKey_UnwrapSymmetricKey
1288 *
1289 */
1290
1291 NSS_EXTERN NSSSymmetricKey *
1292 NSSSymmetricKey_UnwrapSymmetricKey
1293 (
1294 NSSSymmetricKey *wrappingKey,
1295 NSSAlgorithmAndParameters *apOpt,
1296 NSSItem *wrappedKey,
1297 NSSOID *target,
1298 PRUint32 keySizeOpt,
1299 NSSOperations operations,
1300 NSSCallback *uhh
1301 );
1302
1303 /*
1304 * NSSSymmetricKey_UnwrapPrivateKey
1305 *
1306 */
1307
1308 NSS_EXTERN NSSPrivateKey *
1309 NSSSymmetricKey_UnwrapPrivateKey
1310 (
1311 NSSSymmetricKey *wrappingKey,
1312 NSSAlgorithmAndParameters *apOpt,
1313 NSSItem *wrappedKey,
1314 NSSUTF8 *labelOpt,
1315 NSSItem *keyIDOpt,
1316 PRBool persistant,
1317 PRBool sensitive,
1318 NSSToken *destinationOpt,
1319 NSSCallback *uhh
1320 );
1321
1322 /*
1323 * NSSSymmetricKey_DeriveSymmetricKey
1324 *
1325 */
1326
1327 NSS_EXTERN NSSSymmetricKey *
1328 NSSSymmetricKey_DeriveSymmetricKey
1329 (
1330 NSSSymmetricKey *originalKey,
1331 NSSAlgorithmAndParameters *apOpt,
1332 NSSOID *target,
1333 PRUint32 keySizeOpt,
1334 NSSOperations operations,
1335 NSSCallback *uhh
1336 );
1337
1338 /*
1339 * NSSSymmetricKey_CreateCryptoContext
1340 *
1341 * Create a crypto context, in this key's trust domain,
1342 * with this as the distinguished symmetric key.
1343 */
1344
1345 NSS_EXTERN NSSCryptoContext *
1346 NSSSymmetricKey_CreateCryptoContext
1347 (
1348 NSSSymmetricKey *mk,
1349 NSSAlgorithmAndParameters *apOpt,
1350 NSSCallback *uhh
1351 );
1352
1353 /*
1354 * NSSTrustDomain
1355 *
1356 */
1357
1358 /*
1359 * NSSTrustDomain_Create
1360 *
1361 * This creates a trust domain, optionally with an initial cryptoki
1362 * module. If the module name is not null, the module is loaded if
1363 * needed (using the uriOpt argument), and initialized with the
1364 * opaqueOpt argument. If mumble mumble priority settings, then
1365 * module-specification objects in the module can cause the loading
1366 * and initialization of further modules.
1367 *
1368 * The uriOpt is defined to take a URI. At present, we only
1369 * support file: URLs pointing to platform-native shared libraries.
1370 * However, by specifying this as a URI, this keeps open the
1371 * possibility of supporting other, possibly remote, resources.
1372 *
1373 * The "reserved" arguments is held for when we figure out the
1374 * module priority stuff.
1375 */
1376
1377 NSS_EXTERN NSSTrustDomain *
1378 NSSTrustDomain_Create
1379 (
1380 NSSUTF8 *moduleOpt,
1381 NSSUTF8 *uriOpt,
1382 NSSUTF8 *opaqueOpt,
1383 void *reserved
1384 );
1385
1386 /*
1387 * NSSTrustDomain_Destroy
1388 *
1389 */
1390
1391 NSS_EXTERN PRStatus
1392 NSSTrustDomain_Destroy
1393 (
1394 NSSTrustDomain *td
1395 );
1396
1397 /*
1398 * NSSTrustDomain_SetDefaultCallback
1399 *
1400 */
1401
1402 NSS_EXTERN PRStatus
1403 NSSTrustDomain_SetDefaultCallback
1404 (
1405 NSSTrustDomain *td,
1406 NSSCallback *newCallback,
1407 NSSCallback **oldCallbackOpt
1408 );
1409
1410 /*
1411 * NSSTrustDomain_GetDefaultCallback
1412 *
1413 */
1414
1415 NSS_EXTERN NSSCallback *
1416 NSSTrustDomain_GetDefaultCallback
1417 (
1418 NSSTrustDomain *td,
1419 PRStatus *statusOpt
1420 );
1421
1422 /*
1423 * Default policies?
1424 * Default usage?
1425 * Default time, for completeness?
1426 */
1427
1428 /*
1429 * NSSTrustDomain_LoadModule
1430 *
1431 */
1432
1433 NSS_EXTERN PRStatus
1434 NSSTrustDomain_LoadModule
1435 (
1436 NSSTrustDomain *td,
1437 NSSUTF8 *moduleOpt,
1438 NSSUTF8 *uriOpt,
1439 NSSUTF8 *opaqueOpt,
1440 void *reserved
1441 );
1442
1443 /*
1444 * NSSTrustDomain_AddModule
1445 * NSSTrustDomain_AddSlot
1446 * NSSTrustDomain_UnloadModule
1447 * Managing modules, slots, tokens; priorities;
1448 * Traversing all of the above
1449 * this needs more work
1450 */
1451
1452 /*
1453 * NSSTrustDomain_DisableToken
1454 *
1455 */
1456
1457 NSS_EXTERN PRStatus
1458 NSSTrustDomain_DisableToken
1459 (
1460 NSSTrustDomain *td,
1461 NSSToken *token,
1462 NSSError why
1463 );
1464
1465 /*
1466 * NSSTrustDomain_EnableToken
1467 *
1468 */
1469
1470 NSS_EXTERN PRStatus
1471 NSSTrustDomain_EnableToken
1472 (
1473 NSSTrustDomain *td,
1474 NSSToken *token
1475 );
1476
1477 /*
1478 * NSSTrustDomain_IsTokenEnabled
1479 *
1480 * If disabled, "why" is always on the error stack.
1481 * The optional argument is just for convenience.
1482 */
1483
1484 NSS_EXTERN PRStatus
1485 NSSTrustDomain_IsTokenEnabled
1486 (
1487 NSSTrustDomain *td,
1488 NSSToken *token,
1489 NSSError *whyOpt
1490 );
1491
1492 /*
1493 * NSSTrustDomain_FindSlotByName
1494 *
1495 */
1496
1497 NSS_EXTERN NSSSlot *
1498 NSSTrustDomain_FindSlotByName
1499 (
1500 NSSTrustDomain *td,
1501 NSSUTF8 *slotName
1502 );
1503
1504 /*
1505 * NSSTrustDomain_FindTokenByName
1506 *
1507 */
1508
1509 NSS_EXTERN NSSToken *
1510 NSSTrustDomain_FindTokenByName
1511 (
1512 NSSTrustDomain *td,
1513 NSSUTF8 *tokenName
1514 );
1515
1516 /*
1517 * NSSTrustDomain_FindTokenBySlotName
1518 *
1519 */
1520
1521 NSS_EXTERN NSSToken *
1522 NSSTrustDomain_FindTokenBySlotName
1523 (
1524 NSSTrustDomain *td,
1525 NSSUTF8 *slotName
1526 );
1527
1528 /*
1529 * NSSTrustDomain_FindBestTokenForAlgorithm
1530 *
1531 */
1532
1533 NSS_EXTERN NSSToken *
1534 NSSTrustDomain_FindTokenForAlgorithm
1535 (
1536 NSSTrustDomain *td,
1537 NSSOID *algorithm
1538 );
1539
1540 /*
1541 * NSSTrustDomain_FindBestTokenForAlgorithms
1542 *
1543 */
1544
1545 NSS_EXTERN NSSToken *
1546 NSSTrustDomain_FindBestTokenForAlgorithms
1547 (
1548 NSSTrustDomain *td,
1549 NSSOID *algorithms[], /* may be null-terminated */
1550 PRUint32 nAlgorithmsOpt /* limits the array if nonzero */
1551 );
1552
1553 /*
1554 * NSSTrustDomain_Login
1555 *
1556 */
1557
1558 NSS_EXTERN PRStatus
1559 NSSTrustDomain_Login
1560 (
1561 NSSTrustDomain *td,
1562 NSSCallback *uhhOpt
1563 );
1564
1565 /*
1566 * NSSTrustDomain_Logout
1567 *
1568 */
1569
1570 NSS_EXTERN PRStatus
1571 NSSTrustDomain_Logout
1572 (
1573 NSSTrustDomain *td
1574 );
1575
1576 /* Importing things */
1577
1578 /*
1579 * NSSTrustDomain_ImportCertificate
1580 *
1581 * The implementation will pull some data out of the certificate
1582 * (e.g. e-mail address) for use in pkcs#11 object attributes.
1583 */
1584
1585 NSS_EXTERN NSSCertificate *
1586 NSSTrustDomain_ImportCertificate
1587 (
1588 NSSTrustDomain *td,
1589 NSSCertificate *c
1590 );
1591
1592 /*
1593 * NSSTrustDomain_ImportPKIXCertificate
1594 *
1595 */
1596
1597 NSS_EXTERN NSSCertificate *
1598 NSSTrustDomain_ImportPKIXCertificate
1599 (
1600 NSSTrustDomain *td,
1601 /* declared as a struct until these "data types" are defined */
1602 struct NSSPKIXCertificateStr *pc
1603 );
1604
1605 /*
1606 * NSSTrustDomain_ImportEncodedCertificate
1607 *
1608 * Imports any type of certificate we support.
1609 */
1610
1611 NSS_EXTERN NSSCertificate *
1612 NSSTrustDomain_ImportEncodedCertificate
1613 (
1614 NSSTrustDomain *td,
1615 NSSBER *ber
1616 );
1617
1618 /*
1619 * NSSTrustDomain_ImportEncodedCertificateChain
1620 *
1621 * If you just want the leaf, pass in a maximum of one.
1622 */
1623
1624 NSS_EXTERN NSSCertificate **
1625 NSSTrustDomain_ImportEncodedCertificateChain
1626 (
1627 NSSTrustDomain *td,
1628 NSSBER *ber,
1629 NSSCertificate *rvOpt[],
1630 PRUint32 maximumOpt, /* 0 for no max */
1631 NSSArena *arenaOpt
1632 );
1633
1634 /*
1635 * NSSTrustDomain_ImportEncodedPrivateKey
1636 *
1637 */
1638
1639 NSS_EXTERN NSSPrivateKey *
1640 NSSTrustDomain_ImportEncodedPrivateKey
1641 (
1642 NSSTrustDomain *td,
1643 NSSBER *ber,
1644 NSSItem *passwordOpt, /* NULL will cause a callback */
1645 NSSCallback *uhhOpt,
1646 NSSToken *destination
1647 );
1648
1649 /*
1650 * NSSTrustDomain_ImportEncodedPublicKey
1651 *
1652 */
1653
1654 NSS_EXTERN NSSPublicKey *
1655 NSSTrustDomain_ImportEncodedPublicKey
1656 (
1657 NSSTrustDomain *td,
1658 NSSBER *ber
1659 );
1660
1661 /* Other importations: S/MIME capabilities */
1662
1663 /*
1664 * NSSTrustDomain_FindBestCertificateByNickname
1665 *
1666 */
1667
1668 NSS_EXTERN NSSCertificate *
1669 NSSTrustDomain_FindBestCertificateByNickname
1670 (
1671 NSSTrustDomain *td,
1672 const NSSUTF8 *name,
1673 NSSTime *timeOpt, /* NULL for "now" */
1674 NSSUsage *usage,
1675 NSSPolicies *policiesOpt /* NULL for none */
1676 );
1677
1678 /*
1679 * NSSTrustDomain_FindCertificatesByNickname
1680 *
1681 */
1682
1683 NSS_EXTERN NSSCertificate **
1684 NSSTrustDomain_FindCertificatesByNickname
1685 (
1686 NSSTrustDomain *td,
1687 NSSUTF8 *name,
1688 NSSCertificate *rvOpt[],
1689 PRUint32 maximumOpt, /* 0 for no max */
1690 NSSArena *arenaOpt
1691 );
1692
1693 /*
1694 * NSSTrustDomain_FindCertificateByIssuerAndSerialNumber
1695 *
1696 */
1697
1698 NSS_EXTERN NSSCertificate *
1699 NSSTrustDomain_FindCertificateByIssuerAndSerialNumber
1700 (
1701 NSSTrustDomain *td,
1702 NSSDER *issuer,
1703 NSSDER *serialNumber
1704 );
1705
1706 /*
1707 * NSSTrustDomain_FindCertificatesByIssuerAndSerialNumber
1708 *
1709 * Theoretically, this should never happen. However, some companies
1710 * we know have issued duplicate certificates with the same issuer
1711 * and serial number. Do we just ignore them? I'm thinking yes.
1712 */
1713
1714 /*
1715 * NSSTrustDomain_FindBestCertificateBySubject
1716 *
1717 * This does not search through alternate names hidden in extensions.
1718 */
1719
1720 NSS_EXTERN NSSCertificate *
1721 NSSTrustDomain_FindBestCertificateBySubject
1722 (
1723 NSSTrustDomain *td,
1724 NSSDER /*NSSUTF8*/ *subject,
1725 NSSTime *timeOpt,
1726 NSSUsage *usage,
1727 NSSPolicies *policiesOpt
1728 );
1729
1730 /*
1731 * NSSTrustDomain_FindCertificatesBySubject
1732 *
1733 * This does not search through alternate names hidden in extensions.
1734 */
1735
1736 NSS_EXTERN NSSCertificate **
1737 NSSTrustDomain_FindCertificatesBySubject
1738 (
1739 NSSTrustDomain *td,
1740 NSSDER /*NSSUTF8*/ *subject,
1741 NSSCertificate *rvOpt[],
1742 PRUint32 maximumOpt, /* 0 for no max */
1743 NSSArena *arenaOpt
1744 );
1745
1746 /*
1747 * NSSTrustDomain_FindBestCertificateByNameComponents
1748 *
1749 * This call does try several tricks, including a pseudo pkcs#11
1750 * attribute for the ldap module to try as a query. Eventually
1751 * this call falls back to a traversal if that's what's required.
1752 * It will search through alternate names hidden in extensions.
1753 */
1754
1755 NSS_EXTERN NSSCertificate *
1756 NSSTrustDomain_FindBestCertificateByNameComponents
1757 (
1758 NSSTrustDomain *td,
1759 NSSUTF8 *nameComponents,
1760 NSSTime *timeOpt,
1761 NSSUsage *usage,
1762 NSSPolicies *policiesOpt
1763 );
1764
1765 /*
1766 * NSSTrustDomain_FindCertificatesByNameComponents
1767 *
1768 * This call, too, tries several tricks. It will stop on the first
1769 * attempt that generates results, so it won't e.g. traverse the
1770 * entire ldap database.
1771 */
1772
1773 NSS_EXTERN NSSCertificate **
1774 NSSTrustDomain_FindCertificatesByNameComponents
1775 (
1776 NSSTrustDomain *td,
1777 NSSUTF8 *nameComponents,
1778 NSSCertificate *rvOpt[],
1779 PRUint32 maximumOpt, /* 0 for no max */
1780 NSSArena *arenaOpt
1781 );
1782
1783 /*
1784 * NSSTrustDomain_FindCertificateByEncodedCertificate
1785 *
1786 */
1787
1788 NSS_EXTERN NSSCertificate *
1789 NSSTrustDomain_FindCertificateByEncodedCertificate
1790 (
1791 NSSTrustDomain *td,
1792 NSSBER *encodedCertificate
1793 );
1794
1795 /*
1796 * NSSTrustDomain_FindBestCertificateByEmail
1797 *
1798 */
1799
1800 NSS_EXTERN NSSCertificate *
1801 NSSTrustDomain_FindCertificateByEmail
1802 (
1803 NSSTrustDomain *td,
1804 NSSASCII7 *email,
1805 NSSTime *timeOpt,
1806 NSSUsage *usage,
1807 NSSPolicies *policiesOpt
1808 );
1809
1810 /*
1811 * NSSTrustDomain_FindCertificatesByEmail
1812 *
1813 */
1814
1815 NSS_EXTERN NSSCertificate **
1816 NSSTrustDomain_FindCertificatesByEmail
1817 (
1818 NSSTrustDomain *td,
1819 NSSASCII7 *email,
1820 NSSCertificate *rvOpt[],
1821 PRUint32 maximumOpt, /* 0 for no max */
1822 NSSArena *arenaOpt
1823 );
1824
1825 /*
1826 * NSSTrustDomain_FindCertificateByOCSPHash
1827 *
1828 * There can be only one.
1829 */
1830
1831 NSS_EXTERN NSSCertificate *
1832 NSSTrustDomain_FindCertificateByOCSPHash
1833 (
1834 NSSTrustDomain *td,
1835 NSSItem *hash
1836 );
1837
1838 /*
1839 * NSSTrustDomain_TraverseCertificates
1840 *
1841 * This function descends from one in older versions of NSS which
1842 * traverses the certs in the permanent database. That function
1843 * was used to implement selection routines, but was directly
1844 * available too. Trust domains are going to contain a lot more
1845 * certs now (e.g., an ldap server), so we'd really like to
1846 * discourage traversal. Thus for now, this is commented out.
1847 * If it's needed, let's look at the situation more closely to
1848 * find out what the actual requirements are.
1849 */
1850
1851 /* For now, adding this function. This may only be for debugging
1852 * purposes.
1853 * Perhaps some equivalent function, on a specified token, will be
1854 * needed in a "friend" header file?
1855 */
1856 NSS_EXTERN PRStatus *
1857 NSSTrustDomain_TraverseCertificates
1858 (
1859 NSSTrustDomain *td,
1860 PRStatus (*callback)(NSSCertificate *c, void *arg),
1861 void *arg
1862 );
1863
1864 /*
1865 * NSSTrustDomain_FindBestUserCertificate
1866 *
1867 */
1868
1869 NSS_EXTERN NSSCertificate *
1870 NSSTrustDomain_FindBestUserCertificate
1871 (
1872 NSSTrustDomain *td,
1873 NSSTime *timeOpt,
1874 NSSUsage *usage,
1875 NSSPolicies *policiesOpt
1876 );
1877
1878 /*
1879 * NSSTrustDomain_FindUserCertificates
1880 *
1881 */
1882
1883 NSS_EXTERN NSSCertificate **
1884 NSSTrustDomain_FindUserCertificates
1885 (
1886 NSSTrustDomain *td,
1887 NSSTime *timeOpt,
1888 NSSUsage *usageOpt,
1889 NSSPolicies *policiesOpt,
1890 NSSCertificate **rvOpt,
1891 PRUint32 rvLimit, /* zero for no limit */
1892 NSSArena *arenaOpt
1893 );
1894
1895 /*
1896 * NSSTrustDomain_FindBestUserCertificateForSSLClientAuth
1897 *
1898 */
1899
1900 NSS_EXTERN NSSCertificate *
1901 NSSTrustDomain_FindBestUserCertificateForSSLClientAuth
1902 (
1903 NSSTrustDomain *td,
1904 NSSUTF8 *sslHostOpt,
1905 NSSDER *rootCAsOpt[], /* null pointer for none */
1906 PRUint32 rootCAsMaxOpt, /* zero means list is null-terminated */
1907 NSSAlgorithmAndParameters *apOpt,
1908 NSSPolicies *policiesOpt
1909 );
1910
1911 /*
1912 * NSSTrustDomain_FindUserCertificatesForSSLClientAuth
1913 *
1914 */
1915
1916 NSS_EXTERN NSSCertificate **
1917 NSSTrustDomain_FindUserCertificatesForSSLClientAuth
1918 (
1919 NSSTrustDomain *td,
1920 NSSUTF8 *sslHostOpt,
1921 NSSDER *rootCAsOpt[], /* null pointer for none */
1922 PRUint32 rootCAsMaxOpt, /* zero means list is null-terminated */
1923 NSSAlgorithmAndParameters *apOpt,
1924 NSSPolicies *policiesOpt,
1925 NSSCertificate **rvOpt,
1926 PRUint32 rvLimit, /* zero for no limit */
1927 NSSArena *arenaOpt
1928 );
1929
1930 /*
1931 * NSSTrustDomain_FindBestUserCertificateForEmailSigning
1932 *
1933 */
1934
1935 NSS_EXTERN NSSCertificate *
1936 NSSTrustDomain_FindBestUserCertificateForEmailSigning
1937 (
1938 NSSTrustDomain *td,
1939 NSSASCII7 *signerOpt,
1940 NSSASCII7 *recipientOpt,
1941 /* anything more here? */
1942 NSSAlgorithmAndParameters *apOpt,
1943 NSSPolicies *policiesOpt
1944 );
1945
1946 /*
1947 * NSSTrustDomain_FindUserCertificatesForEmailSigning
1948 *
1949 */
1950
1951 NSS_EXTERN NSSCertificate **
1952 NSSTrustDomain_FindUserCertificatesForEmailSigning
1953 (
1954 NSSTrustDomain *td,
1955 NSSASCII7 *signerOpt,
1956 NSSASCII7 *recipientOpt,
1957 /* anything more here? */
1958 NSSAlgorithmAndParameters *apOpt,
1959 NSSPolicies *policiesOpt,
1960 NSSCertificate **rvOpt,
1961 PRUint32 rvLimit, /* zero for no limit */
1962 NSSArena *arenaOpt
1963 );
1964
1965 /*
1966 * Here is where we'd add more Find[Best]UserCertificate[s]For<usage>
1967 * routines.
1968 */
1969
1970 /* Private Keys */
1971
1972 /*
1973 * NSSTrustDomain_GenerateKeyPair
1974 *
1975 * Creates persistant objects. If you want session objects, use
1976 * NSSCryptoContext_GenerateKeyPair. The destination token is where
1977 * the keys are stored. If that token can do the required math, then
1978 * that's where the keys are generated too. Otherwise, the keys are
1979 * generated elsewhere and moved to that token.
1980 */
1981
1982 NSS_EXTERN PRStatus
1983 NSSTrustDomain_GenerateKeyPair
1984 (
1985 NSSTrustDomain *td,
1986 NSSAlgorithmAndParameters *ap,
1987 NSSPrivateKey **pvkOpt,
1988 NSSPublicKey **pbkOpt,
1989 PRBool privateKeyIsSensitive,
1990 NSSToken *destination,
1991 NSSCallback *uhhOpt
1992 );
1993
1994 /*
1995 * NSSTrustDomain_TraversePrivateKeys
1996 *
1997 *
1998 * NSS_EXTERN PRStatus *
1999 * NSSTrustDomain_TraversePrivateKeys
2000 * (
2001 * NSSTrustDomain *td,
2002 * PRStatus (*callback)(NSSPrivateKey *vk, void *arg),
2003 * void *arg
2004 * );
2005 */
2006
2007 /* Symmetric Keys */
2008
2009 /*
2010 * NSSTrustDomain_GenerateSymmetricKey
2011 *
2012 */
2013
2014 NSS_EXTERN NSSSymmetricKey *
2015 NSSTrustDomain_GenerateSymmetricKey
2016 (
2017 NSSTrustDomain *td,
2018 NSSAlgorithmAndParameters *ap,
2019 PRUint32 keysize,
2020 NSSToken *destination,
2021 NSSCallback *uhhOpt
2022 );
2023
2024 /*
2025 * NSSTrustDomain_GenerateSymmetricKeyFromPassword
2026 *
2027 */
2028
2029 NSS_EXTERN NSSSymmetricKey *
2030 NSSTrustDomain_GenerateSymmetricKeyFromPassword
2031 (
2032 NSSTrustDomain *td,
2033 NSSAlgorithmAndParameters *ap,
2034 NSSUTF8 *passwordOpt, /* if null, prompt */
2035 NSSToken *destinationOpt,
2036 NSSCallback *uhhOpt
2037 );
2038
2039 /*
2040 * NSSTrustDomain_FindSymmetricKeyByAlgorithm
2041 *
2042 * Is this still needed?
2043 *
2044 * NSS_EXTERN NSSSymmetricKey *
2045 * NSSTrustDomain_FindSymmetricKeyByAlgorithm
2046 * (
2047 * NSSTrustDomain *td,
2048 * NSSOID *algorithm,
2049 * NSSCallback *uhhOpt
2050 * );
2051 */
2052
2053 /*
2054 * NSSTrustDomain_FindSymmetricKeyByAlgorithmAndKeyID
2055 *
2056 */
2057
2058 NSS_EXTERN NSSSymmetricKey *
2059 NSSTrustDomain_FindSymmetricKeyByAlgorithmAndKeyID
2060 (
2061 NSSTrustDomain *td,
2062 NSSOID *algorithm,
2063 NSSItem *keyID,
2064 NSSCallback *uhhOpt
2065 );
2066
2067 /*
2068 * NSSTrustDomain_TraverseSymmetricKeys
2069 *
2070 *
2071 * NSS_EXTERN PRStatus *
2072 * NSSTrustDomain_TraverseSymmetricKeys
2073 * (
2074 * NSSTrustDomain *td,
2075 * PRStatus (*callback)(NSSSymmetricKey *mk, void *arg),
2076 * void *arg
2077 * );
2078 */
2079
2080 /*
2081 * NSSTrustDomain_CreateCryptoContext
2082 *
2083 * If a callback object is specified, it becomes the for the crypto
2084 * context; otherwise, this trust domain's default (if any) is
2085 * inherited.
2086 */
2087
2088 NSS_EXTERN NSSCryptoContext *
2089 NSSTrustDomain_CreateCryptoContext
2090 (
2091 NSSTrustDomain *td,
2092 NSSCallback *uhhOpt
2093 );
2094
2095 /*
2096 * NSSTrustDomain_CreateCryptoContextForAlgorithm
2097 *
2098 */
2099
2100 NSS_EXTERN NSSCryptoContext *
2101 NSSTrustDomain_CreateCryptoContextForAlgorithm
2102 (
2103 NSSTrustDomain *td,
2104 NSSOID *algorithm
2105 );
2106
2107 /*
2108 * NSSTrustDomain_CreateCryptoContextForAlgorithmAndParameters
2109 *
2110 */
2111
2112 NSS_EXTERN NSSCryptoContext *
2113 NSSTrustDomain_CreateCryptoContextForAlgorithmAndParameters
2114 (
2115 NSSTrustDomain *td,
2116 NSSAlgorithmAndParameters *ap
2117 );
2118
2119 /* find/traverse other objects, e.g. s/mime profiles */
2120
2121 /*
2122 * NSSCryptoContext
2123 *
2124 * A crypto context is sort of a short-term snapshot of a trust domain,
2125 * used for the life of "one crypto operation." You can also think of
2126 * it as a "temporary database."
2127 *
2128 * Just about all of the things you can do with a trust domain -- importing
2129 * or creating certs, keys, etc. -- can be done with a crypto context.
2130 * The difference is that the objects will be temporary ("session") objects.
2131 *
2132 * Also, if the context was created for a key, cert, and/or algorithm; or
2133 * if such objects have been "associated" with the context, then the context
2134 * can do everything the keys can, like crypto operations.
2135 *
2136 * And finally, because it keeps the state of the crypto operations, it
2137 * can do streaming crypto ops.
2138 */
2139
2140 /*
2141 * NSSTrustDomain_Destroy
2142 *
2143 */
2144
2145 NSS_EXTERN PRStatus
2146 NSSCryptoContext_Destroy
2147 (
2148 NSSCryptoContext *cc
2149 );
2150
2151 /* establishing a default callback */
2152
2153 /*
2154 * NSSCryptoContext_SetDefaultCallback
2155 *
2156 */
2157
2158 NSS_EXTERN PRStatus
2159 NSSCryptoContext_SetDefaultCallback
2160 (
2161 NSSCryptoContext *cc,
2162 NSSCallback *newCallback,
2163 NSSCallback **oldCallbackOpt
2164 );
2165
2166 /*
2167 * NSSCryptoContext_GetDefaultCallback
2168 *
2169 */
2170
2171 NSS_EXTERN NSSCallback *
2172 NSSCryptoContext_GetDefaultCallback
2173 (
2174 NSSCryptoContext *cc,
2175 PRStatus *statusOpt
2176 );
2177
2178 /*
2179 * NSSCryptoContext_GetTrustDomain
2180 *
2181 */
2182
2183 NSS_EXTERN NSSTrustDomain *
2184 NSSCryptoContext_GetTrustDomain
2185 (
2186 NSSCryptoContext *cc
2187 );
2188
2189 /* AddModule, etc: should we allow "temporary" changes here? */
2190 /* DisableToken, etc: ditto */
2191 /* Ordering of tokens? */
2192 /* Finding slots+token etc. */
2193 /* login+logout */
2194
2195 /* Importing things */
2196
2197 /*
2198 * NSSCryptoContext_FindOrImportCertificate
2199 *
2200 * If the certificate store already contains this DER cert, return the
2201 * address of the matching NSSCertificate that is already in the store,
2202 * and bump its reference count.
2203 *
2204 * If this DER cert is NOT already in the store, then add the new
2205 * NSSCertificate to the store and bump its reference count,
2206 * then return its address.
2207 *
2208 * if this DER cert is not in the store and cannot be added to it,
2209 * return NULL;
2210 *
2211 * Record the associated crypto context in the certificate.
2212 */
2213
2214 NSS_EXTERN NSSCertificate *
2215 NSSCryptoContext_FindOrImportCertificate (
2216 NSSCryptoContext *cc,
2217 NSSCertificate *c
2218 );
2219
2220 /*
2221 * NSSCryptoContext_ImportPKIXCertificate
2222 *
2223 */
2224
2225 NSS_EXTERN NSSCertificate *
2226 NSSCryptoContext_ImportPKIXCertificate
2227 (
2228 NSSCryptoContext *cc,
2229 struct NSSPKIXCertificateStr *pc
2230 );
2231
2232 /*
2233 * NSSCryptoContext_ImportEncodedCertificate
2234 *
2235 */
2236
2237 NSS_EXTERN NSSCertificate *
2238 NSSCryptoContext_ImportEncodedCertificate
2239 (
2240 NSSCryptoContext *cc,
2241 NSSBER *ber
2242 );
2243
2244 /*
2245 * NSSCryptoContext_ImportEncodedPKIXCertificateChain
2246 *
2247 */
2248
2249 NSS_EXTERN PRStatus
2250 NSSCryptoContext_ImportEncodedPKIXCertificateChain
2251 (
2252 NSSCryptoContext *cc,
2253 NSSBER *ber
2254 );
2255
2256 /* Other importations: S/MIME capabilities
2257 */
2258
2259 /*
2260 * NSSCryptoContext_FindBestCertificateByNickname
2261 *
2262 */
2263
2264 NSS_EXTERN NSSCertificate *
2265 NSSCryptoContext_FindBestCertificateByNickname
2266 (
2267 NSSCryptoContext *cc,
2268 const NSSUTF8 *name,
2269 NSSTime *timeOpt, /* NULL for "now" */
2270 NSSUsage *usage,
2271 NSSPolicies *policiesOpt /* NULL for none */
2272 );
2273
2274 /*
2275 * NSSCryptoContext_FindCertificatesByNickname
2276 *
2277 */
2278
2279 NSS_EXTERN NSSCertificate **
2280 NSSCryptoContext_FindCertificatesByNickname
2281 (
2282 NSSCryptoContext *cc,
2283 NSSUTF8 *name,
2284 NSSCertificate *rvOpt[],
2285 PRUint32 maximumOpt, /* 0 for no max */
2286 NSSArena *arenaOpt
2287 );
2288
2289 /*
2290 * NSSCryptoContext_FindCertificateByIssuerAndSerialNumber
2291 *
2292 */
2293
2294 NSS_EXTERN NSSCertificate *
2295 NSSCryptoContext_FindCertificateByIssuerAndSerialNumber
2296 (
2297 NSSCryptoContext *cc,
2298 NSSDER *issuer,
2299 NSSDER *serialNumber
2300 );
2301
2302 /*
2303 * NSSCryptoContext_FindBestCertificateBySubject
2304 *
2305 * This does not search through alternate names hidden in extensions.
2306 */
2307
2308 NSS_EXTERN NSSCertificate *
2309 NSSCryptoContext_FindBestCertificateBySubject
2310 (
2311 NSSCryptoContext *cc,
2312 NSSDER /*NSSUTF8*/ *subject,
2313 NSSTime *timeOpt,
2314 NSSUsage *usage,
2315 NSSPolicies *policiesOpt
2316 );
2317
2318 /*
2319 * NSSCryptoContext_FindCertificatesBySubject
2320 *
2321 * This does not search through alternate names hidden in extensions.
2322 */
2323
2324 NSS_EXTERN NSSCertificate **
2325 NSSCryptoContext_FindCertificatesBySubject
2326 (
2327 NSSCryptoContext *cc,
2328 NSSDER /*NSSUTF8*/ *subject,
2329 NSSCertificate *rvOpt[],
2330 PRUint32 maximumOpt, /* 0 for no max */
2331 NSSArena *arenaOpt
2332 );
2333
2334 /*
2335 * NSSCryptoContext_FindBestCertificateByNameComponents
2336 *
2337 * This call does try several tricks, including a pseudo pkcs#11
2338 * attribute for the ldap module to try as a query. Eventually
2339 * this call falls back to a traversal if that's what's required.
2340 * It will search through alternate names hidden in extensions.
2341 */
2342
2343 NSS_EXTERN NSSCertificate *
2344 NSSCryptoContext_FindBestCertificateByNameComponents
2345 (
2346 NSSCryptoContext *cc,
2347 NSSUTF8 *nameComponents,
2348 NSSTime *timeOpt,
2349 NSSUsage *usage,
2350 NSSPolicies *policiesOpt
2351 );
2352
2353 /*
2354 * NSSCryptoContext_FindCertificatesByNameComponents
2355 *
2356 * This call, too, tries several tricks. It will stop on the first
2357 * attempt that generates results, so it won't e.g. traverse the
2358 * entire ldap database.
2359 */
2360
2361 NSS_EXTERN NSSCertificate **
2362 NSSCryptoContext_FindCertificatesByNameComponents
2363 (
2364 NSSCryptoContext *cc,
2365 NSSUTF8 *nameComponents,
2366 NSSCertificate *rvOpt[],
2367 PRUint32 maximumOpt, /* 0 for no max */
2368 NSSArena *arenaOpt
2369 );
2370
2371 /*
2372 * NSSCryptoContext_FindCertificateByEncodedCertificate
2373 *
2374 */
2375
2376 NSS_EXTERN NSSCertificate *
2377 NSSCryptoContext_FindCertificateByEncodedCertificate
2378 (
2379 NSSCryptoContext *cc,
2380 NSSBER *encodedCertificate
2381 );
2382
2383 /*
2384 * NSSCryptoContext_FindBestCertificateByEmail
2385 *
2386 */
2387
2388 NSS_EXTERN NSSCertificate *
2389 NSSCryptoContext_FindBestCertificateByEmail
2390 (
2391 NSSCryptoContext *cc,
2392 NSSASCII7 *email,
2393 NSSTime *timeOpt,
2394 NSSUsage *usage,
2395 NSSPolicies *policiesOpt
2396 );
2397
2398 /*
2399 * NSSCryptoContext_FindCertificatesByEmail
2400 *
2401 */
2402
2403 NSS_EXTERN NSSCertificate **
2404 NSSCryptoContext_FindCertificatesByEmail
2405 (
2406 NSSCryptoContext *cc,
2407 NSSASCII7 *email,
2408 NSSCertificate *rvOpt[],
2409 PRUint32 maximumOpt, /* 0 for no max */
2410 NSSArena *arenaOpt
2411 );
2412
2413 /*
2414 * NSSCryptoContext_FindCertificateByOCSPHash
2415 *
2416 */
2417
2418 NSS_EXTERN NSSCertificate *
2419 NSSCryptoContext_FindCertificateByOCSPHash
2420 (
2421 NSSCryptoContext *cc,
2422 NSSItem *hash
2423 );
2424
2425 /*
2426 * NSSCryptoContext_TraverseCertificates
2427 *
2428 *
2429 * NSS_EXTERN PRStatus *
2430 * NSSCryptoContext_TraverseCertificates
2431 * (
2432 * NSSCryptoContext *cc,
2433 * PRStatus (*callback)(NSSCertificate *c, void *arg),
2434 * void *arg
2435 * );
2436 */
2437
2438 /*
2439 * NSSCryptoContext_FindBestUserCertificate
2440 *
2441 */
2442
2443 NSS_EXTERN NSSCertificate *
2444 NSSCryptoContext_FindBestUserCertificate
2445 (
2446 NSSCryptoContext *cc,
2447 NSSTime *timeOpt,
2448 NSSUsage *usage,
2449 NSSPolicies *policiesOpt
2450 );
2451
2452 /*
2453 * NSSCryptoContext_FindUserCertificates
2454 *
2455 */
2456
2457 NSS_EXTERN NSSCertificate **
2458 NSSCryptoContext_FindUserCertificates
2459 (
2460 NSSCryptoContext *cc,
2461 NSSTime *timeOpt,
2462 NSSUsage *usageOpt,
2463 NSSPolicies *policiesOpt,
2464 NSSCertificate **rvOpt,
2465 PRUint32 rvLimit, /* zero for no limit */
2466 NSSArena *arenaOpt
2467 );
2468
2469 /*
2470 * NSSCryptoContext_FindBestUserCertificateForSSLClientAuth
2471 *
2472 */
2473
2474 NSS_EXTERN NSSCertificate *
2475 NSSCryptoContext_FindBestUserCertificateForSSLClientAuth
2476 (
2477 NSSCryptoContext *cc,
2478 NSSUTF8 *sslHostOpt,
2479 NSSDER *rootCAsOpt[], /* null pointer for none */
2480 PRUint32 rootCAsMaxOpt, /* zero means list is null-terminated */
2481 NSSAlgorithmAndParameters *apOpt,
2482 NSSPolicies *policiesOpt
2483 );
2484
2485 /*
2486 * NSSCryptoContext_FindUserCertificatesForSSLClientAuth
2487 *
2488 */
2489
2490 NSS_EXTERN NSSCertificate **
2491 NSSCryptoContext_FindUserCertificatesForSSLClientAuth
2492 (
2493 NSSCryptoContext *cc,
2494 NSSUTF8 *sslHostOpt,
2495 NSSDER *rootCAsOpt[], /* null pointer for none */
2496 PRUint32 rootCAsMaxOpt, /* zero means list is null-terminated */
2497 NSSAlgorithmAndParameters *apOpt,
2498 NSSPolicies *policiesOpt,
2499 NSSCertificate **rvOpt,
2500 PRUint32 rvLimit, /* zero for no limit */
2501 NSSArena *arenaOpt
2502 );
2503
2504 /*
2505 * NSSCryptoContext_FindBestUserCertificateForEmailSigning
2506 *
2507 */
2508
2509 NSS_EXTERN NSSCertificate *
2510 NSSCryptoContext_FindBestUserCertificateForEmailSigning
2511 (
2512 NSSCryptoContext *cc,
2513 NSSASCII7 *signerOpt,
2514 NSSASCII7 *recipientOpt,
2515 /* anything more here? */
2516 NSSAlgorithmAndParameters *apOpt,
2517 NSSPolicies *policiesOpt
2518 );
2519
2520 /*
2521 * NSSCryptoContext_FindUserCertificatesForEmailSigning
2522 *
2523 */
2524
2525 NSS_EXTERN NSSCertificate *
2526 NSSCryptoContext_FindUserCertificatesForEmailSigning
2527 (
2528 NSSCryptoContext *cc,
2529 NSSASCII7 *signerOpt, /* fgmr or a more general name? */
2530 NSSASCII7 *recipientOpt,
2531 /* anything more here? */
2532 NSSAlgorithmAndParameters *apOpt,
2533 NSSPolicies *policiesOpt,
2534 NSSCertificate **rvOpt,
2535 PRUint32 rvLimit, /* zero for no limit */
2536 NSSArena *arenaOpt
2537 );
2538
2539 /* Private Keys */
2540
2541 /*
2542 * NSSCryptoContext_GenerateKeyPair
2543 *
2544 * Creates session objects. If you want persistant objects, use
2545 * NSSTrustDomain_GenerateKeyPair. The destination token is where
2546 * the keys are stored. If that token can do the required math, then
2547 * that's where the keys are generated too. Otherwise, the keys are
2548 * generated elsewhere and moved to that token.
2549 */
2550
2551 NSS_EXTERN PRStatus
2552 NSSCryptoContext_GenerateKeyPair
2553 (
2554 NSSCryptoContext *cc,
2555 NSSAlgorithmAndParameters *ap,
2556 NSSPrivateKey **pvkOpt,
2557 NSSPublicKey **pbkOpt,
2558 PRBool privateKeyIsSensitive,
2559 NSSToken *destination,
2560 NSSCallback *uhhOpt
2561 );
2562
2563 /*
2564 * NSSCryptoContext_TraversePrivateKeys
2565 *
2566 *
2567 * NSS_EXTERN PRStatus *
2568 * NSSCryptoContext_TraversePrivateKeys
2569 * (
2570 * NSSCryptoContext *cc,
2571 * PRStatus (*callback)(NSSPrivateKey *vk, void *arg),
2572 * void *arg
2573 * );
2574 */
2575
2576 /* Symmetric Keys */
2577
2578 /*
2579 * NSSCryptoContext_GenerateSymmetricKey
2580 *
2581 */
2582
2583 NSS_EXTERN NSSSymmetricKey *
2584 NSSCryptoContext_GenerateSymmetricKey
2585 (
2586 NSSCryptoContext *cc,
2587 NSSAlgorithmAndParameters *ap,
2588 PRUint32 keysize,
2589 NSSToken *destination,
2590 NSSCallback *uhhOpt
2591 );
2592
2593 /*
2594 * NSSCryptoContext_GenerateSymmetricKeyFromPassword
2595 *
2596 */
2597
2598 NSS_EXTERN NSSSymmetricKey *
2599 NSSCryptoContext_GenerateSymmetricKeyFromPassword
2600 (
2601 NSSCryptoContext *cc,
2602 NSSAlgorithmAndParameters *ap,
2603 NSSUTF8 *passwordOpt, /* if null, prompt */
2604 NSSToken *destinationOpt,
2605 NSSCallback *uhhOpt
2606 );
2607
2608 /*
2609 * NSSCryptoContext_FindSymmetricKeyByAlgorithm
2610 *
2611 *
2612 * NSS_EXTERN NSSSymmetricKey *
2613 * NSSCryptoContext_FindSymmetricKeyByType
2614 * (
2615 * NSSCryptoContext *cc,
2616 * NSSOID *type,
2617 * NSSCallback *uhhOpt
2618 * );
2619 */
2620
2621 /*
2622 * NSSCryptoContext_FindSymmetricKeyByAlgorithmAndKeyID
2623 *
2624 */
2625
2626 NSS_EXTERN NSSSymmetricKey *
2627 NSSCryptoContext_FindSymmetricKeyByAlgorithmAndKeyID
2628 (
2629 NSSCryptoContext *cc,
2630 NSSOID *algorithm,
2631 NSSItem *keyID,
2632 NSSCallback *uhhOpt
2633 );
2634
2635 /*
2636 * NSSCryptoContext_TraverseSymmetricKeys
2637 *
2638 *
2639 * NSS_EXTERN PRStatus *
2640 * NSSCryptoContext_TraverseSymmetricKeys
2641 * (
2642 * NSSCryptoContext *cc,
2643 * PRStatus (*callback)(NSSSymmetricKey *mk, void *arg),
2644 * void *arg
2645 * );
2646 */
2647
2648 /* Crypto ops on distinguished keys */
2649
2650 /*
2651 * NSSCryptoContext_Decrypt
2652 *
2653 */
2654
2655 NSS_EXTERN NSSItem *
2656 NSSCryptoContext_Decrypt
2657 (
2658 NSSCryptoContext *cc,
2659 NSSAlgorithmAndParameters *apOpt,
2660 NSSItem *encryptedData,
2661 NSSCallback *uhhOpt,
2662 NSSItem *rvOpt,
2663 NSSArena *arenaOpt
2664 );
2665
2666 /*
2667 * NSSCryptoContext_BeginDecrypt
2668 *
2669 */
2670
2671 NSS_EXTERN PRStatus
2672 NSSCryptoContext_BeginDecrypt
2673 (
2674 NSSCryptoContext *cc,
2675 NSSAlgorithmAndParameters *apOpt,
2676 NSSCallback *uhhOpt
2677 );
2678
2679 /*
2680 * NSSCryptoContext_ContinueDecrypt
2681 *
2682 */
2683
2684 /*
2685 * NSSItem semantics:
2686 *
2687 * If rvOpt is NULL, a new NSSItem and buffer are allocated.
2688 * If rvOpt is not null, but the buffer pointer is null,
2689 * then rvOpt is returned but a new buffer is allocated.
2690 * In this case, if the length value is not zero, then
2691 * no more than that much space will be allocated.
2692 * If rvOpt is not null and the buffer pointer is not null,
2693 * then that buffer is re-used. No more than the buffer
2694 * length value will be used; if it's not enough, an
2695 * error is returned. If less is used, the number is
2696 * adjusted downwards.
2697 *
2698 * Note that although this is short of some ideal "Item"
2699 * definition, we can usually tell how big these buffers
2700 * have to be.
2701 *
2702 * Feedback is requested; and earlier is better than later.
2703 */
2704
2705 NSS_EXTERN NSSItem *
2706 NSSCryptoContext_ContinueDecrypt
2707 (
2708 NSSCryptoContext *cc,
2709 NSSItem *data,
2710 NSSItem *rvOpt,
2711 NSSArena *arenaOpt
2712 );
2713
2714 /*
2715 * NSSCryptoContext_FinishDecrypt
2716 *
2717 */
2718
2719 NSS_EXTERN NSSItem *
2720 NSSCryptoContext_FinishDecrypt
2721 (
2722 NSSCryptoContext *cc,
2723 NSSItem *rvOpt,
2724 NSSArena *arenaOpt
2725 );
2726
2727 /*
2728 * NSSCryptoContext_Sign
2729 *
2730 */
2731
2732 NSS_EXTERN NSSItem *
2733 NSSCryptoContext_Sign
2734 (
2735 NSSCryptoContext *cc,
2736 NSSAlgorithmAndParameters *apOpt,
2737 NSSItem *data,
2738 NSSCallback *uhhOpt,
2739 NSSItem *rvOpt,
2740 NSSArena *arenaOpt
2741 );
2742
2743 /*
2744 * NSSCryptoContext_BeginSign
2745 *
2746 */
2747
2748 NSS_EXTERN PRStatus
2749 NSSCryptoContext_BeginSign
2750 (
2751 NSSCryptoContext *cc,
2752 NSSAlgorithmAndParameters *apOpt,
2753 NSSCallback *uhhOpt
2754 );
2755
2756 /*
2757 * NSSCryptoContext_ContinueSign
2758 *
2759 */
2760
2761 NSS_EXTERN PRStatus
2762 NSSCryptoContext_ContinueSign
2763 (
2764 NSSCryptoContext *cc,
2765 NSSItem *data
2766 );
2767
2768 /*
2769 * NSSCryptoContext_FinishSign
2770 *
2771 */
2772
2773 NSS_EXTERN NSSItem *
2774 NSSCryptoContext_FinishSign
2775 (
2776 NSSCryptoContext *cc,
2777 NSSItem *rvOpt,
2778 NSSArena *arenaOpt
2779 );
2780
2781 /*
2782 * NSSCryptoContext_SignRecover
2783 *
2784 */
2785
2786 NSS_EXTERN NSSItem *
2787 NSSCryptoContext_SignRecover
2788 (
2789 NSSCryptoContext *cc,
2790 NSSAlgorithmAndParameters *apOpt,
2791 NSSItem *data,
2792 NSSCallback *uhhOpt,
2793 NSSItem *rvOpt,
2794 NSSArena *arenaOpt
2795 );
2796
2797 /*
2798 * NSSCryptoContext_BeginSignRecover
2799 *
2800 */
2801
2802 NSS_EXTERN PRStatus
2803 NSSCryptoContext_BeginSignRecover
2804 (
2805 NSSCryptoContext *cc,
2806 NSSAlgorithmAndParameters *apOpt,
2807 NSSCallback *uhhOpt
2808 );
2809
2810 /*
2811 * NSSCryptoContext_ContinueSignRecover
2812 *
2813 */
2814
2815 NSS_EXTERN NSSItem *
2816 NSSCryptoContext_ContinueSignRecover
2817 (
2818 NSSCryptoContext *cc,
2819 NSSItem *data,
2820 NSSItem *rvOpt,
2821 NSSArena *arenaOpt
2822 );
2823
2824 /*
2825 * NSSCryptoContext_FinishSignRecover
2826 *
2827 */
2828
2829 NSS_EXTERN NSSItem *
2830 NSSCryptoContext_FinishSignRecover
2831 (
2832 NSSCryptoContext *cc,
2833 NSSItem *rvOpt,
2834 NSSArena *arenaOpt
2835 );
2836
2837 /*
2838 * NSSCryptoContext_UnwrapSymmetricKey
2839 *
2840 */
2841
2842 NSS_EXTERN NSSSymmetricKey *
2843 NSSCryptoContext_UnwrapSymmetricKey
2844 (
2845 NSSCryptoContext *cc,
2846 NSSAlgorithmAndParameters *apOpt,
2847 NSSItem *wrappedKey,
2848 NSSCallback *uhhOpt
2849 );
2850
2851 /*
2852 * NSSCryptoContext_DeriveSymmetricKey
2853 *
2854 */
2855
2856 NSS_EXTERN NSSSymmetricKey *
2857 NSSCryptoContext_DeriveSymmetricKey
2858 (
2859 NSSCryptoContext *cc,
2860 NSSPublicKey *bk,
2861 NSSAlgorithmAndParameters *apOpt,
2862 NSSOID *target,
2863 PRUint32 keySizeOpt, /* zero for best allowed */
2864 NSSOperations operations,
2865 NSSCallback *uhhOpt
2866 );
2867
2868 /*
2869 * NSSCryptoContext_Encrypt
2870 *
2871 * Encrypt a single chunk of data with the distinguished public key
2872 * of this crypto context.
2873 */
2874
2875 NSS_EXTERN NSSItem *
2876 NSSCryptoContext_Encrypt
2877 (
2878 NSSCryptoContext *cc,
2879 NSSAlgorithmAndParameters *apOpt,
2880 NSSItem *data,
2881 NSSCallback *uhhOpt,
2882 NSSItem *rvOpt,
2883 NSSArena *arenaOpt
2884 );
2885
2886 /*
2887 * NSSCryptoContext_BeginEncrypt
2888 *
2889 */
2890
2891 NSS_EXTERN PRStatus
2892 NSSCryptoContext_BeginEncrypt
2893 (
2894 NSSCryptoContext *cc,
2895 NSSAlgorithmAndParameters *apOpt,
2896 NSSCallback *uhhOpt
2897 );
2898
2899 /*
2900 * NSSCryptoContext_ContinueEncrypt
2901 *
2902 */
2903
2904 NSS_EXTERN NSSItem *
2905 NSSCryptoContext_ContinueEncrypt
2906 (
2907 NSSCryptoContext *cc,
2908 NSSItem *data,
2909 NSSItem *rvOpt,
2910 NSSArena *arenaOpt
2911 );
2912
2913 /*
2914 * NSSCryptoContext_FinishEncrypt
2915 *
2916 */
2917
2918 NSS_EXTERN NSSItem *
2919 NSSCryptoContext_FinishEncrypt
2920 (
2921 NSSCryptoContext *cc,
2922 NSSItem *rvOpt,
2923 NSSArena *arenaOpt
2924 );
2925
2926 /*
2927 * NSSCryptoContext_Verify
2928 *
2929 */
2930
2931 NSS_EXTERN PRStatus
2932 NSSCryptoContext_Verify
2933 (
2934 NSSCryptoContext *cc,
2935 NSSAlgorithmAndParameters *apOpt,
2936 NSSItem *data,
2937 NSSItem *signature,
2938 NSSCallback *uhhOpt
2939 );
2940
2941 /*
2942 * NSSCryptoContext_BeginVerify
2943 *
2944 */
2945
2946 NSS_EXTERN PRStatus
2947 NSSCryptoContext_BeginVerify
2948 (
2949 NSSCryptoContext *cc,
2950 NSSAlgorithmAndParameters *apOpt,
2951 NSSItem *signature,
2952 NSSCallback *uhhOpt
2953 );
2954
2955 /*
2956 * NSSCryptoContext_ContinueVerify
2957 *
2958 */
2959
2960 NSS_EXTERN PRStatus
2961 NSSCryptoContext_ContinueVerify
2962 (
2963 NSSCryptoContext *cc,
2964 NSSItem *data
2965 );
2966
2967 /*
2968 * NSSCryptoContext_FinishVerify
2969 *
2970 */
2971
2972 NSS_EXTERN PRStatus
2973 NSSCryptoContext_FinishVerify
2974 (
2975 NSSCryptoContext *cc
2976 );
2977
2978 /*
2979 * NSSCryptoContext_VerifyRecover
2980 *
2981 */
2982
2983 NSS_EXTERN NSSItem *
2984 NSSCryptoContext_VerifyRecover
2985 (
2986 NSSCryptoContext *cc,
2987 NSSAlgorithmAndParameters *apOpt,
2988 NSSItem *signature,
2989 NSSCallback *uhhOpt,
2990 NSSItem *rvOpt,
2991 NSSArena *arenaOpt
2992 );
2993
2994 /*
2995 * NSSCryptoContext_BeginVerifyRecover
2996 *
2997 */
2998
2999 NSS_EXTERN PRStatus
3000 NSSCryptoContext_BeginVerifyRecover
3001 (
3002 NSSCryptoContext *cc,
3003 NSSAlgorithmAndParameters *apOpt,
3004 NSSCallback *uhhOpt
3005 );
3006
3007 /*
3008 * NSSCryptoContext_ContinueVerifyRecover
3009 *
3010 */
3011
3012 NSS_EXTERN NSSItem *
3013 NSSCryptoContext_ContinueVerifyRecover
3014 (
3015 NSSCryptoContext *cc,
3016 NSSItem *data,
3017 NSSItem *rvOpt,
3018 NSSArena *arenaOpt
3019 );
3020
3021 /*
3022 * NSSCryptoContext_FinishVerifyRecover
3023 *
3024 */
3025
3026 NSS_EXTERN NSSItem *
3027 NSSCryptoContext_FinishVerifyRecover
3028 (
3029 NSSCryptoContext *cc,
3030 NSSItem *rvOpt,
3031 NSSArena *arenaOpt
3032 );
3033
3034 /*
3035 * NSSCryptoContext_WrapSymmetricKey
3036 *
3037 */
3038
3039 NSS_EXTERN NSSItem *
3040 NSSCryptoContext_WrapSymmetricKey
3041 (
3042 NSSCryptoContext *cc,
3043 NSSAlgorithmAndParameters *apOpt,
3044 NSSSymmetricKey *keyToWrap,
3045 NSSCallback *uhhOpt,
3046 NSSItem *rvOpt,
3047 NSSArena *arenaOpt
3048 );
3049
3050 /*
3051 * NSSCryptoContext_Digest
3052 *
3053 * Digest a single chunk of data with the distinguished digest key
3054 * of this crypto context.
3055 */
3056
3057 NSS_EXTERN NSSItem *
3058 NSSCryptoContext_Digest
3059 (
3060 NSSCryptoContext *cc,
3061 NSSAlgorithmAndParameters *apOpt,
3062 NSSItem *data,
3063 NSSCallback *uhhOpt,
3064 NSSItem *rvOpt,
3065 NSSArena *arenaOpt
3066 );
3067
3068 /*
3069 * NSSCryptoContext_BeginDigest
3070 *
3071 */
3072
3073 NSS_EXTERN PRStatus
3074 NSSCryptoContext_BeginDigest
3075 (
3076 NSSCryptoContext *cc,
3077 NSSAlgorithmAndParameters *apOpt,
3078 NSSCallback *uhhOpt
3079 );
3080
3081 /*
3082 * NSSCryptoContext_ContinueDigest
3083 *
3084 */
3085
3086 NSS_EXTERN PRStatus
3087 NSSCryptoContext_ContinueDigest
3088 (
3089 NSSCryptoContext *cc,
3090 NSSAlgorithmAndParameters *apOpt,
3091 NSSItem *item
3092 );
3093
3094 /*
3095 * NSSCryptoContext_FinishDigest
3096 *
3097 */
3098
3099 NSS_EXTERN NSSItem *
3100 NSSCryptoContext_FinishDigest
3101 (
3102 NSSCryptoContext *cc,
3103 NSSItem *rvOpt,
3104 NSSArena *arenaOpt
3105 );
3106
3107 /*
3108 * tbd: Combination ops
3109 */
3110
3111 /*
3112 * NSSCryptoContext_Clone
3113 *
3114 */
3115
3116 NSS_EXTERN NSSCryptoContext *
3117 NSSCryptoContext_Clone
3118 (
3119 NSSCryptoContext *cc
3120 );
3121
3122 /*
3123 * NSSCryptoContext_Save
3124 * NSSCryptoContext_Restore
3125 *
3126 * We need to be able to save and restore the state of contexts.
3127 * Perhaps a mark-and-release mechanism would be better?
3128 */
3129
3130 /*
3131 * ..._SignTBSCertificate
3132 *
3133 * This requires feedback from the cert server team.
3134 */
3135
3136 /*
3137 * PRBool NSSCertificate_GetIsTrustedFor{xxx}(NSSCertificate *c);
3138 * PRStatus NSSCertificate_SetIsTrustedFor{xxx}(NSSCertificate *c, PRBool trusted);
3139 *
3140 * These will be helper functions which get the trust object for a cert,
3141 * and then call the corresponding function(s) on it.
3142 *
3143 * PKIX trust objects will have methods to manipulate the low-level trust
3144 * bits (which are based on key usage and extended key usage), and also the
3145 * conceptual high-level usages (e.g. ssl client auth, email encryption, etc.)
3146 *
3147 * Other types of trust objects (if any) might have different low-level
3148 * representations, but hopefully high-level concepts would map.
3149 *
3150 * Only these high-level general routines would be promoted to the
3151 * general certificate level here. Hence the {xxx} above would be things
3152 * like "EmailSigning."
3153 *
3154 *
3155 * NSSPKIXTrust *NSSCertificate_GetPKIXTrustObject(NSSCertificate *c);
3156 * PRStatus NSSCertificate_SetPKIXTrustObject(NSSCertificate *c, NSPKIXTrust *t);
3157 *
3158 * I want to hold off on any general trust object until we've investigated
3159 * other models more thoroughly.
3160 */
3161
3162 PR_END_EXTERN_C
3163
3164 #endif /* NSSPKI_H */
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)