libdap Updated for version 3.21.1
libdap4 is an implementation of OPeNDAP's DAP protocol.
|
Holds information about the link from a DAP2 client to a dataset. More...
#include <Connect.h>
Suppress the C++ defaults for these. | |
Connect () | |
Connect (const Connect &) | |
Connect & | operator= (const Connect &) |
Connect (const string &name, string uname="", string password="") | |
Create an instance of Connect. | |
virtual | ~Connect () |
bool | is_local () |
virtual string | URL (bool CE=true) |
Get the object's URL. | |
virtual string | CE () |
Get the Connect's constraint expression. | |
void | set_credentials (string u, string p) |
Set the credentials for responding to challenges while dereferencing URLs. | |
void | set_accept_deflate (bool deflate) |
void | set_xdap_protocol (int major, int minor) |
void | set_cache_enabled (bool enabled) |
bool | is_cache_enabled () |
void | set_xdap_accept (int major, int minor) |
string | get_version () |
string | get_protocol () |
virtual string | request_version () |
virtual string | request_protocol () |
virtual void | request_das (DAS &das) |
Get the DAS from a server. | |
virtual void | request_das_url (DAS &das) |
Get the DAS from a server. | |
virtual void | request_dds (DDS &dds, string expr="") |
Get the DDS from a server. | |
virtual void | request_dds_url (DDS &dds) |
Get the DDS from a server. | |
virtual void | request_ddx (DDS &dds, string expr="") |
Get the DDX from a server. | |
virtual void | request_ddx_url (DDS &dds) |
The 'url' version of request_ddx. | |
virtual void | request_data (DataDDS &data, string expr="") |
Get the DAS from a server. | |
virtual void | request_data_url (DataDDS &data) |
Get the DAS from a server. | |
virtual void | request_data_ddx (DataDDS &data, string expr="") |
virtual void | request_data_ddx_url (DataDDS &data) |
virtual void | read_data (DataDDS &data, Response *rs) |
Read data which is preceded by MIME headers. This method works for both data dds and data ddx responses. | |
virtual void | read_data_no_mime (DataDDS &data, Response *rs) |
Read data from a file which does not have response MIME headers. This method is a companion to read_data(). While read_data() assumes that the response has MIME headers, this method does not. If you call this with a Response that does contain headers, it will throw an Error (and the message is likely to be inscrutable). | |
virtual void | read_data (DDS &data, Response *rs) |
virtual void | read_data_no_mime (DDS &data, Response *rs) |
Holds information about the link from a DAP2 client to a dataset.
Connect objects are used as containers for information pertaining to the connection a user program makes to a dataset. The dataset may be either local (for example, a file on the user's own computer) or a remote dataset. In the latter case a DAP2 URL will be used to reference the dataset, instead of a filename.
Connect contains methods which can be used to read the DAP2 DAS and DDS objects from the remote dataset as well as reading data. The class understands in a rudimentary way how DAP2 constraint expressions are formed and how to manage them.
Connect also provides additional services such as automatic decompression of compressed data and and error processing.
|
protected |
|
protected |
Create an instance of Connect.
The Connect constructor requires a name
, which is the URL to which the connection is to be made.
n | The URL for the virtual connection. |
uname | Use this username for authentication. Null by default. |
password | Password to use for authentication. Null by default. |
Definition at line 297 of file Connect.cc.
|
virtual |
Definition at line 338 of file Connect.cc.
|
virtual |
Get the Connect's constraint expression.
Return the constraint expression (CE) part of the Connect URL. Note that this CE is supplied as part of the URL passed to the Connect's constructor. It is not the CE passed to the request_data()
function.
Definition at line 1093 of file Connect.cc.
|
inline |
|
inline |
Return the protocol/implementation version of the most recent response. This is a poorly designed method, but it returns information that is useful when used correctly. Before a response is made, this contains the string "unknown." This should ultimately hold the protocol version; it currently holds the implementation version.
@see get_protocol() @deprecated
bool libdap::Connect::is_cache_enabled | ( | ) |
Definition at line 1136 of file Connect.cc.
bool libdap::Connect::is_local | ( | ) |
Definition at line 1057 of file Connect.cc.
Read data which is preceded by MIME headers. This method works for both data dds and data ddx responses.
data | Result. |
rs | Read from this Response object. |
Definition at line 948 of file Connect.cc.
Definition at line 957 of file Connect.cc.
Read data from a file which does not have response MIME headers. This method is a companion to read_data(). While read_data() assumes that the response has MIME headers, this method does not. If you call this with a Response that does contain headers, it will throw an Error (and the message is likely to be inscrutable).
data | Result. |
rs | Read from this Response object. |
Definition at line 1016 of file Connect.cc.
Definition at line 1035 of file Connect.cc.
|
virtual |
Get the DAS from a server.
Reads the DAS corresponding to the dataset in the Connect object's URL. Although DAP does not support using CEs with DAS requests, if present in the Connect object's instance, they will be escaped and passed as the query string of the request.
das | Result. |
Reimplemented in libdap::AISConnect.
Definition at line 419 of file Connect.cc.
|
virtual |
Get the DAS from a server.
Reads the DAS corresponding to the dataset in the Connect object's URL. Although DAP does not support using CEs with DAS requests, if present in the Connect object's instance, they will be escaped and passed as the query string of the request.
Different from request_das method in that this method uses the URL as given without attaching .das or projections or selections.
das | Result. |
Definition at line 482 of file Connect.cc.
Get the DAS from a server.
Reads the DataDDS object corresponding to the dataset in the Connect object's URL. If present in the Connect object's instance, a CE will be escaped, combined with expr
and passed as the query string of the request. The result is a DataDDS which contains the data values bound to variables.
data | Result. |
expr | Send this constraint expression to the server. |
Definition at line 814 of file Connect.cc.
Definition at line 883 of file Connect.cc.
|
virtual |
Definition at line 915 of file Connect.cc.
|
virtual |
Get the DAS from a server.
Reads the DataDDS object corresponding to the dataset in the Connect object's URL. If present in the Connect object's instance, a CE will be escaped, combined with expr
and passed as the query string of the request. The result is a DataDDS which contains the data values bound to variables.
Different from request_data in that this method uses the syntax of the new OPeNDAP server commands using dispatch
data | Result. |
Definition at line 862 of file Connect.cc.
Get the DDS from a server.
Reads the DDS corresponding to the dataset in the Connect object's URL. If present in the Connect object's instance, a CE will be escaped, combined with expr
and passed as the query string of the request.
dds | Result. |
expr | Send this constraint expression to the server. |
Definition at line 545 of file Connect.cc.
|
virtual |
Get the DDS from a server.
Reads the DDS corresponding to the dataset in the Connect object's URL. If present in the Connect object's instance, a CE will be escaped, combined with expr
and passed as the query string of the request.
Different from request_dds method above in that this method assumes URL is complete and does not add anything to the command, such as .dds or projections or selections.
dds | Result. |
Definition at line 621 of file Connect.cc.
Get the DDX from a server.
Reads the DDX corresponding to the dataset in the Connect object's URL. If present in the Connect object's instance, a CE will be escaped, combined with expr
and passed as the query string of the request.
dds | Result. |
expr | Send this constraint expression to the server. |
Definition at line 681 of file Connect.cc.
|
virtual |
The 'url' version of request_ddx.
Definition at line 745 of file Connect.cc.
|
virtual |
Get protocol version information from the server. This is a new method which will ease the transition to DAP 4. Note that this method returns the version of the DAP protocol implemented by the server. The request_version() method returns the server's version number, not the DAP protocol version.
Definition at line 389 of file Connect.cc.
|
virtual |
Get version information from the server. This is a new method which will ease the transition to DAP 4.
Definition at line 355 of file Connect.cc.
void libdap::Connect::set_accept_deflate | ( | bool | deflate | ) |
Set the accept deflate property.
deflate | True if the client can accept compressed responses, False otherwise. |
Definition at line 1113 of file Connect.cc.
void libdap::Connect::set_cache_enabled | ( | bool | cache | ) |
Disable any further use of the client-side cache. In a future version of this software, this should be handled so that the www library is not initialized with the cache running by default.
Definition at line 1131 of file Connect.cc.
Set the credentials for responding to challenges while dereferencing URLs.
u | The username. |
p | The password. |
Definition at line 1105 of file Connect.cc.
void libdap::Connect::set_xdap_accept | ( | int | major, |
int | minor ) |
void libdap::Connect::set_xdap_protocol | ( | int | major, |
int | minor ) |
Set the XDAP-Accept property/header. This is used to send to a server the (highest) DAP protocol version number that this client understands.
major | The client dap protocol major version |
minor | The client dap protocol minor version |
Definition at line 1123 of file Connect.cc.
|
virtual |
Get the object's URL.
Return the Connect object's URL in a string. The URL was set by the class constructor, and may not be reset. If you want to open another URL, you must create another Connect object. There is a Connections class created to handle the management of multiple Connect objects.
ce | If TRUE, the returned URL will include any constraint expression enclosed with the Connect object's URL (including the ? ). If FALSE, any constraint expression will be removed from the URL. The default is TRUE. |
Definition at line 1075 of file Connect.cc.