wtsvc: implement channel open/close.
This commit is contained in:
parent
3b3c27648d
commit
b1ee431a3e
@ -20,7 +20,8 @@
|
|||||||
set(FREERDP_CHANNELS_SRCS
|
set(FREERDP_CHANNELS_SRCS
|
||||||
libchannels.c
|
libchannels.c
|
||||||
libchannels.h
|
libchannels.h
|
||||||
wtsvc.c)
|
wtsvc.c
|
||||||
|
wtsvc.h)
|
||||||
|
|
||||||
add_library(freerdp-channels ${FREERDP_CHANNELS_SRCS})
|
add_library(freerdp-channels ${FREERDP_CHANNELS_SRCS})
|
||||||
|
|
||||||
|
@ -21,16 +21,52 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <freerdp/freerdp.h>
|
|
||||||
#include <freerdp/utils/memory.h>
|
#include <freerdp/utils/memory.h>
|
||||||
#include <freerdp/channels/wtsvc.h>
|
|
||||||
|
#include "wtsvc.h"
|
||||||
|
|
||||||
void* WTSVirtualChannelOpenEx(
|
void* WTSVirtualChannelOpenEx(
|
||||||
/* __in */ freerdp_peer* client,
|
/* __in */ freerdp_peer* client,
|
||||||
/* __in */ const char* pVirtualName,
|
/* __in */ const char* pVirtualName,
|
||||||
/* __in */ uint32 flags)
|
/* __in */ uint32 flags)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
|
int len;
|
||||||
|
rdpPeerChannel* channel;
|
||||||
|
const char* channel_name;
|
||||||
|
|
||||||
|
channel_name = ((flags & WTS_CHANNEL_OPTION_DYNAMIC) != 0 ? "drdynvc" : pVirtualName);
|
||||||
|
|
||||||
|
len = strlen(channel_name);
|
||||||
|
if (len > 8)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
for (i = 0; i < client->settings->num_channels; i++)
|
||||||
|
{
|
||||||
|
if (client->settings->channels[i].joined &&
|
||||||
|
strncmp(client->settings->channels[i].name, channel_name, len) == 0)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (i >= client->settings->num_channels)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
channel = xnew(rdpPeerChannel);
|
||||||
|
channel->client = client;
|
||||||
|
channel->channel_id = client->settings->channels[i].channel_id;
|
||||||
|
if ((flags & WTS_CHANNEL_OPTION_DYNAMIC) != 0)
|
||||||
|
{
|
||||||
|
channel->channel_type = RDP_PEER_CHANNEL_TYPE_DVC;
|
||||||
|
|
||||||
|
/* TODO: do DVC channel initialization here using pVirtualName */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
channel->channel_type = RDP_PEER_CHANNEL_TYPE_SVC;
|
||||||
|
}
|
||||||
|
|
||||||
|
return channel;
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean WTSVirtualChannelQuery(
|
boolean WTSVirtualChannelQuery(
|
||||||
@ -69,5 +105,10 @@ boolean WTSVirtualChannelWrite(
|
|||||||
boolean WTSVirtualChannelClose(
|
boolean WTSVirtualChannelClose(
|
||||||
/* __in */ void* hChannelHandle)
|
/* __in */ void* hChannelHandle)
|
||||||
{
|
{
|
||||||
return false;
|
rdpPeerChannel* channel = (rdpPeerChannel*) hChannelHandle;
|
||||||
|
|
||||||
|
if (channel != NULL)
|
||||||
|
xfree(channel);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
41
libfreerdp-channels/wtsvc.h
Normal file
41
libfreerdp-channels/wtsvc.h
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/**
|
||||||
|
* FreeRDP: A Remote Desktop Protocol client.
|
||||||
|
* Server Virtual Channel Interface
|
||||||
|
*
|
||||||
|
* Copyright 2011-2012 Vic Lee
|
||||||
|
*
|
||||||
|
* 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 __WTSVC_H
|
||||||
|
#define __WTSVC_H
|
||||||
|
|
||||||
|
#include <freerdp/freerdp.h>
|
||||||
|
#include <freerdp/utils/list.h>
|
||||||
|
#include <freerdp/utils/mutex.h>
|
||||||
|
#include <freerdp/channels/wtsvc.h>
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
RDP_PEER_CHANNEL_TYPE_SVC = 0,
|
||||||
|
RDP_PEER_CHANNEL_TYPE_DVC = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct rdp_peer_channel
|
||||||
|
{
|
||||||
|
freerdp_peer* client;
|
||||||
|
uint16 channel_id;
|
||||||
|
uint16 channel_type;
|
||||||
|
} rdpPeerChannel;
|
||||||
|
|
||||||
|
#endif /* __WTSVC_H */
|
@ -23,3 +23,4 @@ add_executable(tfreerdp-server
|
|||||||
target_link_libraries(tfreerdp-server freerdp-core)
|
target_link_libraries(tfreerdp-server freerdp-core)
|
||||||
target_link_libraries(tfreerdp-server freerdp-utils)
|
target_link_libraries(tfreerdp-server freerdp-utils)
|
||||||
target_link_libraries(tfreerdp-server freerdp-codec)
|
target_link_libraries(tfreerdp-server freerdp-codec)
|
||||||
|
target_link_libraries(tfreerdp-server freerdp-channels)
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include <freerdp/utils/thread.h>
|
#include <freerdp/utils/thread.h>
|
||||||
#include <freerdp/codec/rfx.h>
|
#include <freerdp/codec/rfx.h>
|
||||||
#include <freerdp/listener.h>
|
#include <freerdp/listener.h>
|
||||||
|
#include <freerdp/channels/wtsvc.h>
|
||||||
|
|
||||||
static char* test_pcap_file = NULL;
|
static char* test_pcap_file = NULL;
|
||||||
static boolean test_dump_rfx_realtime = true;
|
static boolean test_dump_rfx_realtime = true;
|
||||||
@ -54,6 +55,7 @@ struct test_peer_context
|
|||||||
int icon_x;
|
int icon_x;
|
||||||
int icon_y;
|
int icon_y;
|
||||||
boolean activated;
|
boolean activated;
|
||||||
|
void* debug_channel;
|
||||||
};
|
};
|
||||||
typedef struct test_peer_context testPeerContext;
|
typedef struct test_peer_context testPeerContext;
|
||||||
|
|
||||||
@ -319,6 +321,9 @@ void tf_peer_dump_rfx(freerdp_peer* client)
|
|||||||
|
|
||||||
boolean tf_peer_post_connect(freerdp_peer* client)
|
boolean tf_peer_post_connect(freerdp_peer* client)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
|
testPeerContext* context = (testPeerContext*) client->context;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This callback is called when the entire connection sequence is done, i.e. we've received the
|
* This callback is called when the entire connection sequence is done, i.e. we've received the
|
||||||
* Font List PDU from the client and sent out the Font Map PDU.
|
* Font List PDU from the client and sent out the Font Map PDU.
|
||||||
@ -342,6 +347,22 @@ boolean tf_peer_post_connect(freerdp_peer* client)
|
|||||||
/* A real server should tag the peer as activated here and start sending updates in mainloop. */
|
/* A real server should tag the peer as activated here and start sending updates in mainloop. */
|
||||||
test_peer_load_icon(client);
|
test_peer_load_icon(client);
|
||||||
|
|
||||||
|
/* Iterate all channel names requested by the client and activate those supported by the server */
|
||||||
|
for (i = 0; i < client->settings->num_channels; i++)
|
||||||
|
{
|
||||||
|
if (client->settings->channels[i].joined)
|
||||||
|
{
|
||||||
|
if (strncmp(client->settings->channels[i].name, "rdpdbg", 6) == 0)
|
||||||
|
{
|
||||||
|
context->debug_channel = WTSVirtualChannelOpenEx(client, "rdpdbg", 0);
|
||||||
|
if (context->debug_channel != NULL)
|
||||||
|
{
|
||||||
|
printf("Open channel rdpdbg.\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Return false here would stop the execution of the peer mainloop. */
|
/* Return false here would stop the execution of the peer mainloop. */
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user