src/context.h

Sun, 21 Nov 2010 20:14:31 -0800

author
Paul Aurich <paul@darkrain42.org>
date
Sun, 21 Nov 2010 20:14:31 -0800
changeset 34
510432315106
parent 0
f7d2d78eb424
child 38
4ecd7b0e67ea
permissions
-rw-r--r--

verify: Flag to ignore 'invalid purpose' errors on end cert

#ifndef __CONTEXT_H__
#define __CONTEXT_H__

/*--------------------------------------------------------------------------
 * LuaSec 0.4
 * Copyright (C) 2006-2009 Bruno Silvestre
 *
 *--------------------------------------------------------------------------*/

#include <lua.h>
#include <openssl/ssl.h>

#if defined(_WIN32)
#define LUASEC_API __declspec(dllexport) 
#else
#define LUASEC_API extern
#endif

#define MD_CTX_INVALID 0
#define MD_CTX_SERVER 1
#define MD_CTX_CLIENT 2

#define LUASEC_VERIFY_FLAGS_NONE            0x0000
#define LUASEC_VERIFY_FLAGS_ALWAYS_CONTINUE 0x0001
#define LUASEC_VERIFY_FLAGS_IGNORE_PURPOSE  0x0002

typedef struct t_context_ {
  SSL_CTX *context;
  unsigned int verify_flags;
  char mode;
} t_context;
typedef t_context* p_context;

/* index into the SSL storage where the context is.
 * see SSL_get_ex_data().
 */
extern int luasec_ssl_idx;

p_context checkctx(lua_State *L, int idx);
/* Retrieve the SSL context from the Lua stack */
SSL_CTX *ctx_getcontext(lua_State *L, int idx);
/* Retrieve the mode from the context in the Lua stack */
char ctx_getmode(lua_State *L, int idx);

/* Registre the module. */
LUASEC_API int luaopen_ssl_context(lua_State *L);

#endif

mercurial