[BACK]Return to sshsig.h CVS log [TXT][DIR] Up to [local] / src / usr.bin / ssh

Annotation of src/usr.bin/ssh/sshsig.h, Revision 1.1

1.1     ! djm         1: /*
        !             2:  * Copyright (c) 2019 Google LLC
        !             3:  *
        !             4:  * Permission to use, copy, modify, and distribute this software for any
        !             5:  * purpose with or without fee is hereby granted, provided that the above
        !             6:  * copyright notice and this permission notice appear in all copies.
        !             7:  *
        !             8:  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
        !             9:  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
        !            10:  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
        !            11:  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
        !            12:  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
        !            13:  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
        !            14:  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
        !            15:  */
        !            16:
        !            17: #ifndef SSHSIG_H
        !            18: #define SSHSIG_H
        !            19:
        !            20: struct sshbuf;
        !            21: struct sshkey;
        !            22:
        !            23: typedef int sshsig_signer(struct sshkey *, u_char **, size_t *,
        !            24:     const u_char *, size_t, const char *, u_int, void *);
        !            25:
        !            26: /*
        !            27:  * Creates a detached SSH signature for a given message.
        !            28:  * Returns 0 on success or a negative SSH_ERR_* error code on failure.
        !            29:  * out is populated with the detached signature, or NULL on failure.
        !            30:  */
        !            31: int sshsig_sign_message(struct sshkey *key, const char *hashalg,
        !            32:     const struct sshbuf *message, const char *sig_namespace,
        !            33:     struct sshbuf **out, sshsig_signer *signer, void *signer_ctx);
        !            34:
        !            35: /*
        !            36:  * Creates a detached SSH signature for a given file.
        !            37:  * Returns 0 on success or a negative SSH_ERR_* error code on failure.
        !            38:  * out is populated with the detached signature, or NULL on failure.
        !            39:  */
        !            40: int sshsig_sign_fd(struct sshkey *key, const char *hashalg,
        !            41:     int fd, const char *sig_namespace, struct sshbuf **out,
        !            42:     sshsig_signer *signer, void *signer_ctx);
        !            43:
        !            44: /*
        !            45:  * Verifies that a detached signature is valid and optionally returns key
        !            46:  * used to sign via argument.
        !            47:  * Returns 0 on success or a negative SSH_ERR_* error code on failure.
        !            48:  */
        !            49: int sshsig_verify_message(struct sshbuf *signature,
        !            50:     const struct sshbuf *message, const char *sig_namespace,
        !            51:     struct sshkey **sign_keyp);
        !            52:
        !            53: /*
        !            54:  * Verifies that a detached signature over a file is valid and optionally
        !            55:  * returns key used to sign via argument.
        !            56:  * Returns 0 on success or a negative SSH_ERR_* error code on failure.
        !            57:  */
        !            58: int sshsig_verify_fd(struct sshbuf *signature, int fd,
        !            59:     const char *sig_namespace, struct sshkey **sign_keyp);
        !            60:
        !            61: /*
        !            62:  * Return a base64 encoded "ASCII armoured" version of a raw signature.
        !            63:  */
        !            64: int sshsig_armor(const struct sshbuf *blob, struct sshbuf **out);
        !            65:
        !            66: /*
        !            67:  * Decode a base64 encoded armoured signature to a raw signature.
        !            68:  */
        !            69: int sshsig_dearmor(struct sshbuf *sig, struct sshbuf **out);
        !            70:
        !            71: /*
        !            72:  * Checks whether a particular key/principal/namespace is permitted by
        !            73:  * an allowed_keys file. Returns 0 on success.
        !            74:  */
        !            75: int sshsig_check_allowed_keys(const char *path, const struct sshkey *sign_key,
        !            76:     const char *principal, const char *ns);
        !            77:
        !            78: #endif /* SSHSIG_H */