t/coverage.sh: Exclude auto-generated c files.
t/unit/: Create one test binary for each *_test.c file.
That'll allow to run more stuff in parallel or single tests more selectively.
That'll allow to run more stuff in parallel or single tests more selectively.
core/time_test: Converted to "loop" tests.
core/store*_test.c: Converted most tests to "loop" tests.
frontend/parser_test: Convert to "loop" tests.
That'll make sure we'll see the errors of all test cases in one test run.
That'll make sure we'll see the errors of all test cases in one test run.
frontend/query_test.c: Added unit tests for the FETCH commands.
parser_test: Add testcases covering operand type checks.
analyzer: Verify the type of arithmetic operands.
analyzer: Check types of comparison operands.
Merged branch 'master' of git://github.com/sysdb/sysdb.git.
frontend: Fixed a memory leak in an error condition in FETCH.
configure: Make sure that PACKAGE_URL is defined.
autoconf < 2.64 don't support PACKAGE_URL.
Thanks to @faxm0dem for reporting the resulting build error on RHEL6 in #1
autoconf < 2.64 don't support PACKAGE_URL.
Thanks to @faxm0dem for reporting the resulting build error on RHEL6 in #1
Merged branch 'master' of git://git.tokkee.org/sysdb.
Check the return value of write() to satisfy GCC's unused-result checks.
t/valgrind.suppress: Suppress various issues in OpenSSL 1.0.0.
integration/query.sh: Test FETCH with FILTER.
frontend: Fixed hostname in error messages in FETCH.
frontend: Fix a memory leak in an error condition in FETCH.
integration/test_lib.sh: Store the CA serial in $TESTDIR.
frontend: Provide more details in the logs when shutting down a connection.
sysdb: Print the server version after (re)connecting.
frontend: Added the SERVER_VERSION command.
This command sends back the server version.
This command sends back the server version.
proto: Make sdb_proto_marshal_int32 a public function.
sysdbd-store-network(5): Documented the store::network plugin.
version-gen.sh: Added .git suffix to default version again.
Release SysDB 0.7.0.
ReleaseNotes: Set 0.7.0 release date to 2015-02-21.
ReleaseNotes: Added draft for the 0.7.0 release.
store::network: Reconnect after losing the connection to the remote side.
store::network: Added support for SSL configuration options.
ssl utils: During shutdown, destroy mutexes as the last step.
Even ERR_free_strings() may call CRYPTO_lock.
Even ERR_free_strings() may call CRYPTO_lock.
store::network: Use INFO level for an informational message.
ssl: Register OpenSSL thread-ID and locking callbacks.
This is required for multi-threaded applications. Else, they "will crash at
random".
This is required for multi-threaded applications. Else, they "will crash at
random".
SSL utils: Added init() and shutdown() functions for global setup/shutdown.
Use those functions in sysdb and sysdbd instead of calling the OpenSSL
functions directly.
Use those functions in sysdb and sysdbd instead of calling the OpenSSL
functions directly.
valgrind.suppress: Ignore a Memcheck:Cond error in libcrypto.
This happens with the libssl version on Travis.
This happens with the libssl version on Travis.
t/integration/: Added simple SSL tests.
parser_test: Added various tests for STORE commands.
README: Add libssl to prerequisites.
sysdb(1), sysdbd(1): Document client authentication.
sysdb(1), sysdbd(1): Document files used by the tools by default.
sysdb(1): Document SSL related command line options.
sysdbd.conf(5): Document the Listen SSL options.
frontend, client: Properly support IPv6 when handling address strings.
client: Prefix all log messages with "client:".
sysdb: Add -A option to specify a CA certificates file.
Unload all plugins when shutting down sysdbd.
This will destruct all registered user-data objects, thus properly shutting
down all internal plugin state (e.g. connections to other systems).
This will destruct all registered user-data objects, thus properly shutting
down all internal plugin state (e.g. connections to other systems).
collectd::unixsock: Fixed a memory leak happening when unloading the module.
client: Check the remote peer name.
sysdbd-syslog(5): Documented LogLevel configuration option.
plugin: Fixed log message for newly registered config callbacks.
syslog plugin: Make log-level configurable.
error utils: Add sdb_error_parse_priority().
sysdbd: Add SSL{Certificate,CertificateKey,CACertificates} config options.
frontend: Support custom SSL options for each listener.
sysdb: Added -K and -C options to specify SSL key and cert files.
sysdb: Use SSL keys and certs in ~/.config/sysdb/ssl/ by default.
utils os: Add sdb_realpath().
This function is similar to realpath() but also expands ~/ to the current
user's home directory.
This function is similar to realpath() but also expands ~/ to the current
user's home directory.
SSL utils: Pass a constant options object to all constructors.
sysdb: Add and use sdb_input_reset().
This simplifies cleanup.
This simplifies cleanup.
Move sdb_get_homedir() from tools/sysdb to utils/os.
SSL utils: Include the relevant filename in all error messages.
SSL utils: Add sdb_ssl_free_options().
client: Make SSL options configurable.
configure: Where available, include version information in the summary.
frontend: Log an INFO message about which listener sockets are in use.
client, sysdb: Let TCP connection use SSL.
client: Don't use select() before reading from a client connection.
This doesn't work well if the connection buffers data (like with the upcoming
SSL support).
This doesn't work well if the connection buffers data (like with the upcoming
SSL support).
frontend, sysdbd: Let all TCP connections use SSL.
Client certificate checks are enforced and the client cert's common name (CN)
is used as the peer name.
Client certificate checks are enforced and the client cert's common name (CN)
is used as the peer name.
SSL utils: Added helper functions for managing OpenSSL servers and clients.
The module provides session management for OpenSSL servers and clients and
helper functions for I/O operations.
The module provides session management for OpenSSL servers and clients and
helper functions for I/O operations.
store::network plugin: Fixed a minor memory leak.
valgrind.suppress: Add a memory leak reported for some dl helper.
Removed a spammy and now unnecessary debug log message.
integration: Use store::network in the query tests.
Set up a second SysDB instance which receives all data from the other
instance. Query the receiver instead of the collector.
Set up a second SysDB instance which receives all data from the other
instance. Query the receiver instead of the collector.
integration: Split off mock_timeseries from mock_plugin.
frontend: Trigger the main thread after putting a connection back in the list.
Else, we'd have pauses of up to a second (select timeout) between processing
subsequent requests from a client because the main thread didn't notice that
an open connection was put back into the waiting queue.
Else, we'd have pauses of up to a second (select timeout) between processing
subsequent requests from a client because the main thread didn't notice that
an open connection was put back into the waiting queue.
store::network: Add a store writer plugin sending objects over the network.
The plugin supports sending data to one or more other SysDB instances using
the wire-format of the STORE command.
The plugin supports sending data to one or more other SysDB instances using
the wire-format of the STORE command.
store: Don't report an error in scan() if the store is still empty.
sysdb: Simplified prompt used for continuation lines.
frontend/store: Free dynamically allocated memory of attribute values.
frontend/store: Fixed parsing of STORE attribute commands.
In this case, the object type is a bit-wise OR of the parent type and the
attribute type.
In this case, the object type is a bit-wise OR of the parent type and the
attribute type.
frontend/store: Fixed parsing of STORE command.
After parsing the type, keep it still around in the current buffer. The
sdb_proto_unmarshal_<type> functions expect to find it as well.
After parsing the type, keep it still around in the current buffer. The
sdb_proto_unmarshal_<type> functions expect to find it as well.
plugin: Let store writer plugin object inherit from generic plugin objects.
Else, we cannot use them in the same way.
Else, we cannot use them in the same way.
client: Use sdb_client_rpc in sdb_client_connect.
client: Added sdb_client_rpc.
This function handles a full RPC call: it sends a message to the server and
waits for the reply. While doing so, it handles all asynchronous log messages.
That is, it'll return the actual result status of the command.
This function handles a full RPC call: it sends a message to the server and
waits for the reply. While doing so, it handles all asynchronous log messages.
That is, it'll return the actual result status of the command.
store: Pass on all stored objects to store writer plugins.
core: Add the store writer plugin type.
A plugin may now provide an implementation of a store by providing a set of
callbacks. For now, this is only about writing to a store. Queries are not
supported through this interface.
A plugin may now provide an implementation of a store by providing a set of
callbacks. For now, this is only about writing to a store. Queries are not
supported through this interface.
plugin: Reload time-series fetcher callbacks as well.
integration/config.sh: Add a test to load and reload a plugin.
t/integration: Add a simple time-series fetcher test.
connection_test: Updated according to latest changes.
sysdbql(7): Document the STORE commands.
connection: Log peer information after accepting a connection.
sysdb: Use the current user's homedir rather than the SysDB user.
connection: Let sdb_connection_accept() handle all connection setup.
… rather than having it split up between the caller and accept().
… rather than having it split up between the caller and accept().
client: Add support for TCP connections.
frontend: Add support for TCP connections.
This is the new default listener type (unless the listen address starts with a
slash in which case a UNIXSOCK connection is used).
This does not support any kind of peer lookup yet. Instead, it'll fully trust
the client for now and accept any username. In the future, this will be
configurable and multiple mechanisms (e.g. ident, SSL cert) will be supported.
This is the new default listener type (unless the listen address starts with a
slash in which case a UNIXSOCK connection is used).
This does not support any kind of peer lookup yet. Instead, it'll fully trust
the client for now and accept any username. In the future, this will be
configurable and multiple mechanisms (e.g. ident, SSL cert) will be supported.
frontend: Make peer detection more flexible.
It's now a property of a listener implementation.
Moved the unixsock implementation over from frontend/connection to
frontend/sock.
It's now a property of a listener implementation.
Moved the unixsock implementation over from frontend/connection to
frontend/sock.
os utils: Fixed a typo in the UDP resolver implementation.
frontend/sock: Simplified internal address handling.
Strip the <type>: prefix early. Else, we'd have to strip it off over and over
again when working with the address string.
Strip the <type>: prefix early. Else, we'd have to strip it off over and over
again when working with the address string.
connection: Update the connection name as early as possible.
This is just to avoid weird error messages if setting up the connection
failed.
This is just to avoid weird error messages if setting up the connection
failed.