mirror of
https://github.com/warmcat/libwebsockets.git
synced 2025-03-16 00:00:07 +01:00
![]() Establish a new distributed CMake architecture with CMake code related to a source directory moving to be in the subdir in its own CMakeLists.txt. In particular, there's now one in ./lib which calls through to ones further down the directory tree like ./lib/plat/xxx, ./lib/roles/xxx etc. This cuts the main CMakelists.txt from 98KB -> 33KB, about a 66% reduction, and it's much easier to maintain sub-CMakeLists.txt that are in the same directory as the sources they manage, and conceal all the details that that level. Child CMakelists.txt become responsible for: - include_directories() definition (this is not supported by CMake directly, it passes it back up via PARENT_SCOPE vars in helper macros) - Addition child CMakeLists.txt inclusion, for example toplevel -> role -> role subdir - Source file addition to the build - Dependent library path resolution... this is now a private thing in the child CMakeLists.txt, it just passes back any adaptations to include_directories() and the LIB_LIST without filling the parent namespace with the details |
||
---|---|---|
.. | ||
mount-origin | ||
mount-secret-origin | ||
ba-passwords | ||
CMakeLists.txt | ||
minimal-http-server-basicauth.c | ||
README.md |
lws minimal http server basic auth
This demonstrates how to protect a mount using a password file outside of the mount itself.
The demo has two mounts, a normal one at / and one protected by basic auth at /secret.
The file at ./ba-passwords contains valid user:password combinations.
Discovering the authenticated user
After a successful authentication, the WSI_TOKEN_HTTP_AUTHORIZATION
token
contains the authenticated username.
build
$ cmake . && make
usage
$ ./lws-minimal-http-server-basic-auth
[2018/04/19 08:40:05:1333] USER: LWS minimal http server basic auth | visit http://localhost:7681
[2018/04/19 08:40:05:1333] NOTICE: Creating Vhost 'default' port 7681, 1 protocols, IPv6 off
Visit http://localhost:7681, and follow the link there to the secret area.
Give your browser "user" and "password" as the credentials.