Changed libssh2_session_methods() to use method_type parameter
Этот коммит содержится в:
родитель
d86bcab2d2
Коммит
eef99ca106
@ -239,12 +239,7 @@ LIBSSH2_API void libssh2_session_free(LIBSSH2_SESSION *session);
|
|||||||
LIBSSH2_API char *libssh2_hostkey_hash(LIBSSH2_SESSION *session, int hash_type);
|
LIBSSH2_API char *libssh2_hostkey_hash(LIBSSH2_SESSION *session, int hash_type);
|
||||||
|
|
||||||
LIBSSH2_API int libssh2_session_method_pref(LIBSSH2_SESSION *session, int method_type, char *prefs);
|
LIBSSH2_API int libssh2_session_method_pref(LIBSSH2_SESSION *session, int method_type, char *prefs);
|
||||||
LIBSSH2_API void libssh2_session_methods(LIBSSH2_SESSION *session, char **kex, char **hostkey,
|
LIBSSH2_API char *libssh2_session_methods(LIBSSH2_SESSION *session, int method_type);
|
||||||
char **crypt_cs, char **crypt_sc,
|
|
||||||
char **mac_cs, char **mac_sc,
|
|
||||||
char **comp_cs, char **comp_sc,
|
|
||||||
char **lang_cs, char **lang_sc);
|
|
||||||
|
|
||||||
LIBSSH2_API int libssh2_session_last_error(LIBSSH2_SESSION *session, char **errmsg, int *errmsg_len, int want_buf);
|
LIBSSH2_API int libssh2_session_last_error(LIBSSH2_SESSION *session, char **errmsg, int *errmsg_len, int want_buf);
|
||||||
|
|
||||||
/* Userauth API */
|
/* Userauth API */
|
||||||
|
@ -476,51 +476,57 @@ LIBSSH2_API int libssh2_session_disconnect_ex(LIBSSH2_SESSION *session, int reas
|
|||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
/* {{{ libssh2_session_methods
|
/* {{{ libssh2_session_methods
|
||||||
* Return the currently active methods
|
* Return the currently active methods for method_type
|
||||||
* NOTE: Currently lang_cs and lang_sc are ALWAYS set to empty string regardless of actual negotiation
|
* NOTE: Currently lang_cs and lang_sc are ALWAYS set to empty string regardless of actual negotiation
|
||||||
* Strings should NOT be freed
|
* Strings should NOT be freed
|
||||||
*/
|
*/
|
||||||
LIBSSH2_API void libssh2_session_methods(LIBSSH2_SESSION *session, char **kex, char **hostkey,
|
LIBSSH2_API char *libssh2_session_methods(LIBSSH2_SESSION *session, int method_type)
|
||||||
char **crypt_cs, char **crypt_sc,
|
|
||||||
char **mac_cs, char **mac_sc,
|
|
||||||
char **comp_cs, char **comp_sc,
|
|
||||||
char **lang_cs, char **lang_sc)
|
|
||||||
{
|
{
|
||||||
if (kex) {
|
char *methodlist = NULL;
|
||||||
*kex = session->kex->name;
|
|
||||||
}
|
switch(method_type) {
|
||||||
if (hostkey) {
|
case LIBSSH2_METHOD_KEX:
|
||||||
*hostkey = session->hostkey->name;
|
methodlist = session->kex->name;
|
||||||
}
|
break;
|
||||||
if (crypt_cs) {
|
case LIBSSH2_METHOD_HOSTKEY:
|
||||||
*crypt_cs = session->local.crypt->name;
|
methodlist = session->hostkey->name;
|
||||||
}
|
break;
|
||||||
if (crypt_sc) {
|
case LIBSSH2_METHOD_CRYPT_CS:
|
||||||
*crypt_sc = session->remote.crypt->name;
|
methodlist = session->local.crypt->name;
|
||||||
}
|
break;
|
||||||
if (mac_cs) {
|
case LIBSSH2_METHOD_CRYPT_SC:
|
||||||
*mac_cs = session->local.mac->name;
|
methodlist = session->remote.crypt->name;
|
||||||
}
|
break;
|
||||||
if (mac_sc) {
|
case LIBSSH2_METHOD_MAC_CS:
|
||||||
*mac_sc = session->remote.mac->name;
|
methodlist = session->local.mac->name;
|
||||||
}
|
break;
|
||||||
if (comp_cs) {
|
case LIBSSH2_METHOD_MAC_SC:
|
||||||
*comp_cs = session->local.comp->name;
|
methodlist = session->remote.mac->name;
|
||||||
}
|
break;
|
||||||
if (comp_sc) {
|
case LIBSSH2_METHOD_COMP_CS:
|
||||||
*comp_sc = session->remote.comp->name;
|
methodlist = session->local.comp->name;
|
||||||
}
|
break;
|
||||||
if (lang_cs) {
|
case LIBSSH2_METHOD_COMP_SC:
|
||||||
*lang_cs = "";
|
methodlist = session->remote.comp->name;
|
||||||
}
|
break;
|
||||||
if (lang_sc) {
|
case LIBSSH2_METHOD_LANG_CS:
|
||||||
*lang_sc = "";
|
methodlist = "";
|
||||||
|
break;
|
||||||
|
case LIBSSH2_METHOD_LANG_SC:
|
||||||
|
methodlist = "";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
libssh2_error(session, LIBSSH2_ERROR_INVAL, "Invalid parameter specified for method_type", 0);
|
||||||
|
methodlist = NULL;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return(methodlist);
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
/* {{{ libssh2_session_abstract
|
/* {{{ libssh2_session_abstract
|
||||||
* Retreive a pointer to the abstract property
|
* Retrieve a pointer to the abstract property
|
||||||
*/
|
*/
|
||||||
LIBSSH2_API void **libssh2_session_abstract(LIBSSH2_SESSION *session)
|
LIBSSH2_API void **libssh2_session_abstract(LIBSSH2_SESSION *session)
|
||||||
{
|
{
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user