Commit 7fafde63 by Carlos Martín Nieto

stream: allow registering a user-provided TLS constructor

This allows the application to use their own TLS stream, regardless of
the capabilities of libgit2 itself.
parent d39f643a
...@@ -17,11 +17,16 @@ v0.23 + 1 ...@@ -17,11 +17,16 @@ v0.23 + 1
the opportunity for concurrent operations and not committing any the opportunity for concurrent operations and not committing any
changes until the unlock. changes until the unlock.
* `git_diff_options` added a new callback `progress_cb` to report on the * `git_diff_options` added a new callback `progress_cb` to report on the
progress of the diff as files are being compared. The documentation of progress of the diff as files are being compared. The documentation of
the existing callback `notify_cb` was updated to reflect that it only the existing callback `notify_cb` was updated to reflect that it only
gets called when new deltas are added to the diff. gets called when new deltas are added to the diff.
* `git_stream_register_tls()` lets you register a callback to be used
as the constructor for a TLS stream instead of the libgit2 built-in
one.
### API removals ### API removals
### Breaking API changes ### Breaking API changes
......
...@@ -39,6 +39,19 @@ typedef struct git_stream { ...@@ -39,6 +39,19 @@ typedef struct git_stream {
void (*free)(struct git_stream *); void (*free)(struct git_stream *);
} git_stream; } git_stream;
typedef int (*git_stream_cb)(git_stream **out, const char *host, const char *port);
/**
* Register a TLS stream constructor for the library to use
*
* If a constructor is already set, it will be overwritten. Pass
* `NULL` in order to deregister the current constructor.
*
* @param ctor the constructor to use
* @return 0 or an error code
*/
GIT_EXTERN(int) git_stream_register_tls(git_stream_cb ctor);
GIT_END_DECL GIT_END_DECL
#endif #endif
...@@ -11,8 +11,21 @@ ...@@ -11,8 +11,21 @@
#include "openssl_stream.h" #include "openssl_stream.h"
#include "stransport_stream.h" #include "stransport_stream.h"
static git_stream_cb tls_ctor;
int git_stream_register_tls(git_stream_cb ctor)
{
tls_ctor = ctor;
return 0;
}
int git_tls_stream_new(git_stream **out, const char *host, const char *port) int git_tls_stream_new(git_stream **out, const char *host, const char *port)
{ {
if (tls_ctor)
return tls_ctor(out, host, port);
#ifdef GIT_SECURE_TRANSPORT #ifdef GIT_SECURE_TRANSPORT
return git_stransport_stream_new(out, host, port); return git_stransport_stream_new(out, host, port);
#elif defined(GIT_OPENSSL) #elif defined(GIT_OPENSSL)
......
#include "clar_libgit2.h"
#include "git2/sys/stream.h"
#include "tls_stream.h"
#include "stream.h"
static git_stream test_stream;
static int ctor_called;
static int test_ctor(git_stream **out, const char *host, const char *port)
{
GIT_UNUSED(host);
GIT_UNUSED(port);
ctor_called = 1;
*out = &test_stream;
return 0;
}
void test_core_stream__register_tls(void)
{
git_stream *stream;
int error;
ctor_called = 0;
cl_git_pass(git_stream_register_tls(test_ctor));
cl_git_pass(git_tls_stream_new(&stream, "localhost", "443"));
cl_assert_equal_i(1, ctor_called);
cl_assert_equal_p(&test_stream, stream);
ctor_called = 0;
stream = NULL;
cl_git_pass(git_stream_register_tls(NULL));
error = git_tls_stream_new(&stream, "localhost", "443");
/* We don't have arbitrary TLS stream support on Windows */
#if GIT_WIN32
cl_git_fail_with(-1, error);
#else
cl_git_pass(error);
#endif
cl_assert_equal_i(0, ctor_called);
cl_assert(&test_stream != stream);
git_stream_free(stream);
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment