diff options
author | Pavel Březina <pbrezina@redhat.com> | 2017-02-28 13:32:31 +0100 |
---|---|---|
committer | Lukas Slebodnik <lslebodn@redhat.com> | 2017-03-30 19:07:13 +0200 |
commit | c2ea75da72b426d98ba489039e220d417bfb4c2a (patch) | |
tree | 666294bebdd975d7a345cf1f963e616895cd0666 | |
parent | 886e0f75e6f4c7877a23a3625f8a20c09109b09d (diff) | |
download | sssd-c2ea75da72b426d98ba489039e220d417bfb4c2a.tar.gz sssd-c2ea75da72b426d98ba489039e220d417bfb4c2a.tar.xz sssd-c2ea75da72b426d98ba489039e220d417bfb4c2a.zip |
tcurl: add support for http basic auth
Reviewed-by: Simo Sorce <simo@redhat.com>
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
-rw-r--r-- | src/tests/tcurl_test_tool.c | 14 | ||||
-rw-r--r-- | src/util/tev_curl.c | 24 | ||||
-rw-r--r-- | src/util/tev_curl.h | 15 |
3 files changed, 53 insertions, 0 deletions
diff --git a/src/tests/tcurl_test_tool.c b/src/tests/tcurl_test_tool.c index 9cec000fb..4ceef8e06 100644 --- a/src/tests/tcurl_test_tool.c +++ b/src/tests/tcurl_test_tool.c @@ -45,6 +45,9 @@ struct tool_options { const char *socket_path; const char *capath; const char *cacert; + + const char *username; + const char *password; }; static void request_done(struct tevent_req *req) @@ -194,6 +197,14 @@ prepare_requests(TALLOC_CTX *mem_ctx, } } + if (opts->username != NULL && opts->password != NULL) { + ret = tcurl_req_http_basic_auth(requests[i], opts->username, + opts->password); + if (ret != EOK) { + goto done; + } + } + i++; } @@ -299,6 +310,9 @@ int main(int argc, const char *argv[]) { "verify-host", '\0', POPT_ARG_NONE, &opts.verify_host, '\0', "Verify host when TLS is enabled", NULL }, { "capath", '\0', POPT_ARG_STRING, &opts.capath, '\0', "Path to CA directory where peer certificate is stored", NULL }, { "cacert", '\0', POPT_ARG_STRING, &opts.cacert, '\0', "Path to CA certificate", NULL }, + /* BASIC AUTH */ + { "username", '\0', POPT_ARG_STRING, &opts.username, '\0', "Username for basic authentication", NULL }, + { "password", '\0', POPT_ARG_STRING, &opts.password, '\0', "Password for basic authentication", NULL }, POPT_TABLEEND }; diff --git a/src/util/tev_curl.c b/src/util/tev_curl.c index c155f4c03..8faf07c71 100644 --- a/src/util/tev_curl.c +++ b/src/util/tev_curl.c @@ -1092,3 +1092,27 @@ errno_t tcurl_req_set_client_cert(struct tcurl_request *tcurl_req, return EOK; } + +errno_t tcurl_req_http_basic_auth(struct tcurl_request *tcurl_req, + const char *username, + const char *password) +{ + errno_t ret; + + ret = tcurl_set_option(tcurl_req, CURLOPT_HTTPAUTH, CURLAUTH_BASIC); + if (ret != EOK) { + return ret; + } + + ret = tcurl_set_option(tcurl_req, CURLOPT_USERNAME, username); + if (ret != EOK) { + return ret; + } + + ret = tcurl_set_option(tcurl_req, CURLOPT_PASSWORD, password); + if (ret != EOK) { + return ret; + } + + return EOK; +} diff --git a/src/util/tev_curl.h b/src/util/tev_curl.h index 933abcb9b..c733127b3 100644 --- a/src/util/tev_curl.h +++ b/src/util/tev_curl.h @@ -243,4 +243,19 @@ errno_t tcurl_req_set_client_cert(struct tcurl_request *tcurl_req, const char *cert, const char *key); +/** + * @brief Force HTTP basic authentication with @username and @password. + * + * @param[in] tcurl_request + * @param[in] username + * @param[in] password + * + * @returns errno code + * + * @see tcurl_http + */ +errno_t tcurl_req_http_basic_auth(struct tcurl_request *tcurl_req, + const char *username, + const char *password); + #endif /* __TEV_CURL_H */ |