@@ -150,6 +150,8 @@ static int http_schannel_check_revoke_mode =
150
150
*/
151
151
static int http_schannel_use_ssl_cainfo ;
152
152
153
+ static int http_auto_client_cert ;
154
+
153
155
size_t fread_buffer (char * ptr , size_t eltsize , size_t nmemb , void * buffer_ )
154
156
{
155
157
size_t size = eltsize * nmemb ;
@@ -312,6 +314,11 @@ static int http_options(const char *var, const char *value, void *cb)
312
314
return 0 ;
313
315
}
314
316
317
+ if (!strcmp ("http.sslautoclientcert" , var )) {
318
+ http_auto_client_cert = git_config_bool (var , value );
319
+ return 0 ;
320
+ }
321
+
315
322
if (!strcmp ("http.minsessions" , var )) {
316
323
min_curl_sessions = git_config_int (var , value );
317
324
if (min_curl_sessions > 1 )
@@ -886,13 +893,24 @@ static CURL *get_curl_handle(void)
886
893
}
887
894
#endif
888
895
889
- if (http_ssl_backend && !strcmp ("schannel" , http_ssl_backend ) &&
890
- http_schannel_check_revoke_mode ) {
896
+ if (http_ssl_backend && !strcmp ("schannel" , http_ssl_backend )) {
897
+ long ssl_options = 0 ;
898
+ if (http_schannel_check_revoke_mode ) {
891
899
#ifdef GIT_CURL_HAVE_CURLSSLOPT_NO_REVOKE
892
- curl_easy_setopt ( result , CURLOPT_SSL_OPTIONS , http_schannel_check_revoke_mode ) ;
900
+ ssl_options |= http_schannel_check_revoke_mode ;
893
901
#else
894
- warning (_ ("CURLSSLOPT_NO_REVOKE not supported with cURL < 7.44.0" ));
902
+ warning (_ ("CURLSSLOPT_NO_REVOKE not supported with cURL < 7.44.0" ));
895
903
#endif
904
+ }
905
+
906
+ if (http_auto_client_cert ) {
907
+ #ifdef GIT_CURL_HAVE_CURLSSLOPT_AUTO_CLIENT_CERT
908
+ ssl_options |= CURLSSLOPT_AUTO_CLIENT_CERT ;
909
+ #endif
910
+ }
911
+
912
+ if (ssl_options )
913
+ curl_easy_setopt (result , CURLOPT_SSL_OPTIONS , ssl_options );
896
914
}
897
915
898
916
if (http_proactive_auth )
0 commit comments