-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpam_myproxy.h
109 lines (92 loc) · 3.68 KB
/
pam_myproxy.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#ifndef _PAM_MYPROXY_H
#define _PAM_MYPROXY_H
#include "myproxy_client.h"
/************************************************************************/
/* DEFINES AND TYPES */
/************************************************************************/
/* Name of environment variable for the user */
#define PROXY_ENV_VAR "X509_USER_PROXY"
/* Names used as 'module_data_name' to set data in pam_sm_authenticate */
#define PAM_PREFIX "PAM_"
#define PAM_PROXY_FILENAME PAM_PREFIX "X509_USER_PROXY"
#define PAM_PROXY_CHAIN PAM_PREFIX "PROXYCHAIN"
#define PAM_PROXY_KEY PAM_PREFIX "PROXYKEY"
/* MyProxy defaults */
#define DEF_PORT 7512 /* MyProxy server port */
#define DEF_LIFETIME 43200L /* proxy lifetime */
#define DEF_KEYSIZE 2048 /* bits for key-pair */
#define DEF_FORMAT "/tmp/x509up_XXXXXX" /* formatstring for file */
#define DEF_WRITE 1 /* proxyfile or in mem */
#define DEF_USEENV 1 /* */
/* Cmdline and config file entries */
#define OPT_CONFIG "config"
#define OPT_CAPATH "capath"
#define OPT_CAFILE "cafile"
#define OPT_HOSTCERT "hostcert"
#define OPT_HOSTKEY "hostkey"
#define OPT_MYPROXYHOST "myproxyhost"
#define OPT_MYPROXYPORT "myproxyport"
#define OPT_PROXYFMT "proxyfmt"
#define OPT_WRITEPROXY "writeproxy"
#define OPT_LIFETIME "lifetime"
#define OPT_KEYSIZE "keysize"
#define OPT_USEENV "intern_env"
/* Structure containing all the options for pam module */
typedef struct {
char *conffile; /* Name of config file */
certinfo_t certinfo; /* CApath etc. */
endpoint_t endpoint; /* MyProxy server */
char *proxyfmt; /* Format string for proxy file */
int writeproxy; /* Whether to store in pam or in file */
long lifetime; /* proxy lifetime */
int keysize; /* key bits */
int useenv; /* */
} pam_myproxy_opts_t;
/* Enum with all typical return values, to be mapped on proper pam-function
* return values */
typedef enum {
MYPAM_SUCCESS = 0, /* success */
MYPAM_ERROR = 1, /* system error */
MYPAM_DATA_MISSING = 2, /* missing pam data */
MYPAM_USER_UNKNOWN = 3, /* username unknown */
MYPAM_CRED_EXPIRED = 4, /* credential expired */
MYPAM_AUTH_ERR = 5, /* credential invalid */
} mypam_err_t;
/************************************************************************/
/* FUNCTION PROTOTYPES */
/************************************************************************/
/**
* Initializes the options structure
* \param opts configuration options structure
*/
void _pam_myproxy_config_init(pam_myproxy_opts_t *opts);
/**
* free()s all memory contained in opts structure
* \param opts struct containing the configuration options
*/
void _pam_myproxy_config_free(pam_myproxy_opts_t *opts);
/**
* Parses the config file in opts.conffile, and leaves the output in the
* different opts fields. When an option is unset the value is left unchanged.
* \param opts struct containing the configuration options
* \return -1 I/O error
* -2 permission error (of config file)
* -3 memory error
* 0 success
*/
int _pam_myproxy_parse_config(pam_myproxy_opts_t *opts);
/**
* Parses the commandline options (incl config if present), and leaves the
* output in the different opts fields
* \param argc pam argc
* \param argv pam argv
* \param opts struct containing the configuration options
* \return -1 I/O error (from config file)
* -2 permission error (of config file)
* -3 memory error
* >0 index+1 of wrong commandline option
* 0 success
*/
int _pam_myproxy_parse_cmdline(int argc, const char *argv[],
pam_myproxy_opts_t *opts);
#endif