PageRenderTime 23ms CodeModel.GetById 11ms app.highlight 8ms RepoModel.GetById 1ms app.codeStats 0ms

/security/manager/ssl/src/nsTLSSocketProvider.cpp

http://github.com/zpao/v8monkey
C++ | 99 lines | 52 code | 8 blank | 39 comment | 0 complexity | 0c08a4416a0224ea1e835c44740c9173 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) 2000
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 "nsTLSSocketProvider.h"
41#include "nsNSSIOLayer.h"
42#include "nsNetError.h"
43
44nsTLSSocketProvider::nsTLSSocketProvider()
45{
46}
47
48nsTLSSocketProvider::~nsTLSSocketProvider()
49{
50}
51
52NS_IMPL_THREADSAFE_ISUPPORTS1(nsTLSSocketProvider, nsISocketProvider)
53
54NS_IMETHODIMP
55nsTLSSocketProvider::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                                      true,
72                                      flags & ANONYMOUS_CONNECT);
73  
74  return (NS_FAILED(rv)) ? NS_ERROR_SOCKET_CREATE_FAILED : NS_OK;
75}
76
77// Add the SSL IO layer to an existing socket
78NS_IMETHODIMP
79nsTLSSocketProvider::AddToSocket(PRInt32 family,
80                                 const char *host,
81                                 PRInt32 port,
82                                 const char *proxyHost,
83                                 PRInt32 proxyPort,
84                                 PRUint32 flags,
85                                 PRFileDesc *aSocket,
86                                 nsISupports **securityInfo)
87{
88  nsresult rv = nsSSLIOLayerAddToSocket(family,
89                                        host,
90                                        port,
91                                        proxyHost,
92                                        proxyPort,
93                                        aSocket,
94                                        securityInfo,
95                                        true,
96                                        flags & ANONYMOUS_CONNECT);
97  
98  return (NS_FAILED(rv)) ? NS_ERROR_SOCKET_CREATE_FAILED : NS_OK;
99}