20#ifndef FREERDP_LIB_CORE_NLA_H
21#define FREERDP_LIB_CORE_NLA_H
23typedef 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>
42 NLA_STATE_PUB_KEY_AUTH,
43 NLA_STATE_EARLY_USER_AUTH,
50FREERDP_LOCAL
int nla_authenticate(rdpNla* nla);
53FREERDP_LOCAL
int nla_client_begin(rdpNla* nla);
56FREERDP_LOCAL
int nla_recv_pdu(rdpNla* nla,
wStream* s);
59FREERDP_LOCAL SEC_WINNT_AUTH_IDENTITY* nla_get_identity(rdpNla* nla);
62FREERDP_LOCAL NLA_STATE nla_get_state(
const rdpNla* nla);
64FREERDP_LOCAL BOOL nla_set_state(rdpNla* nla, NLA_STATE state);
67FREERDP_LOCAL
const char* nla_get_state_str(NLA_STATE state);
70FREERDP_LOCAL DWORD nla_get_error(
const rdpNla* nla);
73FREERDP_LOCAL INT32 nla_get_sspi_error(
const rdpNla* nla);
76FREERDP_LOCAL BOOL nla_set_service_principal(rdpNla* nla,
const char* service,
77 const char* hostname);
80FREERDP_LOCAL BOOL nla_set_sspi_module(rdpNla* nla,
const char* sspiModule);
83FREERDP_LOCAL BOOL nla_sspi_module_init(rdpNla* nla);
86FREERDP_LOCAL BOOL nla_impersonate(rdpNla* nla);
89FREERDP_LOCAL BOOL nla_revert_to_self(rdpNla* nla);
91FREERDP_LOCAL
void nla_free(rdpNla* nla);
93WINPR_ATTR_MALLOC(nla_free, 1)
95FREERDP_LOCAL rdpNla* nla_new(rdpContext* context, rdpTransport* transport);
97FREERDP_LOCAL
void nla_set_early_user_auth(rdpNla* nla, BOOL earlyUserAuth);
100FREERDP_LOCAL BOOL nla_encrypt(rdpNla* nla, const
SecBuffer* inBuffer,
SecBuffer* outBuffer);
103FREERDP_LOCAL BOOL nla_decrypt(rdpNla* nla, const
SecBuffer* inBuffer,
SecBuffer* outBuffer);
106FREERDP_LOCAL SECURITY_STATUS nla_QueryContextAttributes(rdpNla* nla, DWORD ulAttr, PVOID pBuffer);
109FREERDP_LOCAL SECURITY_STATUS nla_FreeContextBuffer(rdpNla* nla, PVOID pBuffer);