lit-jrpc-swig : lit-jrpc to jrpc-node to node-C++
Basic microapp infrastructure for Lit web components which interface other web-components or nodejs using jrpc-oo.
In this microapp, lit eventually interfaces C++ over the network through jrpc then locally from js to C++ using swig.
This infrastructure can be easily cloned and updated for your own microapp which allows you to call objects using JRPC2 over the network between browsers, node or both.
web-dev-server
Local Demo with nodjes and First compile the C++ with swig. Then setup the network and run.
compile C++
Follow the README.md in C++
cd C++
./autogen.sh
./configure
make
# test if you like
cd test
./RunTest.js
setup the network and webapp
We will use secure websockets (although you don't have to), so first generate the certificate :
./jrpc-node.genCert.sh
Install the requirements :
npm i
Start jrpc-node
Start the nodejs JRPC-OO side :
./jrpc-node.js
Start lit-jrpc
Start the web dev server :
npm start
If the browser doesn't open to the demo, manually copy the url from the command line to the browser.
Note : for the first time, look at the console, as you have to clear the browser to use the private cert in this example due to the browser's "privacy error".
In the browser
Click the Test.sayHello button to execute the Test::sayHello C++ code on the other side of the network.
Customise this microapp
We will clone and take ownership of the webcomponent and node class. We will use vanilla in place of lit.
- First clone the repo :
git clone https://github.com/flatmax/lit-jrpc-node.git
- Rename the repo :
mv lit-jrpc-node vanilla-jrpc-node
Rename the webcomponent
Steps to create your own web component :
- Choose a name for your component : I will choose VanillaJRPC (vanilla-jrpc)
- Rename some files in the repo :
- mv lit-jrpc.js vanilla-jrpc.js
- mv src/LitJRPC.js src/VanillaJRPC.js
- Find and replace the component name :
- Replace "LitJRPC" for "VanillaJRPC"
- Replace "lit-jrpc" for "vanilla-jrpc"
Customise your OO class
- Choose a name for your class : I will choose VanillaNode
- Rename the class file :
- mv TestClass.js VanillaNode.js
- Find and replace the class name :
- Replace "TestClass" for "VanillaNode"