Connect your stream to Twitch's interactions (follow/sub alerts, chat messages/commands, and point redeems) locally! Neon uses the OBS Scripting Engine to substitute the services provided by third-party utilities such as StreamLabs or StreamElements.
This current state of this project is merely what I have built for my own stream: twitch.tv/drayux. However if its adoption gains any popularity, I will likely try to retrofit this to a much more general-format type of project for the typical user.
Avid users of Firebot may wonder what this project offers instead. Both Neon and Firebot are built with the same goal in mind: to handle all stream integrations client-side. The major difference between the two is that Neon can be thought of as a "lightweight" version that runs within OBS for those like me who wish to have all the magic happen seamlessly in the background. I strongly recommend that those who like pretty GUIs use Firebot instead!
<TODO: Add pretty pictures>
This project is still in a pre-alpha state, and therefore has a number of components left to implement before it reaches its basic functionality. The following are the notable remaining features before the project may be considered to be in "alpha."
- TLS certificate authority verification
- Integration with obslua
- > Settings UI for environment config
- Command line interface (complete with environment arguments)
- Web server API
- > JSON encoding/decoding
- > Server command processing (POST requests)
- > Command API to define the environment (client id, etc.)
- Application unification module (aka merging messages from different endpoints as a websocket application for server-side operation)
- > Connection handler (max connections/shared state for AUM)
- cqueues: Lua event handling and socket management [Artix/Arch package: lua-cqueues]
- Unix-based operating system (aka this does not work on Windows)
This isn't an effort to spite Windows users, merely an unfortunate effect of how the platforms differ in handling events within network sockets; pertaining to the
cqueuesdependency
<TODO: Something something run with OBS or command line params/env file (looks for OBS lua, else looks for env file, else looks for anything defined with params. Said params override OBS settings/env options.)>
<TODO: Explain the components, how the server is the hub for all external connections, and how any webpage should connect to it via ws://localhost.>
The websocket between the server and connected pages will contain a unified event stream, such that each indiviual page need only make one websocket connection. All of said functionality takes place within the provided javascript scripts.