20 #ifndef FREERDP_LIB_CORE_NLA_H
21 #define FREERDP_LIB_CORE_NLA_H
23 typedef struct rdp_nla rdpNla;
25 #include <freerdp/api.h>
26 #include <freerdp/freerdp.h>
28 #include <winpr/sspi.h>
29 #include <winpr/stream.h>
30 #include <winpr/crypto.h>
32 #include <freerdp/crypto/ber.h>
33 #include <freerdp/crypto/der.h>
34 #include <freerdp/crypto/crypto.h>
36 #include "transport.h"
42 NLA_STATE_PUB_KEY_AUTH,
43 NLA_STATE_EARLY_USER_AUTH,
49 FREERDP_LOCAL
int nla_authenticate(rdpNla* nla);
51 FREERDP_LOCAL
int nla_client_begin(rdpNla* nla);
52 FREERDP_LOCAL
int nla_recv_pdu(rdpNla* nla,
wStream* s);
54 FREERDP_LOCAL SEC_WINNT_AUTH_IDENTITY* nla_get_identity(rdpNla* nla);
56 FREERDP_LOCAL NLA_STATE nla_get_state(rdpNla* nla);
57 FREERDP_LOCAL BOOL nla_set_state(rdpNla* nla, NLA_STATE state);
58 FREERDP_LOCAL
const char* nla_get_state_str(NLA_STATE state);
60 FREERDP_LOCAL DWORD nla_get_error(rdpNla* nla);
61 FREERDP_LOCAL INT32 nla_get_sspi_error(rdpNla* nla);
63 FREERDP_LOCAL BOOL nla_set_service_principal(rdpNla* nla,
const char* service,
64 const char* hostname);
66 FREERDP_LOCAL BOOL nla_set_sspi_module(rdpNla* nla,
const char* sspiModule);
67 FREERDP_LOCAL BOOL nla_sspi_module_init(rdpNla* nla);
69 FREERDP_LOCAL BOOL nla_impersonate(rdpNla* nla);
70 FREERDP_LOCAL BOOL nla_revert_to_self(rdpNla* nla);
72 FREERDP_LOCAL
void nla_free(rdpNla* nla);
74 WINPR_ATTR_MALLOC(nla_free, 1)
75 FREERDP_LOCAL rdpNla* nla_new(rdpContext* context, rdpTransport* transport);
77 FREERDP_LOCAL
void nla_set_early_user_auth(rdpNla* nla, BOOL earlyUserAuth);
78 FREERDP_LOCAL BOOL nla_encrypt(rdpNla* nla, const
SecBuffer* inBuffer,
SecBuffer* outBuffer);
79 FREERDP_LOCAL BOOL nla_decrypt(rdpNla* nla, const
SecBuffer* inBuffer,
SecBuffer* outBuffer);
80 FREERDP_LOCAL SECURITY_STATUS nla_QueryContextAttributes(rdpNla* nla, DWORD ulAttr, PVOID pBuffer);