Простой способ обнаружения эмуляторов ключа Guardant Хабрахабр. При работе с ключом защиты Guardant не важно какой модели разработчик использует соответствующие API, при этом от него скрыт сам механизм работы с устройством, не говоря уже о протоколе обмена. Он не имеет на руках валидного хэндла устройства, пользуясь только адресом шлюза т. Сметные программы для Казахстана SANA и ABC. В чем проблема АРОС, Турбо сметчик, Сметный калькулятор, Онлайн расчеты, Прочие. Инструкция По Эксплуатации Бортового Компьютера Тойота Авенсис 2007. Не ставятся драйвера ключей при автоматической полной. Сметный калькулятор middot Сметный эксперт middot Сметчикстроитель. В случае если в системе присутствует эмулятор ключа особенно. Вторая для Guardant Stealth III и выше SignTimeFlashCode. Guardant. Handle через который идет вся работа. В случае если в системе присутствует эмулятор ключа особенно актуально для моделей до Guardant Stealth II включительно используя данный шлюз разработчик не сможет определить, работает ли он с реальным физическим ключом, или его эмуляцией. Задавшись в свое время вопросом как определить наличие физического ключа, мне пришлось немного поштудировать великолепно поданный материал за авторством Павла Агурова в книге. Практика использования и программирования. После чего потратить время на анализ вызовов API функций из трехмегабайтного объектника, линкуемого к приложению, в котором собственно и сокрыта вся магия работы с ключом. В итоге появилось достаточно простое решение данной проблемы не требующее использования оригинальных Guardant API. Единственный минус все это жутко недокументированно и техническая поддержка компании Актив даже не будет рассматривать ваши вопросы, связанные с таким использованием ключей Guardant. Ну и конечно, в какой то момент весь данный код может попросту перестать работать из за изменений в драйверах Guardant. Но пока что, на 2. Порядок действий будет примерно таким Через Setup. Di. Get. Class. Devs. A получим список всех присутствующих устройств. Драйверы электронных ключей требуются для нормальной работы защищенного приложения. Они выступают своего рода проводником между. Различные ключи защиты, удобный менеджер обновлений, функции проверки. Грандсмета для частных сметчиков или при наличии другой сметной. Исследование программ, полные эмуляторы ключей HASP, Hardlock, Guardant, Novex, Eutron. Сметный калькулятор. Проверим, имеет ли устройство отношение к ключам Guardant через проверку GUID устройства. Правда, тут есть небольшой нюанс. Начиная с Guardant Stealth III и выше, изменился протокол работы с ключом, как следствие поменялись константы IOCTL запросов и содержимое входящего и исходящего буфера. Для нормальной работы алгоритма желательно поддерживать возможности как старых, так и новых ключей, поэтому опишу различия Для начала константы IOCTL выглядят так Get. Dongle. Query. Record. IOCTL E1. B2. 00. Get. Dongle. Query. Record. Ex. IOCTL E1. B2. 00. 18. Первая для ключей от Guardant Stealth III. Вторая для Guardant Stealth III и выше SignTimeFlashCodeОтправляя первый запрос на устройство, мы будем ожидать что драйвер нам вернет следующий буфер TDongle. Query. Record packed record. Public. Code DWord Public code. Hrw. Version Byte Аппаратная версия ключа. Max. Net. Res Byte Максимальный сетевой ресурс. Type WORD Флаги типа ключа. ID DWord ID ключа. NProg Byte Номер программы. Ver Byte Версия. SN WORD Серийный номер. Mask WORD Битовая маска. GP WORD Счетчик запусков GPСчетчик времени. Real. Net. Res WORD Текущий сетевой ресурс, д. Точнее запрос конечно, будет выполнен, но буфер придет пустой обниленый. Поэтому на новые ключи мы посылаем второй запрос, который вернет данные немного в другом формате TDongle. Query. Record. Ex packed record. Unknown. 0 array. К сожалению по некоторым причинам я не могу вам дать полное описание данной структуры, но необходимые для данной статьи поля я в ней оставил. Общий код получения данных о установленных ключах выглядит так procedure TEnum. Dongles. Ex. Update. Required DWord. h. All. Devices H. В принципе здесь нет ничего секретного, как видите при вызовах не используется даже шифрование передаваемых и получаемых буферов, но почему то разработчики Guardant SDK не сочли нужным опубликовать данную информацию правда я все же смог получить разрешение на публикацию данного кода, т. Данная функция возвращает полный путь к устройству от рута. Выглядит ее реализация следующим образом function Get. Pn. P. PCI шина или HCD хаб как минимум будут одним из предков. В функции Update. USBDevices вы можете увидеть как можно определить какие из DRIVE. В общем то ничего нового, общий принцип был показан еще в демопримере безопасного отключения Flash устройств. Приведен пример получения строкового представления Public. Code ключа естественно без завершающего контрольного символа, во избежание. Приведен пример получения даты выпуска ключа на основе его ID.