fwknop/lib/fko_context.h
Michael Rash bfdbb8f260 Updated authorship and copyright information
This commit updates all authorship and copyright information to include a
standard header that references the AUTHORS and CREDITS file. This standard
header was written by the Debian legal team at the request of Franck Joncourt.
2014-03-04 17:53:10 -05:00

126 lines
3.4 KiB
C
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
*****************************************************************************
*
* File: fko_context.h
*
* Purpose: fko context definition.
*
* Fwknop is developed primarily by the people listed in the file 'AUTHORS'.
* Copyright (C) 20092014 fwknop developers and contributors. For a full
* list of contributors, see the file 'CREDITS'.
*
* License (GNU General Public License):
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
*
*****************************************************************************
*/
#ifndef FKO_CONTEXT_H
#define FKO_CONTEXT_H 1
#include "fko_common.h"
#if HAVE_LIBGPGME
#include <gpgme.h>
#endif
#if HAVE_LIBGPGME
/* Stucture to hold a list of the gpg signature information
* we are interested in.
*/
struct fko_gpg_sig {
struct fko_gpg_sig *next;
gpgme_sigsum_t summary;
gpgme_error_t status;
gpgme_validity_t validity;
char *fpr;
};
typedef struct fko_gpg_sig *fko_gpg_sig_t;
#endif /* HAVE_LIBGPGME */
/* The pieces we need to make an FKO SPA data packet.
*/
struct fko_context {
/* FKO SPA user-definable message data */
char *rand_val;
char *username;
time_t timestamp;
short message_type;
char *message;
char *nat_access;
char *server_auth;
unsigned int client_timeout;
/* FKO SPA user-settable message encoding types */
short digest_type;
short encryption_type;
int encryption_mode;
short hmac_type;
/* Computed or predefined data */
char *version;
char *digest;
int digest_len;
/* Digest of raw encrypted/base64 data - this is used
* for replay attack detection
*/
char *raw_digest;
short raw_digest_type;
int raw_digest_len;
/* Computed processed data (encodings, etc.) */
char *encoded_msg;
int encoded_msg_len;
char *encrypted_msg;
int encrypted_msg_len;
char *msg_hmac;
int msg_hmac_len;
int added_salted_str;
int added_gpg_prefix;
/* State info */
unsigned int state;
unsigned char initval;
#if HAVE_LIBGPGME
/* For gpgme support */
char *gpg_exe;
char *gpg_recipient;
char *gpg_signer;
char *gpg_home_dir;
unsigned char have_gpgme_context;
gpgme_ctx_t gpg_ctx;
gpgme_key_t recipient_key;
gpgme_key_t signer_key;
unsigned char verify_gpg_sigs;
unsigned char ignore_gpg_sig_error;
fko_gpg_sig_t gpg_sigs;
gpgme_error_t gpg_err;
#endif /* HAVE_LIBGPGME */
};
#endif /* FKO_CONTEXT_H */
/***EOF***/