Qore ConnectionProvider Module Reference 1.10
All Classes Namespaces Functions Variables Modules Pages
ConnectionProvider.qm.dox.h
1// -*- mode: c++; indent-tabs-mode: nil -*-
3
4/* ConnectionProvider.qm Copyright 2016 - 2023 Qore Technologies, s.r.o.
5
6 Permission is hereby granted, free of charge, to any person obtaining a
7 copy of this software and associated documentation files (the "Software"),
8 to deal in the Software without restriction, including without limitation
9 the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 and/or sell copies of the Software, and to permit persons to whom the
11 Software is furnished to do so, subject to the following conditions:
12
13 The above copyright notice and this permission notice shall be included in
14 all copies or substantial portions of the Software.
15
16 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 DEALINGS IN THE SOFTWARE.
23*/
24
25// minimum required Qore module
26
27
28
29
213
215namespace ConnectionProvider {
217
223 *string module;
224
227
229 *softlist<auto> args;
230
232
243
245
256};
257
259
261public hashdecl ConnectionInfo {
263 string name;
264
266 string desc;
267
270
273
276
278 *hash opts;
279
281 string status;
282
284 string type;
285
287 bool up = False;
288
290 *date updated;
291
293
295 string url;
296
299
301
304
306
308 bool locked;
309
311
314
316 hash<auto> tags;
317
319 *hash<string, bool> features;
320
322 bool has_provider = False;
323
326
329
332
335
338};
339
341
343public hashdecl ConfigInfo {
344 string name;
345 string desc;
346 string url;
347 *hash opts;
348};
349
351
353public hashdecl PingInfo {
354 string name;
356
357 string desc;
359
360 *hash opts;
362
363 string url;
365
366 bool ok;
368
369 date time;
371
372 string info;
374
377
379 *hash<ExceptionInfo> ex;
380};
381
383
398 string get_connection_url(string str);
399
400
402
418
419
421
436 *hash<string, AbstractConnection> get_connections(*bool verbose);
437
438
440
455 *hash<string, hash<ConnectionInfo>> get_connection_hash(*bool verbose);
456
457}; // ConnectionProvider namespace
458
459// private, non-exported namespace
460namespace Priv {
461*hash priv_try_get_connections(string mod);
462
463
464ConnectionProvider::AbstractConnection priv_try_get_connection(string mod, string conn);
465
466}; // Priv nsmrspace
abstract base class for connections
Definition: AbstractConnection.qc.dox.h:34
The ConnectionProvider namespace.
Definition: AbstractConnection.qc.dox.h:28
string get_connection_url(string str)
returns a URL string for the given identifier if the identifier is known to a registered connection p...
*hash< string, AbstractConnection > get_connections(*bool verbose)
returns all known connections as a hash keyed by connection identifier; values are AbstractConnection...
AbstractConnection get_connection(string conn)
returns an AbstractConnection object if the identifier is known to a registered connection provider
*hash< string, hash< ConnectionInfo > > get_connection_hash(*bool verbose)
returns a hash of connection information keyed by connection identifier; values are ConnectionInfo ha...
config informaton
Definition: ConnectionProvider.qm.dox.h:343
*hash opts
the options set on the connection
Definition: ConnectionProvider.qm.dox.h:347
string name
the name of the connection
Definition: ConnectionProvider.qm.dox.h:344
string desc
the description
Definition: ConnectionProvider.qm.dox.h:345
string url
the full URL (including any username & password)
Definition: ConnectionProvider.qm.dox.h:346
information that can be used to dynamically construct a connection object
Definition: ConnectionProvider.qm.dox.h:221
string class_name
the name of the constructor's class
Definition: ConnectionProvider.qm.dox.h:226
*string module
any module required to be loaded for the constructor call
Definition: ConnectionProvider.qm.dox.h:223
*string pre_processing
code to execute before construction to preprocess the constructor arguments
Definition: ConnectionProvider.qm.dox.h:255
*string post_processing
code to execute after construction
Definition: ConnectionProvider.qm.dox.h:242
*softlist< auto > args
the constructor arguments
Definition: ConnectionProvider.qm.dox.h:229
connection information hash
Definition: ConnectionProvider.qm.dox.h:261
hash< auto > tags
user-defined key-value pairs associated with the connection
Definition: ConnectionProvider.qm.dox.h:316
bool children_can_support_records
if the data provider or any of its children support records
Definition: ConnectionProvider.qm.dox.h:328
bool loopback
a boolean vaue indicating if the connection is a loopback connection
Definition: ConnectionProvider.qm.dox.h:272
bool has_provider
if the connection supports the data provider API
Definition: ConnectionProvider.qm.dox.h:322
*date last_check
the date/time value of the last connection check (or NOTHING if not checked)
Definition: ConnectionProvider.qm.dox.h:269
*hash opts
the original options used to create the object
Definition: ConnectionProvider.qm.dox.h:278
bool children_can_support_apis
if the data provider or any of its children support requests (APIs)
Definition: ConnectionProvider.qm.dox.h:325
bool monitor
a boolean vaue indicating if the connection should be monitored or not
Definition: ConnectionProvider.qm.dox.h:275
bool up
a boolean vaue indicating the connection is known to be up (will be False if not checked)
Definition: ConnectionProvider.qm.dox.h:287
bool children_can_support_messages
if the data provider or any of its children support messages
Definition: ConnectionProvider.qm.dox.h:334
bool locked
a boolean value indicating whether the connection is locked or not
Definition: ConnectionProvider.qm.dox.h:308
*hash< string, bool > features
connection-defined feature hash
Definition: ConnectionProvider.qm.dox.h:319
string name
the connection name
Definition: ConnectionProvider.qm.dox.h:263
bool children_can_support_transactions
if the data provider or any of its children support transaction management
Definition: ConnectionProvider.qm.dox.h:337
string type
the connection type
Definition: ConnectionProvider.qm.dox.h:284
*date updated
the date/time value of the update (or NOTHING if not updated)
Definition: ConnectionProvider.qm.dox.h:290
bool enabled
a boolean value indicating if the connection should be enabled or not
Definition: ConnectionProvider.qm.dox.h:303
bool debug_data
a boolean value indicating whether the connection should be subject to data debugging
Definition: ConnectionProvider.qm.dox.h:313
bool children_can_support_observers
if the data provider or any of its children support events
Definition: ConnectionProvider.qm.dox.h:331
string status
a string giving the connection's status
Definition: ConnectionProvider.qm.dox.h:281
string desc
the connection description
Definition: ConnectionProvider.qm.dox.h:266
string url
the URL for the connection including the password
Definition: ConnectionProvider.qm.dox.h:295
hash url_hash
a hash of URL information as returned by parse_url()
Definition: ConnectionProvider.qm.dox.h:298
ping response info
Definition: ConnectionProvider.qm.dox.h:353
date time
a relative date/time value giving the elapsed time of the ping operation
Definition: ConnectionProvider.qm.dox.h:369
string desc
the description
Definition: ConnectionProvider.qm.dox.h:357
*hash ping_info
an optional free-form hash giving additional info regarding ping operation or the remote system
Definition: ConnectionProvider.qm.dox.h:375
bool ok
a boolean value giving the result of the ping
Definition: ConnectionProvider.qm.dox.h:366
*hash opts
the options set on the connection
Definition: ConnectionProvider.qm.dox.h:360
string url
a safe version of the URL (without passwords)
Definition: ConnectionProvider.qm.dox.h:363
string name
the name of the connection
Definition: ConnectionProvider.qm.dox.h:354
string info
a string giving the result of the ping ("OK" or an error message)
Definition: ConnectionProvider.qm.dox.h:372