| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 | /* Copyright (C) Sara Golemon <sarag@libssh2.org> * All rights reserved. * * Redistribution and use in source and binary forms, * with or without modification, are permitted provided * that the following conditions are met: * *   Redistributions of source code must retain the above *   copyright notice, this list of conditions and the *   following disclaimer. * *   Redistributions in binary form must reproduce the above *   copyright notice, this list of conditions and the following *   disclaimer in the documentation and/or other materials *   provided with the distribution. * *   Neither the name of the copyright holder nor the names *   of any other contributors may be used to endorse or *   promote products derived from this software without *   specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY * OF SUCH DAMAGE. *//* Note: This include file is only needed for using the * publickey SUBSYSTEM which is not the same as publickey * authentication.  For authentication you only need libssh2.h * * For more information on the publickey subsystem, * refer to IETF draft: secsh-publickey * * SPDX-License-Identifier: BSD-3-Clause */#ifndef LIBSSH2_PUBLICKEY_H#define LIBSSH2_PUBLICKEY_H 1#include "libssh2.h"typedef struct _LIBSSH2_PUBLICKEY               LIBSSH2_PUBLICKEY;typedef struct _libssh2_publickey_attribute {    const char *name;    unsigned long name_len;    const char *value;    unsigned long value_len;    char mandatory;} libssh2_publickey_attribute;typedef struct _libssh2_publickey_list {    unsigned char *packet; /* For freeing */    const unsigned char *name;    unsigned long name_len;    const unsigned char *blob;    unsigned long blob_len;    unsigned long num_attrs;    libssh2_publickey_attribute *attrs; /* free me */} libssh2_publickey_list;/* Generally use the first macro here, but if both name and value are string   literals, you can use _fast() to take advantage of preprocessing */#define libssh2_publickey_attribute(name, value, mandatory) \    { (name), strlen(name), (value), strlen(value), (mandatory) },#define libssh2_publickey_attribute_fast(name, value, mandatory) \    { (name), sizeof(name) - 1, (value), sizeof(value) - 1, (mandatory) },#ifdef __cplusplusextern "C" {#endif/* Publickey Subsystem */LIBSSH2_API LIBSSH2_PUBLICKEY *libssh2_publickey_init(LIBSSH2_SESSION *session);LIBSSH2_API intlibssh2_publickey_add_ex(LIBSSH2_PUBLICKEY *pkey,                         const unsigned char *name,                         unsigned long name_len,                         const unsigned char *blob,                         unsigned long blob_len, char overwrite,                         unsigned long num_attrs,                         const libssh2_publickey_attribute attrs[]);#define libssh2_publickey_add(pkey, name, blob, blob_len, overwrite, \                              num_attrs, attrs) \    libssh2_publickey_add_ex((pkey), \                             (name), strlen(name), \                             (blob), (blob_len), \                             (overwrite), (num_attrs), (attrs))LIBSSH2_API int libssh2_publickey_remove_ex(LIBSSH2_PUBLICKEY *pkey,                                            const unsigned char *name,                                            unsigned long name_len,                                            const unsigned char *blob,                                            unsigned long blob_len);#define libssh2_publickey_remove(pkey, name, blob, blob_len) \    libssh2_publickey_remove_ex((pkey), \                                (name), strlen(name), \                                (blob), (blob_len))LIBSSH2_API intlibssh2_publickey_list_fetch(LIBSSH2_PUBLICKEY *pkey,                             unsigned long *num_keys,                             libssh2_publickey_list **pkey_list);LIBSSH2_API voidlibssh2_publickey_list_free(LIBSSH2_PUBLICKEY *pkey,                            libssh2_publickey_list *pkey_list);LIBSSH2_API int libssh2_publickey_shutdown(LIBSSH2_PUBLICKEY *pkey);#ifdef __cplusplus} /* extern "C" */#endif#endif /* LIBSSH2_PUBLICKEY_H */
 |