2015-05-05 19:16:19 +00:00
|
|
|
/*
|
|
|
|
* pageant.h: header for pageant.c.
|
|
|
|
*/
|
|
|
|
|
2015-05-06 18:32:26 +00:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
2015-05-05 19:16:19 +00:00
|
|
|
/*
|
2018-07-08 16:04:12 +00:00
|
|
|
* Upper limit on length of any agent message. Used as a basic sanity
|
|
|
|
* check on messages' length fields, and used by the Windows Pageant
|
|
|
|
* client IPC to decide how large a file mapping to allocate.
|
2015-05-05 19:16:19 +00:00
|
|
|
*/
|
2018-07-08 16:04:12 +00:00
|
|
|
#define AGENT_MAX_MSGLEN 262144
|
2015-05-05 19:16:19 +00:00
|
|
|
|
2015-05-06 18:32:26 +00:00
|
|
|
typedef void (*pageant_logfn_t)(void *logctx, const char *fmt, va_list ap);
|
|
|
|
|
2015-05-05 19:16:19 +00:00
|
|
|
/*
|
|
|
|
* Initial setup.
|
|
|
|
*/
|
|
|
|
void pageant_init(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The main agent function that answers messages.
|
|
|
|
*
|
|
|
|
* Expects a message/length pair as input, minus its initial length
|
|
|
|
* field but still with its type code on the front.
|
|
|
|
*
|
|
|
|
* Returns a fully formatted message as output, *with* its initial
|
|
|
|
* length field, and sets *outlen to the full size of that message.
|
|
|
|
*/
|
2018-05-24 12:23:17 +00:00
|
|
|
void pageant_handle_msg(BinarySink *bs,
|
|
|
|
const void *msg, int msglen,
|
|
|
|
void *logctx, pageant_logfn_t logfn);
|
2015-05-05 19:16:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Construct a failure response. Useful for agent front ends which
|
|
|
|
* suffer a problem before they even get to pageant_handle_msg.
|
2018-05-24 12:23:17 +00:00
|
|
|
*
|
|
|
|
* 'log_reason' is only used if logfn is not NULL.
|
2015-05-05 19:16:19 +00:00
|
|
|
*/
|
2018-05-24 12:23:17 +00:00
|
|
|
void pageant_failure_msg(BinarySink *bs,
|
|
|
|
const char *log_reason,
|
|
|
|
void *logctx, pageant_logfn_t logfn);
|
2015-05-05 19:16:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Construct a list of public keys, just as the two LIST_IDENTITIES
|
|
|
|
* requests would have returned them.
|
|
|
|
*/
|
2018-05-24 12:23:17 +00:00
|
|
|
void pageant_make_keylist1(BinarySink *);
|
|
|
|
void pageant_make_keylist2(BinarySink *);
|
2015-05-05 19:16:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Accessor functions for Pageant's internal key lists. Fetch the nth
|
|
|
|
* key; count the keys; attempt to add a key (returning true on
|
|
|
|
* success, in which case the ownership of the key structure has been
|
|
|
|
* taken over by pageant.c); attempt to delete a key (returning true
|
|
|
|
* on success, in which case the ownership of the key structure is
|
|
|
|
* passed back to the client).
|
|
|
|
*/
|
2019-01-04 06:51:44 +00:00
|
|
|
RSAKey *pageant_nth_ssh1_key(int i);
|
|
|
|
ssh2_userkey *pageant_nth_ssh2_key(int i);
|
2015-05-05 19:16:19 +00:00
|
|
|
int pageant_count_ssh1_keys(void);
|
|
|
|
int pageant_count_ssh2_keys(void);
|
2019-01-04 06:51:44 +00:00
|
|
|
bool pageant_add_ssh1_key(RSAKey *rkey);
|
|
|
|
bool pageant_add_ssh2_key(ssh2_userkey *skey);
|
|
|
|
bool pageant_delete_ssh1_key(RSAKey *rkey);
|
|
|
|
bool pageant_delete_ssh2_key(ssh2_userkey *skey);
|
2015-05-05 19:16:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This callback must be provided by the Pageant front end code.
|
|
|
|
* pageant_handle_msg calls it to indicate that the message it's just
|
|
|
|
* handled has changed the list of keys held by the agent. Front ends
|
|
|
|
* which expose that key list through dedicated UI may need to refresh
|
|
|
|
* that UI's state in this function; other front ends can leave it
|
|
|
|
* empty.
|
|
|
|
*/
|
|
|
|
void keylist_update(void);
|
2015-05-05 19:16:20 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Functions to establish a listening socket speaking the SSH agent
|
|
|
|
* protocol. Call pageant_listener_new() to set up a state; then
|
2018-05-27 08:29:33 +00:00
|
|
|
* create a socket using the returned Plug; then call
|
2015-05-05 19:16:20 +00:00
|
|
|
* pageant_listener_got_socket() to give the listening state its own
|
2015-05-07 18:04:25 +00:00
|
|
|
* socket pointer. Also, provide a logging function later if you want
|
|
|
|
* to.
|
2015-05-05 19:16:20 +00:00
|
|
|
*/
|
|
|
|
struct pageant_listen_state;
|
Get rid of lots of implicit pointer types.
All the main backend structures - Ssh, Telnet, Pty, Serial etc - now
describe structure types themselves rather than pointers to them. The
same goes for the codebase-wide trait types Socket and Plug, and the
supporting types SockAddr and Pinger.
All those things that were typedefed as pointers are older types; the
newer ones have the explicit * at the point of use, because that's
what I now seem to be preferring. But whichever one of those is
better, inconsistently using a mixture of the two styles is worse, so
let's make everything consistent.
A few types are still implicitly pointers, such as Bignum and some of
the GSSAPI types; generally this is either because they have to be
void *, or because they're typedefed differently on different
platforms and aren't always pointers at all. Can't be helped. But I've
got rid of the main ones, at least.
2018-10-04 18:10:23 +00:00
|
|
|
struct pageant_listen_state *pageant_listener_new(Plug **plug);
|
|
|
|
void pageant_listener_got_socket(struct pageant_listen_state *pl, Socket *);
|
2015-05-07 18:04:25 +00:00
|
|
|
void pageant_listener_set_logfn(struct pageant_listen_state *pl,
|
|
|
|
void *logctx, pageant_logfn_t logfn);
|
2015-05-05 19:16:20 +00:00
|
|
|
void pageant_listener_free(struct pageant_listen_state *pl);
|
2015-05-11 14:06:25 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Functions to perform specific key actions, either as a client of an
|
|
|
|
* ssh-agent running elsewhere, or directly on the agent state in this
|
|
|
|
* process. (On at least one platform we want to do this in an
|
|
|
|
* agnostic way between the two situations.)
|
|
|
|
*
|
|
|
|
* pageant_get_keylist{1,2} work just like pageant_make_keylist{1,2}
|
|
|
|
* above, except that they can also cope if they have to contact an
|
|
|
|
* external agent.
|
|
|
|
*
|
|
|
|
* pageant_add_keyfile() is used to load a private key from a file and
|
|
|
|
* add it to the agent. Initially, you should call it with passphrase
|
|
|
|
* NULL, and it will check if the key is already in the agent, and
|
|
|
|
* whether a passphrase is required. Return values are given in the
|
|
|
|
* enum below. On return, *retstr will either be NULL, or a
|
|
|
|
* dynamically allocated string containing a key comment or an error
|
|
|
|
* message.
|
|
|
|
*
|
|
|
|
* pageant_add_keyfile() also remembers passphrases with which it's
|
|
|
|
* successfully decrypted keys (because if you try to add multiple
|
|
|
|
* keys in one go, you might very well have used the same passphrase
|
|
|
|
* for keys that have the same trust properties). Call
|
|
|
|
* pageant_forget_passphrases() to get rid of them all.
|
|
|
|
*/
|
|
|
|
void *pageant_get_keylist1(int *length);
|
|
|
|
void *pageant_get_keylist2(int *length);
|
|
|
|
enum {
|
|
|
|
PAGEANT_ACTION_OK, /* success; no further action needed */
|
|
|
|
PAGEANT_ACTION_FAILURE, /* failure; *retstr is error message */
|
|
|
|
PAGEANT_ACTION_NEED_PP /* need passphrase: *retstr is key comment */
|
|
|
|
};
|
|
|
|
int pageant_add_keyfile(Filename *filename, const char *passphrase,
|
|
|
|
char **retstr);
|
|
|
|
void pageant_forget_passphrases(void);
|
2015-05-12 12:27:33 +00:00
|
|
|
|
|
|
|
struct pageant_pubkey {
|
|
|
|
/* Everything needed to identify a public key found by
|
|
|
|
* pageant_enum_keys and pass it back to the agent or other code
|
|
|
|
* later */
|
2018-05-24 09:59:39 +00:00
|
|
|
strbuf *blob;
|
2015-05-12 13:48:32 +00:00
|
|
|
char *comment;
|
2015-05-12 12:27:33 +00:00
|
|
|
int ssh_version;
|
|
|
|
};
|
|
|
|
struct pageant_pubkey *pageant_pubkey_copy(struct pageant_pubkey *key);
|
|
|
|
void pageant_pubkey_free(struct pageant_pubkey *key);
|
|
|
|
|
2015-05-11 17:34:45 +00:00
|
|
|
typedef void (*pageant_key_enum_fn_t)(void *ctx,
|
|
|
|
const char *fingerprint,
|
2015-05-12 12:27:33 +00:00
|
|
|
const char *comment,
|
|
|
|
struct pageant_pubkey *key);
|
2015-05-11 17:34:45 +00:00
|
|
|
int pageant_enum_keys(pageant_key_enum_fn_t callback, void *callback_ctx,
|
|
|
|
char **retstr);
|
2015-05-12 12:27:33 +00:00
|
|
|
int pageant_delete_key(struct pageant_pubkey *key, char **retstr);
|
2015-05-12 13:55:44 +00:00
|
|
|
int pageant_delete_all_keys(char **retstr);
|