summaryrefslogtreecommitdiffstats
path: root/server/responder/pam/pamsrv.h
blob: c5250f8d10862c6030de209af428f9942117ec6e (plain)
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
#ifndef __PAMSRV_H__
#define __PAMSRV_H__


#include "util/util.h"
#include "sbus/sssd_dbus.h"
#include "responder/common/responder_cmd.h"

#define PAM_DP_TIMEOUT 5000

#define DEBUG_PAM_DATA(level, pd) do { \
    if (level <= debug_level) pam_print_data(level, pd); \
} while(0);

struct response_data {
    int32_t type;
    int32_t len;
    uint8_t *data;
    struct response_data *next;
};

struct pam_data {
    int cmd;
    uint32_t authtok_type;
    uint32_t authtok_size;
    uint32_t newauthtok_type;
    uint32_t newauthtok_size;
    char *domain;
    char *user;
    char *service;
    char *tty;
    char *ruser;
    char *rhost;
    uint8_t *authtok;
    uint8_t *newauthtok;

    int pam_status;
    int response_delay;
    struct response_data *resp_list;
    struct cli_ctx *cctx;
};

int pam_add_response(struct pam_data *pd, enum response_type type,
                     int len, uint8_t *data);
void pam_print_data(int l, struct pam_data *pd);

typedef void (*pam_dp_callback_t)(struct pam_data *pd);

struct sbus_method *register_pam_dp_methods(void);
struct sss_cmd_table *register_sss_cmds(void);
int pam_dp_send_req(struct cli_ctx *cctx, pam_dp_callback_t callback,
                    int timeout, struct pam_data *pd);


int dp_pack_pam_request(DBusMessage *msg, struct pam_data *pd);
int dp_unpack_pam_request(DBusMessage *msg, struct pam_data *pd, DBusError *dbus_error);
int dp_pack_pam_response(DBusMessage *msg, struct pam_data *pd);
int dp_unpack_pam_response(DBusMessage *msg, struct pam_data *pd, DBusError *dbus_error);
#endif /* __PAMSRV_H__ */