2011-07-12 04:46:03 +04:00
|
|
|
/**
|
|
|
|
* FreeRDP: A Remote Desktop Protocol Client
|
|
|
|
* RDP Licensing
|
|
|
|
*
|
|
|
|
* Copyright 2011 Marc-Andre Moreau <marcandre.moreau@gmail.com>
|
|
|
|
*
|
|
|
|
* 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 __LICENSE_H
|
|
|
|
#define __LICENSE_H
|
|
|
|
|
|
|
|
typedef struct rdp_license rdpLicense;
|
|
|
|
|
|
|
|
#include "rdp.h"
|
2011-07-12 10:53:26 +04:00
|
|
|
#include "crypto.h"
|
2011-07-13 02:18:24 +04:00
|
|
|
#include "certificate.h"
|
2011-07-12 04:46:03 +04:00
|
|
|
|
|
|
|
#include <freerdp/freerdp.h>
|
2011-07-12 09:57:09 +04:00
|
|
|
#include <freerdp/utils/debug.h>
|
2011-07-12 04:46:03 +04:00
|
|
|
#include <freerdp/utils/stream.h>
|
|
|
|
|
|
|
|
/* Licensing Packet Types */
|
|
|
|
#define LICENSE_REQUEST 0x01
|
|
|
|
#define PLATFORM_CHALLENGE 0x02
|
|
|
|
#define NEW_LICENSE 0x03
|
|
|
|
#define UPGRADE_LICENSE 0x04
|
|
|
|
#define LICENSE_INFO 0x12
|
|
|
|
#define NEW_LICENSE_REQUEST 0x13
|
|
|
|
#define PLATFORM_CHALLENGE_RESPONSE 0x15
|
|
|
|
#define ERROR_ALERT 0xFF
|
|
|
|
|
|
|
|
#define LICENSE_PKT_CS_MASK (LICENSE_INFO | NEW_LICENSE_REQUEST | PLATFORM_CHALLENGE_RESPONSE | ERROR_ALERT)
|
|
|
|
#define LICENSE_PKT_SC_MASK (LICENSE_REQUEST | PLATFORM_CHALLENGE | NEW_LICENSE | UPGRADE_LICENSE | ERROR_ALERT)
|
|
|
|
#define LICENSE_PKT_MASK (LICENSE_PKT_CS_MASK | LICENSE_PKT_SC_MASK)
|
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
#define LICENSE_PREAMBLE_LENGTH 4
|
|
|
|
#define LICENSE_PACKET_HEADER_LENGTH (RDP_PACKET_HEADER_LENGTH + RDP_SECURITY_HEADER_LENGTH + LICENSE_PREAMBLE_LENGTH)
|
|
|
|
|
2011-07-12 23:10:43 +04:00
|
|
|
/* Cryptographic Lengths */
|
|
|
|
#define CLIENT_RANDOM_LENGTH 32
|
|
|
|
#define SERVER_RANDOM_LENGTH 32
|
|
|
|
#define MASTER_SECRET_LENGTH 48
|
|
|
|
#define PREMASTER_SECRET_LENGTH 48
|
|
|
|
#define SESSION_KEY_BLOB_LENGTH 48
|
|
|
|
#define MAC_SALT_KEY_LENGTH 16
|
|
|
|
#define LICENSING_ENCRYPTION_KEY_LENGTH 16
|
|
|
|
#define HWID_PLATFORM_ID_LENGTH 4
|
|
|
|
#define HWID_UNIQUE_DATA_LENGTH 16
|
|
|
|
#define HWID_LENGTH 20
|
2011-07-15 01:02:35 +04:00
|
|
|
#define LICENSING_PADDING_SIZE 8
|
2011-07-12 23:10:43 +04:00
|
|
|
|
2011-07-12 04:46:03 +04:00
|
|
|
/* Licensing Preamble Flags */
|
|
|
|
#define PREAMBLE_VERSION_2_0 0x02
|
|
|
|
#define PREAMBLE_VERSION_3_0 0x03
|
|
|
|
#define LicenseProtocolVersionMask 0x0F
|
|
|
|
#define EXTENDED_ERROR_MSG_SUPPORTED 0x80
|
|
|
|
|
|
|
|
/* Licensing Binary Blob Types */
|
2011-07-12 09:16:59 +04:00
|
|
|
#define BB_ANY_BLOB 0x0000
|
2011-07-12 04:46:03 +04:00
|
|
|
#define BB_DATA_BLOB 0x0001
|
|
|
|
#define BB_RANDOM_BLOB 0x0002
|
|
|
|
#define BB_CERTIFICATE_BLOB 0x0003
|
|
|
|
#define BB_ERROR_BLOB 0x0004
|
|
|
|
#define BB_ENCRYPTED_DATA_BLOB 0x0009
|
|
|
|
#define BB_KEY_EXCHG_ALG_BLOB 0x000D
|
|
|
|
#define BB_SCOPE_BLOB 0x000E
|
|
|
|
#define BB_CLIENT_USER_NAME_BLOB 0x000F
|
|
|
|
#define BB_CLIENT_MACHINE_NAME_BLOB 0x0010
|
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
/* Key Exchange Algorithms */
|
2011-07-12 04:46:03 +04:00
|
|
|
#define KEY_EXCHANGE_ALG_RSA 0x00000001
|
|
|
|
|
2011-07-15 10:02:09 +04:00
|
|
|
/* Licensing Error Codes */
|
|
|
|
#define ERR_INVALID_SERVER_CERTIFICATE 0x00000001
|
|
|
|
#define ERR_NO_LICENSE 0x00000002
|
|
|
|
#define ERR_INVALID_MAC 0x00000003
|
|
|
|
#define ERR_INVALID_SCOPE 0x00000004
|
|
|
|
#define ERR_NO_LICENSE_SERVER 0x00000006
|
|
|
|
#define STATUS_VALID_CLIENT 0x00000007
|
|
|
|
#define ERR_INVALID_CLIENT 0x00000008
|
|
|
|
#define ERR_INVALID_PRODUCT_ID 0x0000000B
|
|
|
|
#define ERR_INVALID_MESSAGE_LENGTH 0x0000000C
|
|
|
|
|
|
|
|
/* Licensing State Transition Codes */
|
|
|
|
#define ST_TOTAL_ABORT 0x00000001
|
|
|
|
#define ST_NO_TRANSITION 0x00000002
|
|
|
|
#define ST_RESET_PHASE_TO_START 0x00000003
|
|
|
|
#define ST_RESEND_LAST_MESSAGE 0x00000004
|
|
|
|
|
2011-07-12 04:46:03 +04:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint32 dwVersion;
|
|
|
|
uint32 cbCompanyName;
|
|
|
|
uint8* pbCompanyName;
|
|
|
|
uint32 cbProductId;
|
|
|
|
uint8* pbProductId;
|
|
|
|
} PRODUCT_INFO;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint16 type;
|
|
|
|
uint16 length;
|
|
|
|
uint8* data;
|
|
|
|
} LICENSE_BLOB;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint32 count;
|
|
|
|
LICENSE_BLOB* array;
|
|
|
|
} SCOPE_LIST;
|
|
|
|
|
2011-07-15 10:02:09 +04:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
LICENSE_STATE_AWAIT,
|
|
|
|
LICENSE_STATE_PROCESS,
|
|
|
|
LICENSE_STATE_ABORTED,
|
|
|
|
LICENSE_STATE_COMPLETED
|
|
|
|
} LICENSE_STATE;
|
|
|
|
|
2011-07-12 04:46:03 +04:00
|
|
|
struct rdp_license
|
|
|
|
{
|
2011-07-15 10:02:09 +04:00
|
|
|
LICENSE_STATE state;
|
2011-07-12 09:16:59 +04:00
|
|
|
struct rdp_rdp* rdp;
|
2011-07-13 02:18:24 +04:00
|
|
|
struct rdp_certificate* certificate;
|
2011-07-12 23:10:43 +04:00
|
|
|
uint8 hwid[HWID_LENGTH];
|
2011-07-15 01:02:35 +04:00
|
|
|
uint8 modulus[MODULUS_MAX_SIZE];
|
|
|
|
uint8 exponent[EXPONENT_MAX_SIZE];
|
2011-07-12 23:10:43 +04:00
|
|
|
uint8 client_random[CLIENT_RANDOM_LENGTH];
|
|
|
|
uint8 server_random[SERVER_RANDOM_LENGTH];
|
|
|
|
uint8 master_secret[MASTER_SECRET_LENGTH];
|
|
|
|
uint8 premaster_secret[PREMASTER_SECRET_LENGTH];
|
|
|
|
uint8 session_key_blob[SESSION_KEY_BLOB_LENGTH];
|
|
|
|
uint8 mac_salt_key[MAC_SALT_KEY_LENGTH];
|
|
|
|
uint8 licensing_encryption_key[LICENSING_ENCRYPTION_KEY_LENGTH];
|
2011-07-12 09:16:59 +04:00
|
|
|
PRODUCT_INFO* product_info;
|
2011-07-15 10:02:09 +04:00
|
|
|
LICENSE_BLOB* error_info;
|
2011-07-12 09:16:59 +04:00
|
|
|
LICENSE_BLOB* key_exchange_list;
|
|
|
|
LICENSE_BLOB* server_certificate;
|
|
|
|
LICENSE_BLOB* client_user_name;
|
|
|
|
LICENSE_BLOB* client_machine_name;
|
2011-07-15 09:11:09 +04:00
|
|
|
LICENSE_BLOB* platform_challenge;
|
|
|
|
LICENSE_BLOB* encrypted_premaster_secret;
|
2011-07-13 05:43:52 +04:00
|
|
|
LICENSE_BLOB* encrypted_platform_challenge;
|
2011-07-13 18:21:12 +04:00
|
|
|
LICENSE_BLOB* encrypted_hwid;
|
2011-07-12 09:16:59 +04:00
|
|
|
SCOPE_LIST* scope_list;
|
2011-07-12 04:46:03 +04:00
|
|
|
};
|
|
|
|
|
2011-07-18 07:16:31 +04:00
|
|
|
boolean license_connect(rdpLicense* license);
|
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
void license_send(rdpLicense* license, STREAM* s, uint8 type);
|
|
|
|
void license_recv(rdpLicense* license, STREAM* s);
|
|
|
|
STREAM* license_send_stream_init(rdpLicense* license);
|
2011-07-12 04:46:03 +04:00
|
|
|
|
2011-07-13 19:40:19 +04:00
|
|
|
void license_generate_randoms(rdpLicense* license);
|
2011-07-12 09:57:09 +04:00
|
|
|
void license_generate_keys(rdpLicense* license);
|
2011-07-12 10:53:26 +04:00
|
|
|
void license_generate_hwid(rdpLicense* license);
|
2011-07-15 09:11:09 +04:00
|
|
|
void license_encrypt_premaster_secret(rdpLicense* license);
|
|
|
|
void license_decrypt_platform_challenge(rdpLicense* license);
|
2011-07-12 09:57:09 +04:00
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
PRODUCT_INFO* license_new_product_info();
|
|
|
|
void license_free_product_info(PRODUCT_INFO* productInfo);
|
2011-07-12 04:46:03 +04:00
|
|
|
void license_read_product_info(STREAM* s, PRODUCT_INFO* productInfo);
|
2011-07-12 09:16:59 +04:00
|
|
|
|
|
|
|
LICENSE_BLOB* license_new_binary_blob(uint16 type);
|
|
|
|
void license_free_binary_blob(LICENSE_BLOB* blob);
|
2011-07-12 04:46:03 +04:00
|
|
|
void license_read_binary_blob(STREAM* s, LICENSE_BLOB* blob);
|
2011-07-12 09:16:59 +04:00
|
|
|
void license_write_binary_blob(STREAM* s, LICENSE_BLOB* blob);
|
|
|
|
|
|
|
|
SCOPE_LIST* license_new_scope_list();
|
|
|
|
void license_free_scope_list(SCOPE_LIST* scopeList);
|
|
|
|
void license_read_scope_list(STREAM* s, SCOPE_LIST* scopeList);
|
2011-07-12 04:46:03 +04:00
|
|
|
|
|
|
|
void license_read_license_request_packet(rdpLicense* license, STREAM* s);
|
|
|
|
void license_read_platform_challenge_packet(rdpLicense* license, STREAM* s);
|
|
|
|
void license_read_new_license_packet(rdpLicense* license, STREAM* s);
|
|
|
|
void license_read_upgrade_license_packet(rdpLicense* license, STREAM* s);
|
|
|
|
void license_read_error_alert_packet(rdpLicense* license, STREAM* s);
|
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
void license_write_new_license_request_packet(rdpLicense* license, STREAM* s);
|
|
|
|
void license_send_new_license_request_packet(rdpLicense* license);
|
|
|
|
|
2011-07-13 18:21:12 +04:00
|
|
|
void license_write_platform_challenge_response_packet(rdpLicense* license, STREAM* s, uint8* mac_data);
|
2011-07-12 09:57:09 +04:00
|
|
|
void license_send_platform_challenge_response_packet(rdpLicense* license);
|
|
|
|
|
2011-07-12 09:16:59 +04:00
|
|
|
rdpLicense* license_new(rdpRdp* rdp);
|
2011-07-12 04:46:03 +04:00
|
|
|
void license_free(rdpLicense* license);
|
|
|
|
|
2011-07-12 09:57:09 +04:00
|
|
|
#define WITH_DEBUG_LICENSE 1
|
|
|
|
|
|
|
|
#ifdef WITH_DEBUG_LICENSE
|
|
|
|
#define DEBUG_LICENSE(fmt, ...) DEBUG_CLASS(LICENSE, fmt, ## __VA_ARGS__)
|
|
|
|
#else
|
|
|
|
#define DEBUG_LICENSE(fmt, ...) DEBUG_NULL(fmt, ## __VA_ARGS__)
|
|
|
|
#endif
|
|
|
|
|
2011-07-12 04:46:03 +04:00
|
|
|
#endif /* __LICENSE_H */
|