PageRenderTime 11ms CodeModel.GetById 2ms app.highlight 6ms RepoModel.GetById 2ms app.codeStats 0ms

/security/manager/ssl/src/nsSSLSocketProvider.cpp

http://github.com/zpao/v8monkey
C++ | 98 lines | 52 code | 7 blank | 39 comment | 0 complexity | 7dcc7e9c883e94d28997f9f6e225f877 MD5 | raw file
 1/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 2 *
 3 * ***** BEGIN LICENSE BLOCK *****
 4 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 5 *
 6 * The contents of this file are subject to the Mozilla Public License Version
 7 * 1.1 (the "License"); you may not use this file except in compliance with
 8 * the License. You may obtain a copy of the License at
 9 * http://www.mozilla.org/MPL/
10 *
11 * Software distributed under the License is distributed on an "AS IS" basis,
12 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13 * for the specific language governing rights and limitations under the
14 * License.
15 *
16 * The Original Code is mozilla.org code.
17 *
18 * The Initial Developer of the Original Code is
19 * Netscape Communications Corporation.
20 * Portions created by the Initial Developer are Copyright (C) 1998
21 * the Initial Developer. All Rights Reserved.
22 *
23 * Contributor(s):
24 *   Brian Ryner <bryner@brianryner.com>
25 *
26 * Alternatively, the contents of this file may be used under the terms of
27 * either the GNU General Public License Version 2 or later (the "GPL"), or
28 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29 * in which case the provisions of the GPL or the LGPL are applicable instead
30 * of those above. If you wish to allow use of your version of this file only
31 * under the terms of either the GPL or the LGPL, and not to allow others to
32 * use your version of this file under the terms of the MPL, indicate your
33 * decision by deleting the provisions above and replace them with the notice
34 * and other provisions required by the GPL or the LGPL. If you do not delete
35 * the provisions above, a recipient may use your version of this file under
36 * the terms of any one of the MPL, the GPL or the LGPL.
37 *
38 * ***** END LICENSE BLOCK ***** */
39
40#include "nsSSLSocketProvider.h"
41#include "nsNSSIOLayer.h"
42#include "nsNetError.h"
43
44nsSSLSocketProvider::nsSSLSocketProvider()
45{
46}
47
48nsSSLSocketProvider::~nsSSLSocketProvider()
49{
50}
51
52NS_IMPL_THREADSAFE_ISUPPORTS1(nsSSLSocketProvider, nsISocketProvider)
53
54NS_IMETHODIMP
55nsSSLSocketProvider::NewSocket(PRInt32 family,
56                               const char *host,
57                               PRInt32 port,
58                               const char *proxyHost,
59                               PRInt32 proxyPort,
60                               PRUint32 flags,
61                               PRFileDesc **_result,
62                               nsISupports **securityInfo)
63{
64  nsresult rv = nsSSLIOLayerNewSocket(family,
65                                      host,
66                                      port,
67                                      proxyHost,
68                                      proxyPort,
69                                      _result,
70                                      securityInfo,
71                                      false,
72                                      flags & ANONYMOUS_CONNECT);
73  return (NS_FAILED(rv)) ? NS_ERROR_SOCKET_CREATE_FAILED : NS_OK;
74}
75
76// Add the SSL IO layer to an existing socket
77NS_IMETHODIMP
78nsSSLSocketProvider::AddToSocket(PRInt32 family,
79                                 const char *host,
80                                 PRInt32 port,
81                                 const char *proxyHost,
82                                 PRInt32 proxyPort,
83                                 PRUint32 flags,
84                                 PRFileDesc *aSocket,
85                                 nsISupports **securityInfo)
86{
87  nsresult rv = nsSSLIOLayerAddToSocket(family,
88                                        host,
89                                        port,
90                                        proxyHost,
91                                        proxyPort,
92                                        aSocket,
93                                        securityInfo,
94                                        false,
95                                        flags & ANONYMOUS_CONNECT);
96  
97  return (NS_FAILED(rv)) ? NS_ERROR_SOCKET_CREATE_FAILED : NS_OK;
98}