annotate libpurple/plugins/ssl/ssl-nss.c @ 19680:44b4e8bd759b

The FSF changed its address a while ago; our files were out of date. This is a quick update done with a for loop, find, and sed.
author John Bailey <rekkanoryo@rekkanoryo.org>
date Sat, 08 Sep 2007 03:09:35 +0000
parents fb3b3e93b9ca
children eda223b50bdc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
1 /**
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
2 * @file ssl-nss.c Mozilla NSS SSL plugin.
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
3 *
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
4 * purple
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
5 *
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
6 * Copyright (C) 2003 Christian Hammond <chipx86@gnupdate.org>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
7 *
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
8 * This program is free software; you can redistribute it and/or modify
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
9 * it under the terms of the GNU General Public License as published by
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
10 * the Free Software Foundation; either version 2 of the License, or
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
11 * (at your option) any later version.
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
12 *
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
13 * This program is distributed in the hope that it will be useful,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
16 * GNU General Public License for more details.
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
17 *
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
18 * You should have received a copy of the GNU General Public License
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
19 * along with this program; if not, write to the Free Software
19680
44b4e8bd759b The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents: 19669
diff changeset
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
21 */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
22 #include "internal.h"
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
23 #include "debug.h"
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
24 #include "certificate.h"
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
25 #include "plugin.h"
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
26 #include "sslconn.h"
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
27 #include "version.h"
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
28
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
29 #define SSL_NSS_PLUGIN_ID "ssl-nss"
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
30
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
31 #ifdef HAVE_NSS
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
32
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
33 #undef HAVE_LONG_LONG /* Make Mozilla less angry. If angry, Mozilla SMASH! */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
34
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
35 #include <nspr.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
36 #include <nss.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
37 #include <pk11func.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
38 #include <prio.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
39 #include <secerr.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
40 #include <secmod.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
41 #include <ssl.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
42 #include <sslerr.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
43 #include <sslproto.h>
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
44
17804
016eee704a96 Avoid including NSPR's private header pprio.h just for the prototype of
Stu Tomlinson <stu@nosnilmot.com>
parents: 17752
diff changeset
45 /* This is defined in NSPR's <private/pprio.h>, but to avoid including a
016eee704a96 Avoid including NSPR's private header pprio.h just for the prototype of
Stu Tomlinson <stu@nosnilmot.com>
parents: 17752
diff changeset
46 * private header we duplicate the prototype here */
016eee704a96 Avoid including NSPR's private header pprio.h just for the prototype of
Stu Tomlinson <stu@nosnilmot.com>
parents: 17752
diff changeset
47 NSPR_API(PRFileDesc*) PR_ImportTCPSocket(PRInt32 osfd);
016eee704a96 Avoid including NSPR's private header pprio.h just for the prototype of
Stu Tomlinson <stu@nosnilmot.com>
parents: 17752
diff changeset
48
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
49 typedef struct
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
50 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
51 PRFileDesc *fd;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
52 PRFileDesc *in;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
53 guint handshake_handler;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
54
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
55 } PurpleSslNssData;
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
56
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
57 #define PURPLE_SSL_NSS_DATA(gsc) ((PurpleSslNssData *)gsc->private_data)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
58
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
59 static const PRIOMethods *_nss_methods = NULL;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
60 static PRDescIdentity _identity;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
61
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
62 /* Thank you, Evolution */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
63 static void
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
64 set_errno(int code)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
65 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
66 /* FIXME: this should handle more. */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
67 switch (code) {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
68 case PR_INVALID_ARGUMENT_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
69 errno = EINVAL;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
70 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
71 case PR_PENDING_INTERRUPT_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
72 errno = EINTR;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
73 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
74 case PR_IO_PENDING_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
75 errno = EAGAIN;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
76 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
77 case PR_WOULD_BLOCK_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
78 errno = EAGAIN;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
79 /*errno = EWOULDBLOCK; */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
80 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
81 case PR_IN_PROGRESS_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
82 errno = EINPROGRESS;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
83 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
84 case PR_ALREADY_INITIATED_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
85 errno = EALREADY;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
86 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
87 case PR_NETWORK_UNREACHABLE_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
88 errno = EHOSTUNREACH;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
89 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
90 case PR_CONNECT_REFUSED_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
91 errno = ECONNREFUSED;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
92 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
93 case PR_CONNECT_TIMEOUT_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
94 case PR_IO_TIMEOUT_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
95 errno = ETIMEDOUT;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
96 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
97 case PR_NOT_CONNECTED_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
98 errno = ENOTCONN;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
99 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
100 case PR_CONNECT_RESET_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
101 errno = ECONNRESET;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
102 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
103 case PR_IO_ERROR:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
104 default:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
105 errno = EIO;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
106 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
107 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
108 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
109
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
110 static gchar *get_error_text()
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
111 {
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
112 PRInt32 len = PR_GetErrorTextLength();
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
113 gchar *ret = NULL;
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
114
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
115 if (len > 0) {
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
116 ret = g_malloc(len + 1);
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
117 len = PR_GetErrorText(ret);
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
118 ret[len] = '\0';
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
119 }
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
120
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
121 return ret;
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
122 }
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
123
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
124 static void
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
125 ssl_nss_init_nss(void)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
126 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
127 char *lib;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
128 PR_Init(PR_SYSTEM_THREAD, PR_PRIORITY_NORMAL, 1);
16820
2a98d8b6095e Proabably fixes ticket #578, it's the recommended way of initializing NSS
Stu Tomlinson <stu@nosnilmot.com>
parents: 16673
diff changeset
129 NSS_NoDB_Init(".");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
130
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
131 /* TODO: Fix this so autoconf does the work trying to find this lib. */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
132 #ifndef _WIN32
16098
634b96915d2e Death to Binreloc\!
Sean Egan <seanegan@gmail.com>
parents: 15823
diff changeset
133 lib = g_strdup(LIBDIR "/libnssckbi.so");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
134 #else
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
135 lib = g_strdup("nssckbi.dll");
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
136 #endif
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
137 SECMOD_AddNewModule("Builtins", lib, 0, 0);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
138 g_free(lib);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
139 NSS_SetDomesticPolicy();
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
140
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
141 _identity = PR_GetUniqueIdentity("Purple");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
142 _nss_methods = PR_GetDefaultIOMethods();
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
143 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
144
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
145 static SECStatus
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
146 ssl_auth_cert(void *arg, PRFileDesc *socket, PRBool checksig,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
147 PRBool is_server)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
148 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
149 return SECSuccess;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
150
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
151 #if 0
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
152 CERTCertificate *cert;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
153 void *pinArg;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
154 SECStatus status;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
155
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
156 cert = SSL_PeerCertificate(socket);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
157 pinArg = SSL_RevealPinArg(socket);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
158
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
159 status = CERT_VerifyCertNow((CERTCertDBHandle *)arg, cert, checksig,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
160 certUsageSSLClient, pinArg);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
161
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
162 if (status != SECSuccess) {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
163 purple_debug_error("nss", "CERT_VerifyCertNow failed\n");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
164 CERT_DestroyCertificate(cert);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
165 return status;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
166 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
167
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
168 CERT_DestroyCertificate(cert);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
169 return SECSuccess;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
170 #endif
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
171 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
172
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
173 static SECStatus
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
174 ssl_bad_cert(void *arg, PRFileDesc *socket)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
175 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
176 SECStatus status = SECFailure;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
177 PRErrorCode err;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
178
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
179 if (arg == NULL)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
180 return status;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
181
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
182 *(PRErrorCode *)arg = err = PORT_GetError();
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
183
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
184 switch (err)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
185 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
186 case SEC_ERROR_INVALID_AVA:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
187 case SEC_ERROR_INVALID_TIME:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
188 case SEC_ERROR_BAD_SIGNATURE:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
189 case SEC_ERROR_EXPIRED_CERTIFICATE:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
190 case SEC_ERROR_UNKNOWN_ISSUER:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
191 case SEC_ERROR_UNTRUSTED_CERT:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
192 case SEC_ERROR_CERT_VALID:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
193 case SEC_ERROR_EXPIRED_ISSUER_CERTIFICATE:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
194 case SEC_ERROR_CRL_EXPIRED:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
195 case SEC_ERROR_CRL_BAD_SIGNATURE:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
196 case SEC_ERROR_EXTENSION_VALUE_INVALID:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
197 case SEC_ERROR_CA_CERT_INVALID:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
198 case SEC_ERROR_CERT_USAGES_INVALID:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
199 case SEC_ERROR_UNKNOWN_CRITICAL_EXTENSION:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
200 status = SECSuccess;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
201 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
202
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
203 default:
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
204 status = SECFailure;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
205 break;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
206 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
207
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
208 purple_debug_error("nss", "Bad certificate: %d\n", err);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
209
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
210 return status;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
211 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
212
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
213 static gboolean
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
214 ssl_nss_init(void)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
215 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
216 return TRUE;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
217 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
218
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
219 static void
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
220 ssl_nss_uninit(void)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
221 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
222 PR_Cleanup();
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
223
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
224 _nss_methods = NULL;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
225 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
226
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
227 static void
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
228 ssl_nss_handshake_cb(gpointer data, int fd, PurpleInputCondition cond)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
229 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
230 PurpleSslConnection *gsc = (PurpleSslConnection *)data;
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
231 PurpleSslNssData *nss_data = gsc->private_data;
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
232
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
233 /* I don't think this the best way to do this...
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
234 * It seems to work because it'll eventually use the cached value
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
235 */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
236 if(SSL_ForceHandshake(nss_data->in) != SECSuccess) {
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
237 gchar *error_txt;
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
238 set_errno(PR_GetError());
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
239 if (errno == EAGAIN || errno == EWOULDBLOCK)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
240 return;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
241
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
242 error_txt = get_error_text();
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
243 purple_debug_error("nss", "Handshake failed %s (%d)\n", error_txt ? error_txt : "", PR_GetError());
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
244 g_free(error_txt);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
245
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
246 if (gsc->error_cb != NULL)
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
247 gsc->error_cb(gsc, PURPLE_SSL_HANDSHAKE_FAILED, gsc->connect_cb_data);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
248
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
249 purple_ssl_close(gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
250
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
251 return;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
252 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
253
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
254 purple_input_remove(nss_data->handshake_handler);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
255 nss_data->handshake_handler = 0;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
256
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
257 gsc->connect_cb(gsc->connect_cb_data, gsc, cond);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
258 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
259
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
260 static void
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
261 ssl_nss_connect(PurpleSslConnection *gsc)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
262 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
263 PurpleSslNssData *nss_data = g_new0(PurpleSslNssData, 1);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
264 PRSocketOptionData socket_opt;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
265
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
266 gsc->private_data = nss_data;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
267
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
268 nss_data->fd = PR_ImportTCPSocket(gsc->fd);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
269
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
270 if (nss_data->fd == NULL)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
271 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
272 purple_debug_error("nss", "nss_data->fd == NULL!\n");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
273
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
274 if (gsc->error_cb != NULL)
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
275 gsc->error_cb(gsc, PURPLE_SSL_CONNECT_FAILED, gsc->connect_cb_data);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
276
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
277 purple_ssl_close((PurpleSslConnection *)gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
278
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
279 return;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
280 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
281
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
282 socket_opt.option = PR_SockOpt_Nonblocking;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
283 socket_opt.value.non_blocking = PR_TRUE;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
284
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
285 if (PR_SetSocketOption(nss_data->fd, &socket_opt) != PR_SUCCESS) {
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
286 gchar *error_txt = get_error_text();
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
287 purple_debug_warning("nss", "unable to set socket into non-blocking mode: %s (%d)\n", error_txt ? error_txt : "", PR_GetError());
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
288 g_free(error_txt);
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
289 }
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
290
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
291 nss_data->in = SSL_ImportFD(NULL, nss_data->fd);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
292
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
293 if (nss_data->in == NULL)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
294 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
295 purple_debug_error("nss", "nss_data->in == NUL!\n");
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
296
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
297 if (gsc->error_cb != NULL)
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
298 gsc->error_cb(gsc, PURPLE_SSL_CONNECT_FAILED, gsc->connect_cb_data);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
299
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
300 purple_ssl_close((PurpleSslConnection *)gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
301
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
302 return;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
303 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
304
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
305 SSL_OptionSet(nss_data->in, SSL_SECURITY, PR_TRUE);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
306 SSL_OptionSet(nss_data->in, SSL_HANDSHAKE_AS_CLIENT, PR_TRUE);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
307
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
308 SSL_AuthCertificateHook(nss_data->in,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
309 (SSLAuthCertificate)ssl_auth_cert,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
310 (void *)CERT_GetDefaultCertDB());
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
311 SSL_BadCertHook(nss_data->in, (SSLBadCertHandler)ssl_bad_cert, NULL);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
312
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
313 if(gsc->host)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
314 SSL_SetURL(nss_data->in, gsc->host);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
315
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
316 #if 0
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
317 /* This seems like it'd the be the correct way to implement the
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
318 nonblocking stuff, but it doesn't seem to work */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
319 SSL_HandshakeCallback(nss_data->in,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
320 (SSLHandshakeCallback) ssl_nss_handshake_cb, gsc);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
321 #endif
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
322 SSL_ResetHandshake(nss_data->in, PR_FALSE);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
323
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
324 nss_data->handshake_handler = purple_input_add(gsc->fd,
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
325 PURPLE_INPUT_READ, ssl_nss_handshake_cb, gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
326
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
327 ssl_nss_handshake_cb(gsc, gsc->fd, PURPLE_INPUT_READ);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
328 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
329
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
330 static void
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
331 ssl_nss_close(PurpleSslConnection *gsc)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
332 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
333 PurpleSslNssData *nss_data = PURPLE_SSL_NSS_DATA(gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
334
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
335 if(!nss_data)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
336 return;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
337
17752
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
338 if (nss_data->in) {
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
339 PR_Close(nss_data->in);
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
340 gsc->fd = -1;
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
341 } else if (nss_data->fd) {
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
342 PR_Close(nss_data->fd);
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
343 gsc->fd = -1;
278e22624ce5 A while ago, "Paranoid" emailed devel@p.i, having noticed that purple_ssl_close() closes the ssl fd twice. I meant to commit this fix sooner, but here it is.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 16820
diff changeset
344 }
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
345
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
346 if (nss_data->handshake_handler)
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
347 purple_input_remove(nss_data->handshake_handler);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
348
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
349 g_free(nss_data);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
350 gsc->private_data = NULL;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
351 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
352
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
353 static size_t
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
354 ssl_nss_read(PurpleSslConnection *gsc, void *data, size_t len)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
355 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
356 ssize_t ret;
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
357 PurpleSslNssData *nss_data = PURPLE_SSL_NSS_DATA(gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
358
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
359 ret = PR_Read(nss_data->in, data, len);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
360
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
361 if (ret == -1)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
362 set_errno(PR_GetError());
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
363
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
364 return ret;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
365 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
366
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
367 static size_t
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
368 ssl_nss_write(PurpleSslConnection *gsc, const void *data, size_t len)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
369 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
370 ssize_t ret;
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
371 PurpleSslNssData *nss_data = PURPLE_SSL_NSS_DATA(gsc);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
372
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
373 if(!nss_data)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
374 return 0;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
375
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
376 ret = PR_Write(nss_data->in, data, len);
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
377
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
378 if (ret == -1)
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
379 set_errno(PR_GetError());
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
380
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
381 return ret;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
382 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
383
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
384 static GList *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
385 ssl_nss_peer_certs(PurpleSslConnection *gsc)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
386 {
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
387 PurpleSslNssData *nss_data = PURPLE_SSL_NSS_DATA(gsc);
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
388 CERTCertificate *cert;
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
389 /*
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
390 GList *chain = NULL;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
391 void *pinArg;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
392 SECStatus status;
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
393 */
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
394
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
395 /* TODO: this is a blind guess */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
396 cert = SSL_PeerCertificate(nss_data->fd);
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
397
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
398
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
399
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
400 return NULL;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
401 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
402
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
403 /************************************************************************/
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
404 /* X.509 functionality */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
405 /************************************************************************/
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
406 static PurpleCertificateScheme x509_nss;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
407
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
408 /** Helpr macro to retrieve the NSS certdata from a PurpleCertificate */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
409 #define X509_NSS_DATA(pcrt) ( (CERTCertificate * ) (pcrt->data) )
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
410
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
411 /** Imports a PEM-formatted X.509 certificate from the specified file.
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
412 * @param filename Filename to import from. Format is PEM
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
413 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
414 * @return A newly allocated Certificate structure of the x509_gnutls scheme
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
415 */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
416 static PurpleCertificate *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
417 x509_import_from_file(const gchar *filename)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
418 {
19273
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
419 gchar *rawcert;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
420 gsize len = 0;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
421 CERTCertificate *crt_dat;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
422 PurpleCertificate *crt;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
423
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
424 g_return_val_if_fail(filename, NULL);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
425
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
426 purple_debug_info("nss/x509",
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
427 "Loading certificate from %s\n",
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
428 filename);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
429
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
430 /* Load the raw data up */
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
431 g_return_val_if_fail(
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
432 g_file_get_contents(filename,
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
433 &rawcert, &len,
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
434 NULL ),
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
435 NULL);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
436
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
437 /* Decode the certificate */
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
438 crt_dat = CERT_DecodeCertFromPackage(rawcert, len);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
439 g_free(rawcert);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
440
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
441 g_return_val_if_fail(crt_dat, NULL);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
442
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
443 crt = g_new0(PurpleCertificate, 1);
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
444 crt->scheme = &x509_nss;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
445 crt->data = crt_dat;
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
446
db42632ac756 - Add x509_import_from_file
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19272
diff changeset
447 return crt;
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
448 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
449
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
450 /**
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
451 * Exports a PEM-formatted X.509 certificate to the specified file.
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
452 * @param filename Filename to export to. Format will be PEM
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
453 * @param crt Certificate to export
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
454 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
455 * @return TRUE if success, otherwise FALSE
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
456 */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
457 static gboolean
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
458 x509_export_certificate(const gchar *filename, PurpleCertificate *crt)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
459 {
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
460 /* TODO: WRITEME */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
461 return FALSE;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
462 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
463
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
464 static PurpleCertificate *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
465 x509_copy_certificate(PurpleCertificate *crt)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
466 {
19069
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
467 CERTCertificate *crt_dat;
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
468 PurpleCertificate *newcrt;
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
469
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
470 g_return_val_if_fail(crt, NULL);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
471 g_return_val_if_fail(crt->scheme == &x509_nss, NULL);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
472
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
473 crt_dat = X509_NSS_DATA(crt);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
474 g_return_val_if_fail(crt_dat, NULL);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
475
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
476 /* Create the certificate copy */
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
477 newcrt = g_new0(PurpleCertificate, 1);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
478 newcrt->scheme = &x509_nss;
19083
5b8035030053 - Comment on NSS's refcounting prowess
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19074
diff changeset
479 /* NSS does refcounting automatically */
19069
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
480 newcrt->data = CERT_DupCertificate(crt_dat);
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
481
fcb3e4a2aa9a - x509_nss copy op
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19068
diff changeset
482 return newcrt;
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
483 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
484
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
485 /** Frees a Certificate
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
486 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
487 * Destroys a Certificate's internal data structures and frees the pointer
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
488 * given.
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
489 * @param crt Certificate instance to be destroyed. It WILL NOT be destroyed
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
490 * if it is not of the correct CertificateScheme. Can be NULL
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
491 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
492 */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
493 static void
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
494 x509_destroy_certificate(PurpleCertificate * crt)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
495 {
19070
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
496 CERTCertificate *crt_dat;
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
497
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
498 g_return_if_fail(crt);
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
499 g_return_if_fail(crt->scheme == &x509_nss);
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
500
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
501 crt_dat = X509_NSS_DATA(crt);
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
502 g_return_if_fail(crt_dat);
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
503
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
504 /* Finally we have the certificate. So let's kill it */
19083
5b8035030053 - Comment on NSS's refcounting prowess
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19074
diff changeset
505 /* NSS does refcounting automatically */
19070
7ccb5ab3e07e - x509_nss destroy_certificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19069
diff changeset
506 CERT_DestroyCertificate(crt_dat);
19087
7fa5d10969f4 - x509_destroy_certificate is supposed to free the PurpleCertificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19083
diff changeset
507
7fa5d10969f4 - x509_destroy_certificate is supposed to free the PurpleCertificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19083
diff changeset
508 /* Delete the PurpleCertificate as well */
7fa5d10969f4 - x509_destroy_certificate is supposed to free the PurpleCertificate
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19083
diff changeset
509 g_free(crt);
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
510 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
511
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
512 #if 0
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
513 /** Determines whether one certificate has been issued and signed by another
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
514 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
515 * @param crt Certificate to check the signature of
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
516 * @param issuer Issuer's certificate
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
517 *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
518 * @return TRUE if crt was signed and issued by issuer, otherwise FALSE
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
519 * @TODO Modify this function to return a reason for invalidity?
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
520 */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
521 static gboolean
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
522 x509_certificate_signed_by(PurpleCertificate * crt,
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
523 PurpleCertificate * issuer)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
524 {
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
525 return FALSE;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
526 }
19669
fb3b3e93b9ca Attempt to display user readable error messages for NSS.
Daniel Atallah <daniel.atallah@gmail.com>
parents: 19648
diff changeset
527 #endif
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
528
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
529 static GByteArray *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
530 x509_sha1sum(PurpleCertificate *crt)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
531 {
19074
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
532 CERTCertificate *crt_dat;
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
533 size_t hashlen = 20; /* Size of an sha1sum */
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
534 GByteArray *sha1sum;
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
535 SECItem *derCert; /* DER representation of the cert */
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
536 SECStatus st;
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
537
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
538 g_return_val_if_fail(crt, NULL);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
539 g_return_val_if_fail(crt->scheme == &x509_nss, NULL);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
540
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
541 crt_dat = X509_NSS_DATA(crt);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
542 g_return_val_if_fail(crt_dat, NULL);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
543
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
544 /* Get the certificate DER representation */
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
545 derCert = &(crt_dat->derCert);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
546
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
547 /* Make a hash! */
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
548 sha1sum = g_byte_array_sized_new(hashlen);
19630
578b3c67d52c - ssl-nss now reports a certificate's sha1sum correctly
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19508
diff changeset
549 /* glib leaves the size as 0 by default */
578b3c67d52c - ssl-nss now reports a certificate's sha1sum correctly
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19508
diff changeset
550 sha1sum->len = hashlen;
578b3c67d52c - ssl-nss now reports a certificate's sha1sum correctly
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19508
diff changeset
551
19074
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
552 st = PK11_HashBuf(SEC_OID_SHA1, sha1sum->data,
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
553 derCert->data, derCert->len);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
554
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
555 /* Check for errors */
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
556 if (st != SECSuccess) {
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
557 g_byte_array_free(sha1sum, TRUE);
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
558 purple_debug_error("nss/x509",
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
559 "Error: hashing failed!\n");
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
560 return NULL;
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
561 }
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
562
3004bfa0e846 - x509_nss sha1sum
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19073
diff changeset
563 return sha1sum;
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
564 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
565
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
566 static gchar *
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
567 x509_common_name (PurpleCertificate *crt)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
568 {
19071
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
569 CERTCertificate *crt_dat;
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
570 char *nss_cn;
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
571 gchar *ret_cn;
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
572
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
573 g_return_val_if_fail(crt, NULL);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
574 g_return_val_if_fail(crt->scheme == &x509_nss, NULL);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
575
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
576 crt_dat = X509_NSS_DATA(crt);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
577 g_return_val_if_fail(crt_dat, NULL);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
578
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
579 /* Q:
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
580 Why get a newly allocated string out of NSS, strdup it, and then
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
581 return the new copy?
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
582
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
583 A:
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
584 The NSS LXR docs state that I should use the NSPR free functions on
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
585 the strings that the NSS cert functions return. Since the libpurple
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
586 API expects a g_free()-able string, we make our own copy and return
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
587 that.
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
588
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
589 NSPR is something of a prima donna. */
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
590
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
591 nss_cn = CERT_GetCommonName( &(crt_dat->subject) );
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
592 ret_cn = g_strdup(nss_cn);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
593 PORT_Free(nss_cn);
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
594
d224a1e4b919 - x509_nss get_subject_name (x509_common_name)
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19070
diff changeset
595 return ret_cn;
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
596 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
597
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
598 static gboolean
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
599 x509_check_name (PurpleCertificate *crt, const gchar *name)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
600 {
19072
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
601 CERTCertificate *crt_dat;
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
602 SECStatus st;
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
603
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
604 g_return_val_if_fail(crt, FALSE);
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
605 g_return_val_if_fail(crt->scheme == &x509_nss, FALSE);
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
606
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
607 crt_dat = X509_NSS_DATA(crt);
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
608 g_return_val_if_fail(crt_dat, FALSE);
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
609
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
610 st = CERT_VerifyCertName(crt_dat, name);
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
611
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
612 if (st == SECSuccess) {
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
613 return TRUE;
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
614 }
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
615 else if (st == SECFailure) {
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
616 return FALSE;
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
617 }
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
618
4bdf4ce3473b - ssl-nss x509_nss check_name
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19071
diff changeset
619 /* If we get here...bad things! */
19508
f0c3497e2ea6 - Change g_assert to purple_debug_error
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19273
diff changeset
620 purple_debug_error("nss/x509",
f0c3497e2ea6 - Change g_assert to purple_debug_error
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19273
diff changeset
621 "x509_check_name fell through where it shouldn't "
f0c3497e2ea6 - Change g_assert to purple_debug_error
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19273
diff changeset
622 "have.\n");
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
623 return FALSE;
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
624 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
625
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
626 static gboolean
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
627 x509_times (PurpleCertificate *crt, time_t *activation, time_t *expiration)
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
628 {
19073
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
629 CERTCertificate *crt_dat;
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
630 PRTime nss_activ, nss_expir;
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
631
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
632 g_return_val_if_fail(crt, FALSE);
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
633 g_return_val_if_fail(crt->scheme == &x509_nss, FALSE);
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
634
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
635 crt_dat = X509_NSS_DATA(crt);
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
636 g_return_val_if_fail(crt_dat, FALSE);
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
637
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
638 /* Extract the times into ugly PRTime thingies */
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
639 /* TODO: Maybe this shouldn't throw an error? */
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
640 g_return_val_if_fail(
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
641 SECSuccess == CERT_GetCertTimes(crt_dat,
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
642 &nss_activ, &nss_expir),
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
643 FALSE);
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
644
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
645 if (activation) {
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
646 *activation = nss_activ;
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
647 }
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
648 if (expiration) {
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
649 *expiration = nss_expir;
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
650 }
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
651
2156321c5482 - x509_nss get_times
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19072
diff changeset
652 return TRUE;
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
653 }
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
654
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
655 static PurpleCertificateScheme x509_nss = {
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
656 "x509", /* Scheme name */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
657 N_("X.509 Certificates"), /* User-visible scheme name */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
658 x509_import_from_file, /* Certificate import function */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
659 x509_export_certificate, /* Certificate export function */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
660 x509_copy_certificate, /* Copy */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
661 x509_destroy_certificate, /* Destroy cert */
19272
c861705e934b - Fill out the x509_nss struct properly
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19087
diff changeset
662 NULL, /* Signed-by */
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
663 x509_sha1sum, /* SHA1 fingerprint */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
664 NULL, /* Unique ID */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
665 NULL, /* Issuer Unique ID */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
666 x509_common_name, /* Subject name */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
667 x509_check_name, /* Check subject name */
19648
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
668 x509_times, /* Activation/Expiration time */
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
669
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
670 NULL,
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
671 NULL,
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
672 NULL,
450f4a3c4c0f - Add purple_reserved fields to various structures.
William Ehlhardt <williamehlhardt@gmail.com>
parents: 19630
diff changeset
673 NULL
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
674 };
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
675
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
676 static PurpleSslOps ssl_ops =
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
677 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
678 ssl_nss_init,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
679 ssl_nss_uninit,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
680 ssl_nss_connect,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
681 ssl_nss_close,
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
682 ssl_nss_read,
16673
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
683 ssl_nss_write,
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
684 ssl_nss_peer_certs,
16673
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
685
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
686 /* padding */
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
687 NULL,
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
688 NULL,
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
689 NULL
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
690 };
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
691
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
692 #endif /* HAVE_NSS */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
693
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
694
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
695 static gboolean
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
696 plugin_load(PurplePlugin *plugin)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
697 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
698 #ifdef HAVE_NSS
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
699 if (!purple_ssl_get_ops()) {
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
700 purple_ssl_set_ops(&ssl_ops);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
701 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
702
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
703 /* Init NSS now, so others can use it even if sslconn never does */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
704 ssl_nss_init_nss();
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
705
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
706 /* Register the X.509 functions we provide */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
707 purple_certificate_register_scheme(&x509_nss);
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
708
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
709 return TRUE;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
710 #else
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
711 return FALSE;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
712 #endif
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
713 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
714
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
715 static gboolean
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
716 plugin_unload(PurplePlugin *plugin)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
717 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
718 #ifdef HAVE_NSS
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
719 if (purple_ssl_get_ops() == &ssl_ops) {
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
720 purple_ssl_set_ops(NULL);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
721 }
19068
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
722
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
723 /* Unregister our X.509 functions */
9ac0fbb569a5 - Skeleton for ssl-nss x509 provider
William Ehlhardt <williamehlhardt@gmail.com>
parents: 17804
diff changeset
724 purple_certificate_unregister_scheme(&x509_nss);
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
725 #endif
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
726
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
727 return TRUE;
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
728 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
729
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
730 static PurplePluginInfo info =
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
731 {
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
732 PURPLE_PLUGIN_MAGIC,
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
733 PURPLE_MAJOR_VERSION,
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
734 PURPLE_MINOR_VERSION,
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
735 PURPLE_PLUGIN_STANDARD, /**< type */
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
736 NULL, /**< ui_requirement */
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
737 PURPLE_PLUGIN_FLAG_INVISIBLE, /**< flags */
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
738 NULL, /**< dependencies */
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
739 PURPLE_PRIORITY_DEFAULT, /**< priority */
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
740
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
741 SSL_NSS_PLUGIN_ID, /**< id */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
742 N_("NSS"), /**< name */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
743 VERSION, /**< version */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
744 /** summary */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
745 N_("Provides SSL support through Mozilla NSS."),
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
746 /** description */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
747 N_("Provides SSL support through Mozilla NSS."),
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
748 "Christian Hammond <chipx86@gnupdate.org>",
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
749 PURPLE_WEBSITE, /**< homepage */
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
750
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
751 plugin_load, /**< load */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
752 plugin_unload, /**< unload */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
753 NULL, /**< destroy */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
754
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
755 NULL, /**< ui_info */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
756 NULL, /**< extra_info */
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
757 NULL, /**< prefs_info */
16673
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
758 NULL, /**< actions */
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
759
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
760 /* padding */
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
761 NULL,
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
762 NULL,
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
763 NULL,
6531f1a2e1d7 Added NULL pads to ssl stuff
Gary Kramlich <grim@reaperworld.com>
parents: 16098
diff changeset
764 NULL
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
765 };
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
766
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
767 static void
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
768 init_plugin(PurplePlugin *plugin)
15374
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
769 {
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
770 }
5fe8042783c1 Rename gtk/ and libgaim/ to pidgin/ and libpurple/
Sean Egan <seanegan@gmail.com>
parents:
diff changeset
771
15823
32c366eeeb99 sed -ie 's/gaim/purple/g'
Sean Egan <seanegan@gmail.com>
parents: 15374
diff changeset
772 PURPLE_INIT_PLUGIN(ssl_nss, init_plugin, info)