mirror of
https://github.com/libssh2/libssh2.git
synced 2025-04-26 16:48:48 +03:00
- All files have prominent copyright and SPDX identifier - If not embedded in the file, in the .reuse/dep5 file - All used licenses are in LICENSES/ (not shipped in tarballs) - A new REUSE CI job verify that all files are OK Assisted-by: Viktor Szakats Closes #1084
58 lines
1.6 KiB
C
58 lines
1.6 KiB
C
/* Copyright (C) The libssh2 project and its contributors.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include "runner.h"
|
|
|
|
static const char *username = "libssh2"; /* set in Dockerfile */
|
|
static const char *key_file_private = "key_rsa";
|
|
static const char *key_file_public = "key_rsa.pub"; /* set in Dockerfile */
|
|
|
|
int test(LIBSSH2_SESSION *session)
|
|
{
|
|
int rc;
|
|
LIBSSH2_CHANNEL *channel;
|
|
|
|
const char *userauth_list =
|
|
libssh2_userauth_list(session, username,
|
|
(unsigned int)strlen(username));
|
|
if(!userauth_list) {
|
|
print_last_session_error("libssh2_userauth_list");
|
|
return 1;
|
|
}
|
|
|
|
if(!strstr(userauth_list, "publickey")) {
|
|
fprintf(stderr, "'publickey' was expected in userauth list: %s\n",
|
|
userauth_list);
|
|
return 1;
|
|
}
|
|
|
|
rc = libssh2_userauth_publickey_fromfile_ex(session, username,
|
|
(unsigned int)strlen(username),
|
|
srcdir_path(key_file_public),
|
|
srcdir_path(key_file_private),
|
|
NULL);
|
|
if(rc) {
|
|
print_last_session_error("libssh2_userauth_publickey_fromfile_ex");
|
|
return 1;
|
|
}
|
|
|
|
channel = libssh2_channel_open_session(session);
|
|
#if 0
|
|
if(!channel) {
|
|
printf("Error opening channel\n");
|
|
return 1;
|
|
}
|
|
#endif
|
|
|
|
rc = libssh2_channel_request_auth_agent(channel);
|
|
if(rc) {
|
|
fprintf(stderr, "Auth agent request for agent forwarding failed, "
|
|
"error code %d\n", rc);
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|