src/context.h

Sun, 05 Dec 2010 23:45:57 -0800

author
Paul Aurich <paul@darkrain42.org>
date
Sun, 05 Dec 2010 23:45:57 -0800
changeset 38
4ecd7b0e67ea
parent 34
510432315106
child 41
e26f1f91118a
permissions
-rw-r--r--

Clean up the ex_data callers
The best explanation I can come up with here is that I totally missed the existence of SSL_[gs]et_ex_data...

#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;

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