Multi-line svn commit, see body.
[shibboleth/cpp-xmltooling.git] / xmltooling / util / CurlNetAccessor.cpp
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements.  See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License.  You may obtain a copy of the License at
8  * 
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  * 
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17
18 /*
19  * $Id$
20  */
21
22 #include "internal.h"
23
24 #include <xercesc/util/XMLUniDefs.hpp>
25 #include <xercesc/util/XMLUni.hpp>
26 #include <xercesc/util/XMLString.hpp>
27 #include <xercesc/util/XMLExceptMsgs.hpp>
28 #include <xmltooling/util/CurlURLInputStream.hpp>
29 #include <xmltooling/util/CurlNetAccessor.hpp>
30
31 using namespace xmltooling;
32
33 const XMLCh CurlNetAccessor::fgMyName[] =
34 {
35     chLatin_C, chLatin_u, chLatin_r, chLatin_l, chLatin_N, chLatin_e,
36     chLatin_t, chLatin_A, chLatin_c, chLatin_c, chLatin_e, chLatin_s,
37     chLatin_s, chLatin_o, chLatin_r, chNull
38 };
39
40
41 CurlNetAccessor::CurlNetAccessor()
42 {
43         initCurl();
44 }
45
46
47 CurlNetAccessor::~CurlNetAccessor()
48 {
49         cleanupCurl();
50 }
51
52
53 //
54 // Global once-only init and cleanup of curl
55 //
56 // The init count used here is not thread protected; we assume
57 // that creation of the CurlNetAccessor will be serialized by
58 // the application. If the application is also using curl, then
59 // care must be taken that curl is initialized only once, by some
60 // other means, or by overloading these methods.
61 //
62 int CurlNetAccessor::fgCurlInitCount = 0;
63
64 void
65 CurlNetAccessor::initCurl()
66 {
67         if (fgCurlInitCount++ == 0)
68                 curl_global_init(       0
69                                                   | CURL_GLOBAL_ALL                     // Initialize all curl modules
70                                         //        | CURL_GLOBAL_WIN32           // Initialize Windows sockets first
71                                         //        | CURL_GLOBAL_SSL                     // Initialize SSL first
72                                                   );
73 }
74
75
76 void
77 CurlNetAccessor::cleanupCurl()
78 {
79         if (fgCurlInitCount > 0 && --fgCurlInitCount == 0)
80                 curl_global_cleanup();
81 }
82
83
84 BinInputStream*
85 CurlNetAccessor::makeNew(const XMLURL&  urlSource, const XMLNetHTTPInfo* httpInfo/*=0*/)
86 {
87         // Just create a CurlURLInputStream
88         // We defer any checking of the url type for curl in CurlURLInputStream
89         CurlURLInputStream* retStrm =
90                 new (urlSource.getMemoryManager()) CurlURLInputStream(urlSource, httpInfo);
91         return retStrm;            
92 }
93