nss: upgrade to release 3.73
[LibreOffice.git] / dbaccess / source / filter / xml / xmlServerDatabase.cxx
blob590db077437b4d39bbe36c50113d9073a8c51839
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include "xmlServerDatabase.hxx"
21 #include "xmlfilter.hxx"
22 #include <xmloff/xmltoken.hxx>
23 #include <strings.hxx>
24 #include <rtl/ustrbuf.hxx>
25 #include <tools/diagnose_ex.h>
27 namespace dbaxml
29 using namespace ::com::sun::star::uno;
30 using namespace ::com::sun::star::xml::sax;
32 OXMLServerDatabase::OXMLServerDatabase( ODBFilter& rImport,
33 const Reference< XFastAttributeList > & _xAttrList) :
34 SvXMLImportContext( rImport )
36 Reference<XPropertySet> xDataSource = rImport.getDataSource();
38 PropertyValue aProperty;
40 OUString sType,sHostName,sPortNumber,sDatabaseName;
41 if (xDataSource.is())
43 for (auto &aIter : sax_fastparser::castToFastAttributeList( _xAttrList ))
45 OUString sValue = aIter.toString();
47 switch( aIter.getToken() & TOKEN_MASK )
49 case XML_TYPE:
50 sType = sValue;
51 break;
52 case XML_HOSTNAME:
53 sHostName = sValue;
54 break;
55 case XML_PORT:
56 sPortNumber = sValue;
57 break;
58 case XML_LOCAL_SOCKET:
59 aProperty.Name = "LocalSocket";
60 aProperty.Value <<= sValue;
61 rImport.addInfo(aProperty);
62 break;
63 case XML_DATABASE_NAME:
64 sDatabaseName = sValue;
65 break;
66 default:
67 XMLOFF_WARN_UNKNOWN("dbaccess", aIter);
71 if ( sType.isEmpty() )
72 return;
74 OUStringBuffer sURL;
75 if ( sType == "sdbc:mysql:jdbc" || sType == "sdbc:mysqlc" || sType == "sdbc:mysql:mysqlc" )
77 sURL.append( sType ).append( ":" ).append(sHostName);
78 if ( !sPortNumber.isEmpty() )
80 sURL.append(":").append(sPortNumber);
82 if ( !sDatabaseName.isEmpty() )
84 sURL.append("/").append(sDatabaseName);
87 else if ( sType == "jdbc:oracle:thin" )
89 sURL.append("jdbc:oracle:thin:@").append(sHostName);
90 if ( !sPortNumber.isEmpty() )
92 sURL.append(":").append(sPortNumber);
94 if ( !sDatabaseName.isEmpty() )
96 sURL.append(":").append(sDatabaseName);
99 else if ( sType == "sdbc:address:ldap" )
101 sURL.append("sdbc:address:ldap:").append(sHostName);
102 if ( !sPortNumber.isEmpty() )
104 sURL.append(":").append(sPortNumber);
107 else
109 sURL.append(sType).append(":").append(sHostName);
110 if ( !sPortNumber.isEmpty() )
112 sURL.append(":").append(sPortNumber);
114 if ( !sDatabaseName.isEmpty() )
116 sURL.append(":").append(sDatabaseName);
121 xDataSource->setPropertyValue(PROPERTY_URL,makeAny(sURL.makeStringAndClear()));
123 catch(const Exception&)
125 DBG_UNHANDLED_EXCEPTION("dbaccess");
129 OXMLServerDatabase::~OXMLServerDatabase()
134 } // namespace dbaxml
136 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */