From 7f707eb094b8167346449cc49def51e0de963466 Mon Sep 17 00:00:00 2001 From: Michel Moriniaux Date: Sun, 12 Mar 2023 15:00:03 -0700 Subject: [PATCH] added Win Installer script --- ...ASCOM.ShortCircuitBigPowerSwitch Setup.iss | 156 ++++++++++++++++++ .../ASCOM.ShortCircuitBigPowerSwitch Test.js | 6 + Drivers/BigPowerSwitchServer/readme.txt | 32 +++- 3 files changed, 193 insertions(+), 1 deletion(-) create mode 100644 Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Setup.iss create mode 100644 Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Test.js diff --git a/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Setup.iss b/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Setup.iss new file mode 100644 index 0000000..4e4a03a --- /dev/null +++ b/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Setup.iss @@ -0,0 +1,156 @@ +; +; Script generated by the ASCOM Driver Installer Script Generator 6.6.0.0 +; Generated by Michel Moriniaux on 3/12/2023 (UTC) +; +[Setup] +AppID={{c3224456-eeb4-4602-ba85-b0c88fcc674c} +AppName=ASCOM ASCOM.ShortCircuitBigPowerSwitch Switch Driver +AppVerName=ASCOM ASCOM.ShortCircuitBigPowerSwitch Switch Driver 0.1.0 +AppVersion=0.1.0 +AppPublisher=Michel Moriniaux +AppPublisherURL=mailto:michel.moriniaux+BPS@gmail.com +AppSupportURL=https://ascomtalk.groups.io/g/Help +AppUpdatesURL=https://ascom-standards.org/ +VersionInfoVersion=1.0.0 +MinVersion=6.1.7601 +DefaultDirName="{cf}\ASCOM\Switch" +DisableDirPage=yes +DisableProgramGroupPage=yes +OutputDir="." +OutputBaseFilename="ASCOM.ShortCircuitBigPowerSwitch Setup" +Compression=lzma +SolidCompression=yes +; Put there by Platform if Driver Installer Support selected +WizardImageFile="C:\Program Files (x86)\ASCOM\Platform 6 Developer Components\Installer Generator\Resources\WizardImage.bmp" +LicenseFile="C:\Program Files (x86)\ASCOM\Platform 6 Developer Components\Installer Generator\Resources\CreativeCommons.txt" +; {cf}\ASCOM\Uninstall\Switch folder created by Platform, always +UninstallFilesDir="{cf}\ASCOM\Uninstall\Switch\ASCOM.ShortCircuitBigPowerSwitch" + +[Languages] +Name: "english"; MessagesFile: "compiler:Default.isl" + +[Dirs] +Name: "{cf}\ASCOM\Uninstall\Switch\ASCOM.ShortCircuitBigPowerSwitch" +; TODO: Add subfolders below {app} as needed (e.g. Name: "{app}\MyFolder") + +[Files] +Source: "C:\Users\Mitch\source\repos\BigPowerSwitchServer\bin\Release\ASCOM.ShortCircuitBigPowerSwitch.exe"; DestDir: "{app}" ;AfterInstall: RegASCOM() +; Require a read-me HTML to appear after installation, maybe driver's Help doc +Source: "C:\Users\Mitch\source\repos\BigPowerSwitchServer\readme.txt"; DestDir: "{app}"; Flags: isreadme +; TODO: Add other files needed by your driver here (add subfolders above) + +;Only if COM Local Server +[Run] +Filename: "{app}\ASCOM.ShortCircuitBigPowerSwitch.exe"; Parameters: "/regserver" + + + + +;Only if COM Local Server +[UninstallRun] +Filename: "{app}\ASCOM.ShortCircuitBigPowerSwitch.exe"; Parameters: "/unregserver" + + + +; DCOM setup for COM local Server, needed for TheSky +[Registry] +; TODO: If needed set this value to the Switch CLSID of your driver (mind the leading/extra '{') +#define AppClsid "{{7e9afd02-a203-4e48-a51f-b9273422785c}" + +; set the DCOM access control for TheSky on the Switch interface +Root: HKCR; Subkey: CLSID\{#AppClsid}; ValueType: string; ValueName: AppID; ValueData: {#AppClsid} +Root: HKCR; Subkey: AppId\{#AppClsid}; ValueType: string; ValueData: "ASCOM ASCOM.ShortCircuitBigPowerSwitch Switch Driver" +Root: HKCR; Subkey: AppId\{#AppClsid}; ValueType: string; ValueName: AppID; ValueData: {#AppClsid} +Root: HKCR; Subkey: AppId\{#AppClsid}; ValueType: dword; ValueName: AuthenticationLevel; ValueData: 1 +; set the DCOM key for the executable as a whole +Root: HKCR; Subkey: AppId\ASCOM.ShortCircuitBigPowerSwitch.exe; ValueType: string; ValueName: AppID; ValueData: {#AppClsid} +; CAUTION! DO NOT EDIT - DELETING ENTIRE APPID TREE WILL BREAK WINDOWS! +Root: HKCR; Subkey: AppId\{#AppClsid}; Flags: uninsdeletekey +Root: HKCR; Subkey: AppId\ASCOM.ShortCircuitBigPowerSwitch.exe; Flags: uninsdeletekey + +[Code] +const + REQUIRED_PLATFORM_VERSION = 6.2; // Set this to the minimum required ASCOM Platform version for this application + +// +// Function to return the ASCOM Platform's version number as a double. +// +function PlatformVersion(): Double; +var + PlatVerString : String; +begin + Result := 0.0; // Initialise the return value in case we can't read the registry + try + if RegQueryStringValue(HKEY_LOCAL_MACHINE_32, 'Software\ASCOM','PlatformVersion', PlatVerString) then + begin // Successfully read the value from the registry + Result := StrToFloat(PlatVerString); // Create a double from the X.Y Platform version string + end; + except + ShowExceptionMessage; + Result:= -1.0; // Indicate in the return value that an exception was generated + end; +end; + +// +// Before the installer UI appears, verify that the required ASCOM Platform version is installed. +// +function InitializeSetup(): Boolean; +var + PlatformVersionNumber : double; + begin + Result := FALSE; // Assume failure + PlatformVersionNumber := PlatformVersion(); // Get the installed Platform version as a double + If PlatformVersionNumber >= REQUIRED_PLATFORM_VERSION then // Check whether we have the minimum required Platform or newer + Result := TRUE + else + if PlatformVersionNumber = 0.0 then + MsgBox('No ASCOM Platform is installed. Please install Platform ' + Format('%3.1f', [REQUIRED_PLATFORM_VERSION]) + ' or later from https://www.ascom-standards.org', mbCriticalError, MB_OK) + else + MsgBox('ASCOM Platform ' + Format('%3.1f', [REQUIRED_PLATFORM_VERSION]) + ' or later is required, but Platform '+ Format('%3.1f', [PlatformVersionNumber]) + ' is installed. Please install the latest Platform before continuing; you will find it at https://www.ascom-standards.org', mbCriticalError, MB_OK); +end; + +// Code to enable the installer to uninstall previous versions of itself when a new version is installed +procedure CurStepChanged(CurStep: TSetupStep); +var + ResultCode: Integer; + UninstallExe: String; + UninstallRegistry: String; +begin + if (CurStep = ssInstall) then // Install step has started + begin + // Create the correct registry location name, which is based on the AppId + UninstallRegistry := ExpandConstant('Software\Microsoft\Windows\CurrentVersion\Uninstall\{#SetupSetting("AppId")}' + '_is1'); + // Check whether an extry exists + if RegQueryStringValue(HKLM, UninstallRegistry, 'UninstallString', UninstallExe) then + begin // Entry exists and previous version is installed so run its uninstaller quietly after informing the user + MsgBox('Setup will now remove the previous version.', mbInformation, MB_OK); + Exec(RemoveQuotes(UninstallExe), ' /SILENT', '', SW_SHOWNORMAL, ewWaitUntilTerminated, ResultCode); + sleep(1000); //Give enough time for the install screen to be repainted before continuing + end + end; +end; + +// +// Register and unregister the driver with the Chooser +// We already know that the Helper is available +// +procedure RegASCOM(); +var + P: Variant; +begin + P := CreateOleObject('ASCOM.Utilities.Profile'); + P.DeviceType := 'Switch'; + P.Register('ASCOM.ShortCircuitBigPowerSwitch.Switch', 'BigPowerSwitch Exxxtreme'); +end; + +procedure CurUninstallStepChanged(CurUninstallStep: TUninstallStep); +var + P: Variant; +begin + if CurUninstallStep = usUninstall then + begin + P := CreateOleObject('ASCOM.Utilities.Profile'); + P.DeviceType := 'Switch'; + P.Unregister('ASCOM.ShortCircuitBigPowerSwitch.Switch'); + end; +end; diff --git a/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Test.js b/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Test.js new file mode 100644 index 0000000..96c78dc --- /dev/null +++ b/Drivers/BigPowerSwitchServer/ASCOM.ShortCircuitBigPowerSwitch Test.js @@ -0,0 +1,6 @@ +//*** CHECK THIS ProgID *** +var X = new ActiveXObject("ASCOM.ShortCircuitBigPowerSwitch.Switch"); +WScript.Echo("This is " + X.Name + ")"); +// You may want to uncomment this... +// X.Connected = true; +X.SetupDialog(); diff --git a/Drivers/BigPowerSwitchServer/readme.txt b/Drivers/BigPowerSwitchServer/readme.txt index b92d11c..d31b278 100644 --- a/Drivers/BigPowerSwitchServer/readme.txt +++ b/Drivers/BigPowerSwitchServer/readme.txt @@ -1 +1,31 @@ -An open source power distribution switch for 12VDC applications +# BigPowerBox Arduino Firmware +An open source power distribution switch for 12VDC applications + +Please see the README for the firmware before reading this file + +- [BigPowerBox Arduino Firmware](#bigpowerbox-arduino-firmware) +- [Introduction](#introduction) +- [Principles of Operation](#principles-of-operation) +- [Installing the driver](#installing-the-driver) +- [Building the driver](#building-the-driver) + +# Introduction +This Ascom driver will work with the open source hardware BigPowerBox or any hardware that respects the BigPowerBox Protocol. + +The driver exposes all the power ports and sensors of the device via Ascom Switches. The polling frequency will depend on the client software. For eg. N.I.N.A polls each switch's name and value every 2sec. + +The configuration pane allows to set the names of the power ports. Note that upon launch the configuration dialog does not know the names saved on the device, please set the comm port and press OK, connect and then re-access the configuration dialog. The names saved on the device will be populated and will be editable. Any modifications done to the port names prior to connecting to the device will be discarded. + +# Principles of Operation +The driver is built as a COM server. This allows multiple clients to connect and control the switches concurrently. +The server driver is started when the first client connects. The server connects to the hardware via a USB serial port, retrieves the board description and populates the internal data structures. +The client polling and hardware polling are decoupled for performance reasons. Once connected the hardware driver starts a polling thread that polls the hardware ( status command ) every ***UPDATEINTERVAL*** seconds ( 2 in the Release version) and updates the internal data structures. When a client requests a port value or status the hardware driver responds with the value stored in the data structure. When a client wants to update a switch the command is directly forwarded to the hardware. +So in short *Read* operations are asynchronous and *Write* oprations are synchronous. +The sevrer maintains a list of clients and shuts down once all clients have disconnected. + +# Installing the driver +Downlad the installer from the realeases tab and run it, it should register the server and make the driver available in the ASCOM choser. + +# Building the driver +Open the solution in Visual Studio 2022 and press `CTRL+B` the driver should build. +Open a command prompt and run the local server exe `ASCOM.ShortCircuitBigPowerSwitch.exe` with the `/regserver` parameter (requires admin privileges), which will create the entry that appears in the ASCOM Chooser. This registration only needs to be done once on each PC. Use the `/unregserver` parameter to unregister the server when no longer required. Never use `REGASM` on the local server executable.