43360b0453
Continue adding comments to struct rdp_freerdp fields.
151 lines
5.1 KiB
C
151 lines
5.1 KiB
C
/**
|
|
* FreeRDP: A Remote Desktop Protocol Client
|
|
* FreeRDP Interface
|
|
*
|
|
* Copyright 2009-2011 Jay Sorg
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef __FREERDP_H
|
|
#define __FREERDP_H
|
|
|
|
typedef struct rdp_rdp rdpRdp;
|
|
typedef struct rdp_gdi rdpGdi;
|
|
typedef struct rdp_rail rdpRail;
|
|
typedef struct rdp_cache rdpCache;
|
|
typedef struct rdp_channels rdpChannels;
|
|
typedef struct rdp_graphics rdpGraphics;
|
|
|
|
typedef struct rdp_freerdp freerdp;
|
|
typedef struct rdp_context rdpContext;
|
|
typedef struct rdp_freerdp_peer freerdp_peer;
|
|
|
|
#include <freerdp/api.h>
|
|
#include <freerdp/types.h>
|
|
#include <freerdp/settings.h>
|
|
#include <freerdp/extension.h>
|
|
#include <freerdp/utils/stream.h>
|
|
|
|
#include <freerdp/input.h>
|
|
#include <freerdp/update.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef void (*pContextNew)(freerdp* instance, rdpContext* context);
|
|
typedef void (*pContextFree)(freerdp* instance, rdpContext* context);
|
|
|
|
typedef boolean (*pPreConnect)(freerdp* instance);
|
|
typedef boolean (*pPostConnect)(freerdp* instance);
|
|
typedef boolean (*pAuthenticate)(freerdp* instance, char** username, char** password, char** domain);
|
|
typedef boolean (*pVerifyCertificate)(freerdp* instance, char* subject, char* issuer, char* fingerprint);
|
|
|
|
typedef int (*pSendChannelData)(freerdp* instance, int channelId, uint8* data, int size);
|
|
typedef int (*pReceiveChannelData)(freerdp* instance, int channelId, uint8* data, int size, int flags, int total_size);
|
|
|
|
struct rdp_context
|
|
{
|
|
freerdp* instance; /* 0 */
|
|
freerdp_peer* peer; /* 1 */
|
|
uint32 paddingA[16 - 2]; /* 2 */
|
|
|
|
int argc; /* 16 */
|
|
char** argv; /* 17 */
|
|
uint32 paddingB[32 - 18]; /* 18 */
|
|
|
|
rdpRdp* rdp; /* 32 */
|
|
rdpGdi* gdi; /* 33 */
|
|
rdpRail* rail; /* 34 */
|
|
rdpCache* cache; /* 35 */
|
|
rdpChannels* channels; /* 36 */
|
|
rdpGraphics* graphics; /* 37 */
|
|
uint32 paddingC[64 - 38]; /* 38 */
|
|
};
|
|
|
|
/** Defines the options for a given instance of RDP connection.
|
|
* This is built by the client and given to the FreeRDP library to create the connection
|
|
* with the expected options.
|
|
*/
|
|
struct rdp_freerdp
|
|
{
|
|
rdpContext* context; /**< (offset 0)
|
|
Pointer to a rdpContext structure.
|
|
Can be initialized by a call to freerdp_context_new() */
|
|
uint32 paddingA[16 - 1]; /* 1 */
|
|
|
|
rdpInput* input; /* 16 */
|
|
rdpUpdate* update; /* 17 */
|
|
rdpSettings* settings; /* 18 */
|
|
uint32 paddingB[32 - 19]; /* 19 */
|
|
|
|
size_t context_size; /* 32 */
|
|
|
|
pContextNew ContextNew; /**< (offset 33)
|
|
Callback for context allocation
|
|
Can be set before calling freerdp_context_new() to have it executed after allocation and initialization.
|
|
Must be set to NULL if not needed. */
|
|
|
|
pContextFree ContextFree; /**< (offset 34)
|
|
Callback for context deallocation
|
|
Can be set before calling freerdp_context_free() to have it executed before deallocation.
|
|
Must be set to NULL if not needed. */
|
|
uint32 paddingC[48 - 35]; /* 35 */
|
|
|
|
pPreConnect PreConnect; /**< (offset 48)
|
|
Callback for pre-connect operations.
|
|
Can be set before calling freerdp_connect() to have it executed before the actual connection happens.
|
|
Must be set to NULL if not needed. */
|
|
|
|
pPostConnect PostConnect; /**< (offset 49)
|
|
Callback for post-connect operations.
|
|
Can be set before calling freerdp_connect() to have it executed after the actual connection has succeeded.
|
|
Must be set to NULL if not needed. */
|
|
|
|
pAuthenticate Authenticate; /**< (offset 50)
|
|
Callback for authentication.
|
|
It is used to get the username/password when it was not provided at connection time. */
|
|
pVerifyCertificate VerifyCertificate; /**< (offset 51)
|
|
Callback for certificate validation.
|
|
Used to verify that an unknown certificate is trusted. */
|
|
uint32 paddingD[64 - 52]; /* 52 */
|
|
|
|
pSendChannelData SendChannelData; /* 64 */
|
|
pReceiveChannelData ReceiveChannelData; /* 65 */
|
|
uint32 paddingE[80 - 66]; /* 66 */
|
|
};
|
|
|
|
FREERDP_API void freerdp_context_new(freerdp* instance);
|
|
FREERDP_API void freerdp_context_free(freerdp* instance);
|
|
|
|
FREERDP_API boolean freerdp_connect(freerdp* instance);
|
|
FREERDP_API boolean freerdp_shall_disconnect(freerdp* instance);
|
|
FREERDP_API boolean freerdp_disconnect(freerdp* instance);
|
|
|
|
FREERDP_API boolean freerdp_get_fds(freerdp* instance, void** rfds, int* rcount, void** wfds, int* wcount);
|
|
FREERDP_API boolean freerdp_check_fds(freerdp* instance);
|
|
|
|
FREERDP_API uint32 freerdp_error_info(freerdp* instance);
|
|
|
|
FREERDP_API void freerdp_get_version(int* major, int* minor, int* revision);
|
|
|
|
FREERDP_API freerdp* freerdp_new();
|
|
FREERDP_API void freerdp_free(freerdp* instance);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|