wolfssh/ide/winvs
JacobBarthelmeh 39983a2c6c revert header on sln 2023-09-14 14:54:11 -06:00
..
api-test fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
client fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
echoserver fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
testsuite fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
unit-test fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
wolfsftp-client fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
wolfssh wolfSSHd port to Windows 2023-08-30 09:08:25 -07:00
wolfsshd remove DDL typo and update wolfSSHd for DLL Release 2023-09-14 14:49:47 -06:00
README.md fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
include.am fix ups for format, spelling, includes, and string compare 2023-08-30 13:32:17 -07:00
user_settings.h wolfSSHd port to Windows 2023-08-30 09:08:25 -07:00
wolfssh.props Update expected wolfSSL paths on Windows. 2022-02-25 10:06:42 -08:00
wolfssh.sln revert header on sln 2023-09-14 14:54:11 -06:00

README.md

VisualStudio solution for wolfSSH

The solution file, wolfssh.sln, facilitates bulding wolfSSH and its example and test programs. The solution provides both Debug and Release builds of Static and Dynamic 32- or 64-bit libraries. The file user_settings.h should be used in the wolfSSL build to configure it.

This project assumes that the wolfSSH and wolfSSL source directories are installed side-by-side and do not have the version number in their names:

Projects\
    wolfssh\
    wolfssl\

The file wolfssh\ide\winvs\user_settings.h contains the settings used to configure wolfSSL with the appropriate settings. This file must be copied from the directory wolfssh\ide\winvs to wolfssl\IDE\WIN. If you change one copy you must change both copies. The option WOLFCRYPT_ONLY disables the build of the wolfSSL files and only builds the wolfCrypt algorithms. To also keep wolfSSL, delete that option.

User Macros

The solution is using user macros to indicate the location of the wolfSSL library and headers. All paths are set to the default build destinations in the wolfssl64 solution. The user macro wolfCryptDir is used as the base path for finding the libraries. It is initially set to ..\..\..\..\wolfssl. And then, for example, the additional include directories value for the API test project is set to $(wolfCryptDir).

The wolfCryptDir path must be relative to the project files, which are all one directory down

wolfssh/wolfssh.vcxproj
unit-test/unit-test.vcxproj

etc. The other user macros are the directories where the wolfSSL libraries for the different builds may be found. So the user macro wolfCryptDllRelease64 is initially set to

$(wolfCryptDir)\DLL Release\x64

This value is used in the debugging environment for the echoserver's 64-bit DLL Release build is set to

PATH=$(wolfCryptDllRelease64);%PATH%

When you run the echoserver from the debugger, it finds the wolfSSL DLL in that directory.

SSHD Service

Creating a new service sc.exe create wolfSSHd binpath="D:\work\wolfssh\ide\winvs\Debug\x64\wolfsshd.exe -f <sshd_config fils> -h <optionally load host key> -p <optional port number>"

Starting wolfSSHd service run the following command in an adminstrator power shell session: sc.exe start wolfSSHd

To stop the service run the following in an adminstrator power shell session: sc.exe stop wolfSSHd

To delete the service run sc.exe delete wolfSSHd