Сервисы - это специальные коммуникационные программы, которые запускаются из почтовой системы, когда от удаленной системы вместо пакета инициирования сеанса связи FTN приходит специальная строка.
Пользователь, соединяясь обычной терминальной программой со станцией, оснащенной системой Аргус, может воспользоваться сервисом, введя с клавиатуры специальную последовательность. Самой распространенной последовательностью для входа в BBS-сервисы являются два идущих подряд символа Escape. Так как символ Escape не являются печатными, вместо него в поле Enter используется символ косой черты (back slash).
Поле Door and parameters содержит путь к исполнимому файлу сервиса и специальные параметры.
Символ '?' перед командой/именем файла в строке Door and Paramenters сообщает о том, что процесс должен быть запущен в скрытом режиме, '!' - в нормальном режиме, а ‹??› - в DETACHED_MODE (без использования консоли). В отличие от ‹?›, флаг ‹??› можно использовать только для Win32-консольных приложений. Попытка запуска DETACHED Win3.1 или DOS-приложения вызовет ошибку. По умолчанию процессы запускаются в минимизированном окне.
Процессы могут быть запущены с определенным уровнем приоритета:
|
запустить с низким приоритетом (IDLE_PRIORITY_CLASS) |
|
запустить с высоким приоритетом (HIGH_PRIORITY_CLASS) |
|
запустить с критическим приоритетом (REALTIME_PRIORITY_CLASS) |
|
'>' - вместо запуска приложения установить файл-флаг с именем, следующим за '>'. |
По умолчанию процессы запускаются с нормальным приоритетом (NORMAL_PRIORITY_CLASS).
После соединения, в момент ожидания входа пользователя, Аргус может высвечивать заставку-приглашение для пользователей терминальных программ. Заставка устанавливается в окне настройки EMSI-данных.
Командная строка сервиса может содержать специальные параметры, которые перед запуском сервиса транслируются в соответствующие значения. Каждый параметр начинается с символа %
. Все параметры регистрозависимы, то есть %c
не может быть использован вместо %C
.
Вот как транслируется строка параметров "Door and parameters" в строку запуска, при скорости DTE 57600, DCE 21600, номере линии - 2 и port handle - 64:
Door and parameters | d:\max\maxn.exe -s%b -b%B -n%n -p%h |
Translated execution string | d:\max\maxn.exe -s57600 -b21600 -n2 -p64 |
Вне зависимости от того, указан какой-либо параметр или нет, система Аргус создает для запускаемого сервиса блок переменных окружения, в котором передаются все значения специальных параметров.
Environment | Description | Dialup value | TCP/IP value | |
|
|
Скорость соединения | DCE (modem to modem) | Значение берется из “подразумеваемой скорости соединения” |
|
|
Скорость порта | DTE (computer to modem) | такое же, как и %B |
|
|
Строка CONNECT (пробелы заменены на подчеркивания) | такая, как вернул модем, например "16800/ARQ/HST ” |
формируется TCP/IP Daemon›ом на основе адреса и порта соединения, например:
" |
|
|
Транслированный код коррекции ошибок | "MNP ", если в строке CONNECT присутствует MNP, ARQ или REL, иначе пустая строка |
Всегда "TCP/IP " |
|
|
Имя линии почтовой системы (пробелы заменены на подчеркивания) | берется из названия линии, указанного в диалоге dialup/lines/line | "TCP/IP" плюс порядковый номер TCP/IP соединения, например:
" |
|
|
Номер линии почтовой системы | Порядковый номер в списке dialup/lines, например "1 " для первой линии |
порядковый номер TCP/IP соединения, например "2 " для линии "TCP/IP 2 " |
|
|
Communication resource handle | COM port Win32 handle | WinSock2 overlapped socket handle |
|
|
Номер порта | Номер COM-порта, например "1 " для COM1 или "4 " для COM4 |
Номер TCP/IP-порт, например: 24554 для BinkP. |
|
|
Индекс порта | Номер порта, считаемый с нуля, например "0 " для COM1 или "3 " для COM4 |
такой же, как и %C |
Если внешнее приложение является полноценной Win32-программой, оно может унаследовать Win32-handle открытого коммуникационного порта (или соединенного Winsock2 overlapped socked), и использовать этот порт (или socket) для передачи данных.
Параметр %Z
всегда транслируется в пустую строку - он предназначен для того, чтобы сообщить системе Аргус о необходимости закрыть порт перед запуском внешнего приложения. После завершения работы приложения Аргус снова откроет порт. Параметр Z%
предназначен для приложений Windows 3.1 и DOS, которые не в состоянии оперировать с портом, открытым в режиме Win32. Поэтому Windows 3.1 и DOS-приложения должны открывать и инициализировать порт самостоятельно.
Параметр %Z
следует использовать с большой осторожностью. При закрытии порта, драйвер Windows сбрасывает все контрольные сигналы UART (см. Контроль потока данных), в том числе DTR, который в большинстве модемов применяется для инициализации. Поэтому, для передачи COM-порта DOS- и Windows 3.1-приложениям, необходимо настроить модем так, чтобы он не воспринимал изменение сигнала DTR как сброс.
Специальные параметры используются также в строке External Fax Receiver диалога конфигурации модемов для запуска внешних программ по приему факсов.
См. также Конфигурация внешних приложений.
Последовательность действий для установки системы Аргус с Proboard BBS под Windows NT (при некоторых изменениях подходят для Windows 95), модем USR Sportster 28800 with Fax (пример предоставил Sean Rima):
1. Добавьте драйвер FOSSIL в \winnt\system32\config.nt, например device=c:\dos\bnu.sys /p=01
2. Argus / Config / Dialup / Modems, выберите Ваш модем и добавьте к строке инициализации AT&C1&D0
.
3. Добавьте к Argus / Advanced / Externals / Doors строку “Enter = pp
” и “Door and Paramenters = c:\pb\proboard.exe %Z -b%B -p%C
”