aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/libssh/libssh.h3
-rw-r--r--include/libssh/session.h1
-rw-r--r--src/options.c15
3 files changed, 18 insertions, 1 deletions
diff --git a/include/libssh/libssh.h b/include/libssh/libssh.h
index d71a6936..0641d2c4 100644
--- a/include/libssh/libssh.h
+++ b/include/libssh/libssh.h
@@ -333,7 +333,8 @@ enum ssh_options_e {
SSH_OPTIONS_KEY_EXCHANGE,
SSH_OPTIONS_HOSTKEYS,
SSH_OPTIONS_GSSAPI_SERVER_IDENTITY,
- SSH_OPTIONS_GSSAPI_CLIENT_IDENTITY
+ SSH_OPTIONS_GSSAPI_CLIENT_IDENTITY,
+ SSH_OPTIONS_GSSAPI_DELEGATE_CREDENTIALS,
};
enum {
diff --git a/include/libssh/session.h b/include/libssh/session.h
index 86f94dfa..8a94daa5 100644
--- a/include/libssh/session.h
+++ b/include/libssh/session.h
@@ -185,6 +185,7 @@ struct ssh_session_struct {
char compressionlevel;
char *gss_server_identity;
char *gss_client_identity;
+ int gss_delegate_creds;
} opts;
};
diff --git a/src/options.c b/src/options.c
index 4791e156..24d34df4 100644
--- a/src/options.c
+++ b/src/options.c
@@ -375,6 +375,10 @@ int ssh_options_set_algo(ssh_session session, int algo,
* Set it to specify the GSSAPI client identity that libssh
* should expect when connecting to the server (const char *).
*
+ * - SSH_OPTIONS_GSSAPI_DELEGATE_CREDENTIALS
+ * Set it to specify that GSSAPI should delegate credentials
+ * to the server (int, 0 = false).
+ *
* @param value The value to set. This is a generic pointer and the
* datatype which is used should be set according to the
* type set.
@@ -828,6 +832,17 @@ int ssh_options_set(ssh_session session, enum ssh_options_e type,
}
}
break;
+ case SSH_OPTIONS_GSSAPI_DELEGATE_CREDENTIALS:
+ if (value == NULL) {
+ ssh_set_error_invalid(session);
+ return -1;
+ } else {
+ int x = *(int *)value;
+
+ session->opts.gss_delegate_creds = (x & 0xff);
+ }
+ break;
+
default:
ssh_set_error(session, SSH_REQUEST_DENIED, "Unknown ssh option %d", type);
return -1;