summaryrefslogtreecommitdiff
path: root/configmgr/source/inc/bootstrap.hxx
blob: 744c8de7bbbc40bb19b08f8e874d877c794a6c78 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
/*************************************************************************
 *
 *  $RCSfile: bootstrap.hxx,v $
 *
 *  $Revision: 1.21 $
 *
 *  last change: $Author: jb $ $Date: 2002-10-24 15:44:01 $
 *
 *  The Contents of this file are made available subject to the terms of
 *  either of the following licenses
 *
 *         - GNU Lesser General Public License Version 2.1
 *         - Sun Industry Standards Source License Version 1.1
 *
 *  Sun Microsystems Inc., October, 2000
 *
 *  GNU Lesser General Public License Version 2.1
 *  =============================================
 *  Copyright 2000 by Sun Microsystems, Inc.
 *  901 San Antonio Road, Palo Alto, CA 94303, USA
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License version 2.1, as published by the Free Software Foundation.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *  MA  02111-1307  USA
 *
 *
 *  Sun Industry Standards Source License Version 1.1
 *  =================================================
 *  The contents of this file are subject to the Sun Industry Standards
 *  Source License Version 1.1 (the "License"); You may not use this file
 *  except in compliance with the License. You may obtain a copy of the
 *  License at http://www.openoffice.org/license.html.
 *
 *  Software provided under this License is provided on an "AS IS" basis,
 *  WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
 *  WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
 *  MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
 *  See the License for the specific provisions governing your rights and
 *  obligations concerning the Software.
 *
 *  The Initial Developer of the Original Code is: Sun Microsystems, Inc.
 *
 *  Copyright: 2000 by Sun Microsystems, Inc.
 *
 *  All Rights Reserved.
 *
 *  Contributor(s): _______________________________________
 *
 *
 ************************************************************************/

#ifndef CONFIGMGR_BOOTSTRAP_HXX_
#define CONFIGMGR_BOOTSTRAP_HXX_

#ifndef _COM_SUN_STAR_UNO_REFERENCE_HXX_
#include <com/sun/star/uno/Reference.hxx>
#endif
#ifndef _COM_SUN_STAR_UNO_SEQUENCE_HXX_
#include <com/sun/star/uno/Sequence.hxx>
#endif
#ifndef _COM_SUN_STAR_UNO_ANY_HXX_
#include <com/sun/star/uno/Any.hxx>
#endif
#ifndef _COM_SUN_STAR_BEANS_NAMEDVALUE_HPP_
#include <com/sun/star/beans/NamedValue.hpp>
#endif
#ifndef _COM_SUN_STAR_UNO_XCOMPONENTCONTEXT_HPP_
#include <com/sun/star/uno/XComponentContext.hpp>
#endif
#ifndef _COM_SUN_STAR_LANG_ILLEGALARGUMENTEXCEPTION_HPP_
#include <com/sun/star/lang/IllegalArgumentException.hpp>
#endif
#ifndef _COM_SUN_STAR_LANG_XMULTISERVICEFACTORY_HPP_
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#endif
#ifndef _RTL_USTRING_HXX_
#include <rtl/ustring.hxx>
#endif

#ifndef INCLUDED_MAP
#include <map>
#define INCLUDED_MAP
#endif

namespace osl {
    class Profile;
}

namespace configmgr
{
    class IConfigSession;

    // ===================================================================================

    namespace uno = ::com::sun::star::uno;
    namespace lang = ::com::sun::star::lang;
    namespace beans = ::com::sun::star::beans;
    using ::rtl::OUString;

    // ===================================================================================
    #define UNO_SESSION_IDENTIFIER              "uno"
    #define PORTAL_SESSION_IDENTIFIER           "portal"
    #define REMOTE_SESSION_IDENTIFIER           "remote"
    #define LOCAL_SESSION_IDENTIFIER            "local"
    #define SETUP_SESSION_IDENTIFIER            "setup"
    #define PLUGIN_SESSION_IDENTIFIER           "plugin"


    // ===================================================================================
    // ===================================================================================
    // = Settings
    // ===================================================================================
    class Settings
    {
    public:
        enum Origin
        {
            SO_NOT_SET,
            SO_UNKNOWN,
            SO_FALLBACK,
            SO_INIFILE,
            SO_BOOTSTRAP,
            SO_DEFAULT,
            SO_OVERRIDE,
            SO_ADJUSTMENT,
            SO_MANUAL
        };
        typedef OUString Name;

        // a single setting
        class Setting
        {
            uno::Any        m_aValue;
            Origin          m_eOrigin;
        public:
            Setting() : m_aValue(), m_eOrigin(SO_NOT_SET) { }
            Setting(const OUString& _rValue, Origin _eOrigin) : m_aValue(uno::makeAny(_rValue)), m_eOrigin(_eOrigin) { }
            Setting(const sal_Int32 _nValue, Origin _eOrigin) : m_aValue(uno::makeAny(_nValue)), m_eOrigin(_eOrigin) { }
            Setting(const uno::Any& _rValue, Origin _eOrigin) : m_aValue(_rValue), m_eOrigin(_eOrigin) { }


            uno::Any    value()  const { return m_aValue; }
            Origin      origin() const { return m_eOrigin; };

            OUString        toString() const;
            sal_Int32       toInt32() const;
            sal_Bool        toBool() const;
        };
    protected:
        typedef std::map< Name, Setting > SettingsImpl;
        SettingsImpl        m_aImpl;

    public:
        typedef SettingsImpl::const_iterator Iterator;
    public:
        /// default ctor
        Settings();

        /** construct a settings object
           containing the given overrides

        */
        Settings(const uno::Sequence< uno::Any >& _rOverrides, Origin _eOrigin = SO_OVERRIDE);

        /// merge the given overrides into the object itself
        void mergeOverrides(const Settings& _rOverrides);

        // check setting existence
        sal_Bool        haveSetting(Name const& _pName) const;
        Origin          getOrigin(Name const& _pName) const;

        void            putSetting(Name const&  _pName, const Setting& _rSetting);
        void            clearSetting(Name const& _pName);

        OUString        getStringSetting(Name const& _pName) const;
        sal_Int32       getIntSetting(Name const& _pName) const;
        sal_Bool        getBoolSetting(Name const& _pName) const;
        Setting         getSetting(Name const& _pName) const;
        Setting         getMaybeSetting(Name const& _pName) const;

        SettingsImpl::size_type size() const { return m_aImpl.size(); }
        Iterator begin()    const { return m_aImpl.begin(); }
        Iterator end()      const { return m_aImpl.end(); }

        void swap(Settings& _rOther) { m_aImpl.swap(_rOther.m_aImpl); }
    private:
        void implAddOverrides(const uno::Sequence< uno::Any >& _rOverrides, Origin _eOrigin);
        bool implExtractOverride(const uno::Any & _rOverride, Name& _rName, uno::Any& _rValue);
    };


    class ConnectionSettings
    {
        friend class BootstrapSettings;

        Settings m_aSettings;

        ConnectionSettings() : m_aSettings() {};
    public:
        ConnectionSettings(const uno::Sequence< uno::Any >& _rOverrides,
                            Settings::Origin _eOrigin = Settings::SO_OVERRIDE);

        /// merge the given overrides into the object itself
        void mergeOverrides(const Settings& _rOverrides)
        {
            implMergeOverrides(_rOverrides);
            implNormalizeSettings();
        }

        /// merge the given overrides into the object itself
        void mergeOverrides(const ConnectionSettings& _rOverrides)
        {
            implMergeOverrides(_rOverrides.m_aSettings);
        }

        bool validate();

        bool isComplete() const;
        bool isComplete(OUString const& aSessionType) const;

        sal_Bool    isSessionTypeKnown() const;

        sal_Bool    hasUser() const;
        sal_Bool    hasPassword() const;

        sal_Bool    hasLocale() const;
        sal_Bool    hasAsyncSetting() const;
        sal_Bool    hasOfflineSetting() const;

        sal_Bool    hasServer() const;
        sal_Bool    hasPort() const;
        sal_Bool    hasTimeout() const;
        sal_Bool    hasService() const;

        sal_Bool    isPlugin() const;
        sal_Bool    isLocalSession() const;
        sal_Bool    isRemoteSession() const;
        bool        isUnoBackend() const;

        sal_Bool    hasUnoBackendService() const;
        sal_Bool    hasUnoBackendWrapper() const;

        sal_Bool    isSourcePathValid() const;
        sal_Bool    isUpdatePathValid() const;
        sal_Bool    hasReinitializeFlag() const;

        // get a special setting
        OUString    getSessionType() const;
        sal_Bool    isAdminSession() const;

        OUString    getUnoBackendService() const;
        OUString    getUnoBackendWrapper() const;

        OUString    getUser() const;
        OUString    getPassword() const;

        OUString    getLocale() const;
        sal_Bool    getAsyncSetting() const;
        sal_Bool    getOfflineSetting() const;

        OUString    getSourcePath() const;
        OUString    getUpdatePath() const;
        sal_Bool    getReinitializeFlag() const;

        OUString    getServer() const;
        OUString    getService() const;
        sal_Int32   getPort() const;
        sal_Int32   getTimeout() const;

        // make sure this behaves as a user session
        void setUserSession();
        void setUserSession(const OUString& _rRemoteServiceName);

        // make sure this behaves as an administrative session
        void setAdminSession();
        void setAdminSession(const OUString& _rRemoteServiceName);

        // set a new session type. Must be one of the *_SESSION_IDENTIFIER defines
        void setSessionType(const OUString& _rSessionIdentifier, Settings::Origin _eOrigin /*= SO_MANUAL*/);

        // set a desired service, only necessary in remote environments
        sal_Bool    isServiceRequired() const;
        void        setService(const OUString& _rService, Settings::Origin _eOrigin /*= SO_MANUAL*/);

        // set this to a wildcard locale
        void        setAnyLocale(Settings::Origin _eOrigin /*= SO_MANUAL*/);

        IConfigSession* createConnection(
            uno::Reference< lang::XMultiServiceFactory > const& _rxServiceMgr) const;

        void swap(ConnectionSettings& _rOther) { m_aSettings.swap(_rOther.m_aSettings); }

        uno::Sequence< beans::NamedValue > getUnoSettings() const;

    private:
        bool checkSettings() const;

        /** @return <TRUE/> if the setting exists and is a valid path
        */
        // sal_Bool isValidPathSetting(Settings::Name const& _pSetting) const;

        // if we do not already have the given config path setting, ensure that it exists (calculated relative to a given path)
        //sal_Bool ensureConfigPath(Settings::Name const& _pSetting, const OUString& _rBasePath);

        /// merge the given overrides into the object itself
        void implMergeOverrides(const Settings& _rOverrides);

        // ensure that the named setting is a valid file URL
        bool implNormalizePathSetting(Settings::Name const& _pSetting);

        // normalize the server and port settings
        void implNormalizeRemoteServer();

        // transform settings that are accepted for compatibility reasons to their normal form
        void implNormalizeSettings();

        // tries to ensure that a session type is set
        bool implDetermineSessionType();

    // convenience wrappers for Settings members
    public:
        sal_Bool    haveSetting(Settings::Name const& _pName) const
        { return m_aSettings.haveSetting(_pName); }

        Settings::Setting   getSetting(Settings::Name const& _pName) const
        { return m_aSettings.getSetting(_pName); }

    // private convenience wrappers for Settings members
    private:
        void        putSetting(Settings::Name const&  _pName, const Settings::Setting& _rSetting)
        { m_aSettings.putSetting(_pName,_rSetting); }

        void        clearSetting(Settings::Name const& _pName)
        { m_aSettings.clearSetting(_pName); }
    };

// ===================================================================================

// ===================================================================================
    class BootstrapSettings
    {
    public:
        typedef uno::Reference< uno::XComponentContext > Context;

        ConnectionSettings  settings; /// the settings collected from bootstrapping (may work even if !valid)
        bool                valid;    /// indicates whether the whole bootstrap process was executed successfully

        explicit
        BootstrapSettings(Context const & xContext)
        : settings()
        , valid(false)
        {
            bootstrap(xContext);
        }

        void raiseBootstrapException( uno::Reference< uno::XInterface > const & xErrorContext ) const;

        static OUString getURL();
    private:
        void bootstrap(Context const & xContext);

        struct Impl;
        friend struct Impl;
    };
// ===================================================================================

    // a transition helper
    BootstrapSettings::Context getBootstrapContext(const uno::Reference< lang::XMultiServiceFactory >& _xORB);

// ===================================================================================
}

#endif // CONFIGMGR_BOOTSTRAP_HXX_