xref: /aosp_15_r20/external/libwebsockets/minimal-examples/raw/minimal-raw-proxy-fallback/README.md (revision 1c60b9aca93fdbc9b5f19b2d2194c91294b22281)
1*1c60b9acSAndroid Build Coastguard Worker# lws minimal ws server raw proxy fallback
2*1c60b9acSAndroid Build Coastguard Worker
3*1c60b9acSAndroid Build Coastguard WorkerThis demonstrates how a vhost doing normal http or http(s) duty can be also be
4*1c60b9acSAndroid Build Coastguard Workerbound to a specific role and protocol as a fallback if the incoming protocol is
5*1c60b9acSAndroid Build Coastguard Workerunexpected for tls or http.  The example makes the fallback role + protocol
6*1c60b9acSAndroid Build Coastguard Workeran lws plugin that performs raw packet proxying.
7*1c60b9acSAndroid Build Coastguard Worker
8*1c60b9acSAndroid Build Coastguard WorkerBy default the fallback in the example will proxy 127.0.0.1:22, which is usually
9*1c60b9acSAndroid Build Coastguard Workeryour ssh server listen port, on 127.0.0.1:7681.  You should be able to ssh into
10*1c60b9acSAndroid Build Coastguard Workerport 7681 the same as you can port 22.  At the same time, you should be able to
11*1c60b9acSAndroid Build Coastguard Workervisit http://127.0.0.1:7681 in a browser (and if you give -s, to
12*1c60b9acSAndroid Build Coastguard Workerhttps://127.0.0.1:7681 while your ssh client can still connect to the same
13*1c60b9acSAndroid Build Coastguard Workerport.
14*1c60b9acSAndroid Build Coastguard Worker
15*1c60b9acSAndroid Build Coastguard Worker## build
16*1c60b9acSAndroid Build Coastguard Worker
17*1c60b9acSAndroid Build Coastguard WorkerTo build this standalone, you must tell cmake where the lws source tree
18*1c60b9acSAndroid Build Coastguard Worker./plugins directory can be found, since it relies on including the source
19*1c60b9acSAndroid Build Coastguard Workerof the raw-proxy plugin.
20*1c60b9acSAndroid Build Coastguard Worker
21*1c60b9acSAndroid Build Coastguard Worker```
22*1c60b9acSAndroid Build Coastguard Worker $ cmake . -DLWS_PLUGINS_DIR=~/libwebsockets/plugins && make
23*1c60b9acSAndroid Build Coastguard Worker```
24*1c60b9acSAndroid Build Coastguard Worker
25*1c60b9acSAndroid Build Coastguard Worker## usage
26*1c60b9acSAndroid Build Coastguard Worker
27*1c60b9acSAndroid Build Coastguard WorkerCommandline option|Meaning
28*1c60b9acSAndroid Build Coastguard Worker---|---
29*1c60b9acSAndroid Build Coastguard Worker-d <loglevel>|Debug verbosity in decimal, eg, -d15
30*1c60b9acSAndroid Build Coastguard Worker-r ipv4:address:port|Configure the remote IP and port that will be proxied, by default ipv4:127.0.0.1:22
31*1c60b9acSAndroid Build Coastguard Worker-s|Configure the server for tls / https and `LWS_SERVER_OPTION_ALLOW_NON_SSL_ON_SSL_PORT`
32*1c60b9acSAndroid Build Coastguard Worker-h|(needs -s) Configure the vhost also for `LWS_SERVER_OPTION_ALLOW_HTTP_ON_HTTPS_LISTENER`, allowing http service on tls port (caution... it's insecure then)
33*1c60b9acSAndroid Build Coastguard Worker-u|(needs -s) Configure the vhost also for `LWS_SERVER_OPTION_REDIRECT_HTTP_TO_HTTPS`, so the server issues a redirect to https to clients that attempt to connect to a server configured for tls with http.
34*1c60b9acSAndroid Build Coastguard Worker```
35*1c60b9acSAndroid Build Coastguard Worker $ ./lws-minimal-raw-proxy
36*1c60b9acSAndroid Build Coastguard Worker[2018/11/30 19:22:35:7290] USER: LWS minimal raw proxy-fallback
37*1c60b9acSAndroid Build Coastguard Worker[2018/11/30 19:22:35:7291] NOTICE: Creating Vhost 'default' port 7681, 1 protocols, IPv6 off
38*1c60b9acSAndroid Build Coastguard Worker[2018/11/30 19:22:35:7336] NOTICE: callback_raw_proxy: onward ipv4 127.0.0.1:22
39*1c60b9acSAndroid Build Coastguard Worker...
40*1c60b9acSAndroid Build Coastguard Worker```
41*1c60b9acSAndroid Build Coastguard Worker
42*1c60b9acSAndroid Build Coastguard Worker```
43*1c60b9acSAndroid Build Coastguard Worker $ ssh -p7681 [email protected]
44*1c60b9acSAndroid Build Coastguard WorkerLast login: Fri Nov 30 19:29:23 2018 from 127.0.0.1
45*1c60b9acSAndroid Build Coastguard Worker[me@learn ~]$
46*1c60b9acSAndroid Build Coastguard Worker```
47*1c60b9acSAndroid Build Coastguard Worker
48*1c60b9acSAndroid Build Coastguard WorkerAt the same time, visiting http(s)://127.0.0.1:7681 in a browser works fine.
49*1c60b9acSAndroid Build Coastguard Worker
50