/** * FreeRDP: A Remote Desktop Protocol Implementation * RDPDR utility functions * * Copyright 2021 Armin Novak * Copyright 2021 Thincast Technologies GmbH * * 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_UTILS_RDPDR_H #define FREERDP_UTILS_RDPDR_H #include #include #ifdef __cplusplus extern "C" { #endif typedef struct { UINT32 DeviceType; UINT32 DeviceId; char PreferredDosName[8]; UINT32 DeviceDataLength; BYTE* DeviceData; } RdpdrDevice; typedef struct { UINT16 CapabilityType; UINT16 CapabilityLength; UINT32 Version; } RDPDR_CAPABILITY_HEADER; FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_component_string(UINT16 component); FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_packetid_string(UINT16 packetid); FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_irp_string(UINT32 major); FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_cap_type_string(UINT16 capability); FREERDP_API LONG scard_log_status_error(const char* tag, const char* what, LONG status); /** @brief log a smartcard related issue with a wLog * * @param log The logger to use * @param what The module affected * @param status The status to log * * @return The \ref status logged * @since version 3.16.0 */ FREERDP_API LONG scard_log_status_error_wlog(wLog* log, const char* what, LONG status); FREERDP_API WINPR_ATTR_NODISCARD const char* scard_get_ioctl_string(UINT32 ioControlCode, BOOL funcName); FREERDP_API WINPR_ATTR_NODISCARD BOOL rdpdr_write_iocompletion_header(wStream* out, UINT32 DeviceId, UINT32 CompletionId, NTSTATUS ioStatus); FREERDP_API void rdpdr_dump_received_packet(wLog* log, DWORD lvl, wStream* out, const char* custom); FREERDP_API void rdpdr_dump_send_packet(wLog* log, DWORD lvl, wStream* out, const char* custom); FREERDP_API WINPR_ATTR_NODISCARD UINT rdpdr_read_capset_header(wLog* log, wStream* s, RDPDR_CAPABILITY_HEADER* header); FREERDP_API WINPR_ATTR_NODISCARD UINT rdpdr_write_capset_header(wLog* log, wStream* s, const RDPDR_CAPABILITY_HEADER* header); /** @brief convert a constant of type \ref RDPDR_CAPS_IRP_MJ to string * * @param ioCode1 A \ref RDPDR_CAPS_IRP_MJ value * @return A string representation of the constant or \b RDPDR_IRP_MJ_UNKNOWN for unknown * values * * @since version 3.21.0 */ FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_irp_val2str(UINT32 ioCode1); /** @brief convert a mask of \ref RDPDR_CAPS_IRP_MJ type values to string * * @param ioCode1Mask A \ref RDPDR_CAPS_IRP_MJ value * @param buffer A pointer to a buffer that can hold the string representation * @param len The length of the buffer in bytes. * @return A string representation of the constant mask or \b nullptr in case the buffer is too * small * * @since version 3.21.0 */ FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_irp_mask2str(UINT32 ioCode1Mask, char* buffer, size_t len); /** @brief Convert a single \ref FreeRDP_RDPDR_DTYP to string * * @param type The value to convert * @return A constant string representation of \ref type or the string \b * UNKNOWN for an invalid value * @since version 3.22.0 */ FREERDP_API WINPR_ATTR_NODISCARD const char* rdpdr_device_type_string(UINT32 type); #ifdef __cplusplus } #endif #endif