libfreerdp-core: MCS Connect-Initial

This commit is contained in:
Marc-André Moreau 2011-07-07 15:35:09 -04:00
parent 64f71b0b30
commit a05be813be
7 changed files with 246 additions and 52 deletions

View File

@ -25,8 +25,7 @@
* @param length length * @param length length
*/ */
void void ber_write_length(STREAM* s, int length)
ber_write_length(STREAM* s, int length)
{ {
if (length > 0x7F) if (length > 0x7F)
{ {
@ -46,8 +45,7 @@ ber_write_length(STREAM* s, int length)
* @param length length * @param length length
*/ */
void void ber_write_universal_tag(STREAM* s, uint8 tag, int length)
ber_write_universal_tag(STREAM* s, uint8 tag, int length)
{ {
stream_write_uint8(s, (BER_CLASS_UNIV | BER_PRIMITIVE) | (BER_TAG_MASK & tag)); stream_write_uint8(s, (BER_CLASS_UNIV | BER_PRIMITIVE) | (BER_TAG_MASK & tag));
ber_write_length(s, length); ber_write_length(s, length);
@ -60,8 +58,7 @@ ber_write_universal_tag(STREAM* s, uint8 tag, int length)
* @param length length * @param length length
*/ */
void void ber_write_application_tag(STREAM* s, uint8 tag, int length)
ber_write_application_tag(STREAM* s, uint8 tag, int length)
{ {
if (tag > 30) if (tag > 30)
{ {
@ -75,3 +72,52 @@ ber_write_application_tag(STREAM* s, uint8 tag, int length)
ber_write_length(s, length); ber_write_length(s, length);
} }
} }
/**
* Write a BER OCTET_STRING
* @param s stream
* @param oct_str octet string
* @param length string length
*/
void ber_write_octet_string(STREAM* s, uint8* oct_str, int length)
{
ber_write_universal_tag(s, BER_TAG_OCTET_STRING);
stream_write(s, oct_str, length);
}
/**
* Write a BER BOOLEAN
* @param s
* @param value
*/
void ber_write_boolean(STREAM* s, boolean value)
{
ber_write_universal_tag(s, BER_TAG_BOOLEAN);
stream_write_uint8(s, (value == True) ? 0xFF : 0);
}
/**
* Write a BER INTEGER
* @param s
* @param value
*/
void ber_write_integer(STREAM* s, uint32 value)
{
ber_write_universal_tag(s, BER_TAG_INTEGER);
if (value <= 0xFF)
{
stream_write_uint8(s, value);
}
else if (value <= 0xFFFF)
{
stream_write_uint16_be(s, value);
}
else if (value <= 0xFFFFFFFF)
{
stream_write_uint32_be(s, value);
}
}

View File

@ -20,6 +20,7 @@
#ifndef __BER_H #ifndef __BER_H
#define __BER_H #define __BER_H
#include <freerdp/types.h>
#include <freerdp/utils/stream.h> #include <freerdp/utils/stream.h>
/* BER type */ /* BER type */
@ -42,11 +43,11 @@
#define BER_TAG_INTEGER 0x02 #define BER_TAG_INTEGER 0x02
#define BER_TAG_OCTET_STRING 0x04 #define BER_TAG_OCTET_STRING 0x04
void void ber_write_length(STREAM* s, int length);
ber_write_length(STREAM* s, int length); void ber_write_universal_tag(STREAM* s, uint8 tag, int length);
void void ber_write_application_tag(STREAM* s, uint8 tag, int length);
ber_write_universal_tag(STREAM* s, uint8 tag, int length); void ber_write_octet_string(STREAM* s, uint8* oct_str, int length);
void void ber_write_boolean(STREAM* s, boolean value);
ber_write_application_tag(STREAM* s, uint8 tag, int length); void ber_write_integer(STREAM* s, uint32 value);
#endif /* __BER_H */ #endif /* __BER_H */

View File

@ -492,8 +492,7 @@ void credssp_current_time(uint8* timestamp)
* @return new CredSSP state machine. * @return new CredSSP state machine.
*/ */
rdpCredssp* rdpCredssp* credssp_new(rdpTransport* transport)
credssp_new(rdpTransport* transport)
{ {
rdpCredssp* self; rdpCredssp* self;
@ -514,8 +513,7 @@ credssp_new(rdpTransport* transport)
* @param credssp * @param credssp
*/ */
void void credssp_free(rdpCredssp* credssp)
credssp_free(rdpCredssp* credssp)
{ {
if (credssp != NULL) if (credssp != NULL)
{ {

View File

@ -26,3 +26,142 @@
* ITU-T T.125 Multipoint Communication Service Protocol Specification * ITU-T T.125 Multipoint Communication Service Protocol Specification
*/ */
/**
* Connect-Initial ::= [APPLICATION 101] IMPLICIT SEQUENCE
* {
* callingDomainSelector OCTET_STRING,
* calledDomainSelector OCTET_STRING,
* upwardFlag BOOLEAN,
* targetParameters DomainParameters,
* minimumParameters DomainParameters,
* maximumParameters DomainParameters,
* userData OCTET_STRING
* }
*
* DomainParameters ::= SEQUENCE
* {
* maxChannelIds INTEGER (0..MAX),
* maxUserIds INTEGER (0..MAX),
* maxTokenIds INTEGER (0..MAX),
* numPriorities INTEGER (0..MAX),
* minThroughput INTEGER (0..MAX),
* maxHeight INTEGER (0..MAX),
* maxMCSPDUsize INTEGER (0..MAX),
* protocolVersion INTEGER (0..MAX)
* }
*
*/
uint8 callingDomainSelector[1] = "\x01";
uint8 calledDomainSelector[1] = "\x01";
/**
* Initialize MCS Domain Parameters.
* @param domainParameters domain parameters
* @param maxChannelIds max channel ids
* @param maxUserIds max user ids
* @param maxTokenIds max token ids
* @param maxMCSPDUsize max MCS PDU size
*/
static void mcs_init_domain_parameters(DOMAIN_PARAMETERS* domainParameters,
uint32 maxChannelIds, uint32 maxUserIds, uint32 maxTokenIds, uint32 maxMCSPDUsize)
{
domainParameters->maxChannelIds = maxChannelIds;
domainParameters->maxUserIds = maxUserIds;
domainParameters->maxTokenIds = maxTokenIds;
domainParameters->maxMCSPDUsize = maxMCSPDUsize;
}
/**
* Write MCS Domain Parameters.
* @param s stream
* @param domainParameters domain parameters
*/
static void mcs_write_domain_parameters(STREAM* s, DOMAIN_PARAMETERS* domainParameters)
{
ber_write_integer(domainParameters->maxChannelIds);
ber_write_integer(domainParameters->maxUserIds);
ber_write_integer(domainParameters->maxTokenIds);
ber_write_integer(domainParameters->numPriorities);
ber_write_integer(domainParameters->minThroughput);
ber_write_integer(domainParameters->maxHeight);
ber_write_integer(domainParameters->maxMCSPDUsize);
ber_write_integer(domainParameters->protocolVersion);
}
/**
* Write an MCS Connect Initial PDU.
* @param s stream
* @param mcs MCS module
* @param user_data GCC Conference Create Request
*/
void mcs_write_connect_initial(STREAM* s, rdpMcs* mcs, STREAM* user_data)
{
int length;
int gcc_CCrq_length = stream_get_length(user_data);
length = gcc_CCrq_length + 3 * 34 + 13;
/* Connect-Initial (APPLICATION 101, IMPLICIT SEQUENCE) */
ber_write_application_tag(s, MCS_TYPE_CONNECT_INITIAL, length);
/* callingDomainSelector (OCTET_STRING) */
ber_write_octet_string(s, callingDomainSelector, sizeof(callingDomainSelector));
/* calledDomainSelector (OCTET_STRING) */
ber_write_octet_string(s, calledDomainSelector, sizeof(calledDomainSelector));
/* upwardFlag (BOOLEAN) */
ber_write_boolean(s, True);
/* targetParameters (DomainParameters) */
mcs_write_domain_parameters(s, &mcs->targetParameters);
/* minimumParameters (DomainParameters) */
mcs_write_domain_parameters(s, &mcs->minimumParameters);
/* maximumParameters (DomainParameters) */
mcs_write_domain_parameters(s, &mcs->maximumParameters);
/* userData (OCTET_STRING) */
ber_write_octet_string(s, user_data->data, gcc_CCrq_length);
}
/**
* Instantiate new MCS module.
* @param transport transport
* @return new MCS module
*/
rdpMcs* mcs_new(rdpTransport* transport)
{
rdpMcs* mcs;
mcs = (rdpMcs*) xzalloc(sizeof(rdpMcs));
if (mcs != NULL)
{
mcs->transport = transport;
mcs_init_domain_parameters(&mcs->targetParameters, 34, 2, 0, 0xFFFF);
mcs_init_domain_parameters(&mcs->minimumParameters, 1, 1, 1, 0x420);
mcs_init_domain_parameters(&mcs->maximumParameters, 0xFFFF, 0xFC17, 0xFFFF, 0xFFFF);
}
return mcs;
}
/**
* Free MCS module.
* @param mcs MCS module to be freed
*/
void mcs_free(rdpMcs* mcs)
{
if (mcs != NULL)
{
xfree(mcs);
}
}

View File

@ -21,10 +21,37 @@
#define __MCS_H #define __MCS_H
#include "ber.h" #include "ber.h"
#include "transport.h"
#include <freerdp/utils/stream.h> #include <freerdp/utils/stream.h>
#define MCS_BER_CONNECT_INITIAL 0x65 typedef struct
#define MCS_BER_CONNECT_RESPONSE 0x66 {
uint32 maxChannelIds;
uint32 maxUserIds;
uint32 maxTokenIds;
uint32 numPriorities;
uint32 minThroughput;
uint32 maxHeight
uint32 maxMCSPDUsize;
uint32 protocolVersion;
} DOMAIN_PARAMETERS;
struct rdp_mcs
{
struct rdp_transport* transport;
DOMAIN_PARAMETERS targetParameters;
DOMAIN_PARAMETERS minimumParameters;
DOMAIN_PARAMETERS maximumParameters;
};
typedef struct rdp_mcs rdpMcs;
#define MCS_TYPE_CONNECT_INITIAL 0x65
#define MCS_TYPE_CONNECT_RESPONSE 0x66
void mcs_write_connect_initial(STREAM* s, rdpMcs* mcs, int length);
rdpMcs* mcs_new(rdpTransport* transport);
void mcs_free(rdpMcs* mcs);
#endif /* __MCS_H */ #endif /* __MCS_H */

View File

@ -25,8 +25,7 @@
* @param length length * @param length length
*/ */
void void per_write_length(STREAM* s, int length)
per_write_length(STREAM* s, int length)
{ {
if (length > 0x7F) if (length > 0x7F)
stream_write_uint16_be(s, (length | 0x8000)); stream_write_uint16_be(s, (length | 0x8000));
@ -40,8 +39,7 @@ per_write_length(STREAM* s, int length)
* @param choice index of chosen field * @param choice index of chosen field
*/ */
void void per_write_choice(STREAM* s, uint8 choice)
per_write_choice(STREAM* s, uint8 choice)
{ {
stream_write_uint8(s, choice); stream_write_uint8(s, choice);
} }
@ -52,8 +50,7 @@ per_write_choice(STREAM* s, uint8 choice)
* @param selection bit map of selected fields * @param selection bit map of selected fields
*/ */
void void per_write_selection(STREAM* s, uint8 selection)
per_write_selection(STREAM* s, uint8 selection)
{ {
stream_write_uint8(s, selection); stream_write_uint8(s, selection);
} }
@ -64,8 +61,7 @@ per_write_selection(STREAM* s, uint8 selection)
* @param number number of sets * @param number number of sets
*/ */
void void per_write_number_of_sets(STREAM* s, uint8 number)
per_write_number_of_sets(STREAM* s, uint8 number)
{ {
stream_write_uint8(s, number); stream_write_uint8(s, number);
} }
@ -76,8 +72,7 @@ per_write_number_of_sets(STREAM* s, uint8 number)
* @param length * @param length
*/ */
void void per_write_padding(STREAM* s, int length)
per_write_padding(STREAM* s, int length)
{ {
int i; int i;
@ -91,8 +86,7 @@ per_write_padding(STREAM* s, int length)
* @param oid object identifier (oid) * @param oid object identifier (oid)
*/ */
void void per_write_object_identifier(STREAM* s, uint8 oid[6])
per_write_object_identifier(STREAM* s, uint8 oid[6])
{ {
uint8 t12 = (oid[0] << 4) & (oid[1] & 0x0F); uint8 t12 = (oid[0] << 4) & (oid[1] & 0x0F);
stream_write_uint8(s, 5); /* length */ stream_write_uint8(s, 5); /* length */
@ -110,8 +104,7 @@ per_write_object_identifier(STREAM* s, uint8 oid[6])
* @param length string length * @param length string length
*/ */
void void per_write_string(STREAM* s, uint8* str, int length)
per_write_string(STREAM* s, uint8* str, int length)
{ {
int i; int i;
@ -127,8 +120,7 @@ per_write_string(STREAM* s, uint8* str, int length)
* @param min minimum string length * @param min minimum string length
*/ */
void void per_write_octet_string(STREAM* s, uint8* oct_str, int length, int min)
per_write_octet_string(STREAM* s, uint8* oct_str, int length, int min)
{ {
int i; int i;
int mlength; int mlength;
@ -149,8 +141,7 @@ per_write_octet_string(STREAM* s, uint8* oct_str, int length, int min)
* @param min minimum string length * @param min minimum string length
*/ */
void void per_write_numeric_string(STREAM* s, uint8* num_str, int length, int min)
per_write_numeric_string(STREAM* s, uint8* num_str, int length, int min)
{ {
int i; int i;
int mlength; int mlength;

View File

@ -22,21 +22,13 @@
#include <freerdp/utils/stream.h> #include <freerdp/utils/stream.h>
void void per_write_length(STREAM* s, int length);
per_write_length(STREAM* s, int length); void per_write_choice(STREAM* s, uint8 choice);
void void per_write_selection(STREAM* s, uint8 selection);
per_write_choice(STREAM* s, uint8 choice); void per_write_number_of_sets(STREAM* s, uint8 number);
void void per_write_padding(STREAM* s, int length);
per_write_selection(STREAM* s, uint8 selection); void per_write_object_identifier(STREAM* s, uint8 oid[6]);
void void per_write_octet_string(STREAM* s, uint8* oct_str, int length, int min);
per_write_number_of_sets(STREAM* s, uint8 number); void per_write_numeric_string(STREAM* s, uint8* num_str, int length, int min);
void
per_write_padding(STREAM* s, int length);
void
per_write_object_identifier(STREAM* s, uint8 oid[6]);
void
per_write_octet_string(STREAM* s, uint8* oct_str, int length, int min);
void
per_write_numeric_string(STREAM* s, uint8* num_str, int length, int min);
#endif /* __PER_H */ #endif /* __PER_H */