Giter Club home page Giter Club logo

cgi-js / cgi-js Goto Github PK

View Code? Open in Web Editor NEW
16.0 2.0 3.0 4.09 MB

Run cgi / interpreted script files that supports command line execution, or connect to cgi / other server proxies : npm install cgijs --save

Home Page: https://www.npmjs.com/package/cgijs

License: Other

PHP 0.45% JavaScript 97.52% Perl 0.13% Python 0.81% Ruby 0.11% Java 0.21% Batchfile 0.01% Shell 0.03% HTML 0.67% ASP.NET 0.06%
cgi-js interpreted-languages apache-httpd apache-tomcat nginx mongoose embedded-server cgi php ruby

cgi-js's Introduction

cgijs

CGIJS is a all featured library to run any CGI mode / Interpreted language script files, or connect to any web application server proxies, or manage processes in the system.

CGIJS library:

  • Supports running any CGI / Interpreted Language scripts using the nodejs process module in any OS that runs node.js. Needs the language interpretor to be installed in the system
  • [TODO] Supports running any CGI / Interpreted Language scripts using interpreters library module in any OS that runs node.js. Do not need the language interpretor to be installed in the system
  • Supports both CGI executables as well as proxy to localhost/ remote /embedded servers using proxying of multiple protocols (http, websockets, tcp, udp, socks, ssh, ftp).
  • Supports managing processes like embedded server executables, embedded database executables, or any other embedded/ non-embedded executables
  • Supports working with shell, json, ini, csv, yaml, and xml internally

[Funding Invited]

General Note: The library is production ready. However, please be cautious of processes/executables permissions/security in your project using CGIJS

History

CGIJS was created with a motivation to allow creation of a Desktop executable/ application using Electron that can run any CGI / Interpreted language scripted files/ applications under the hood.

Desktop CGI

Installation

npm install cgijs --save

If you wish to run interpreted languages like php, perl, python, micropython, cpython, ruby, julia, cpp, golang, ocaml, lua, napi, wasm-run, r-lang, openssl with wasm files without having the language's binary present/ installed in your system then use the following package.

npm install bridge-wasm --save

Features

Light weight, Flexible, Generic implementation. CGIJS is Nodejs Framework Independent / agnostic for application development.

There are three main modules inside CGIJS - file for CGI file execution, proxy for running proxies, and process for managing processes.

SECURITY NOTE:

  • The process shell module is security agnostic and is dependant on your code.
    • The package accesses the shell to run script executables using the node.js process module. Please consider your security risks based on your executable's/ script's security risks.
  • The proxy module is security agnostic and is dependant on your code and proxy's security.
    • The package has a LAN or WAN network proxy module AND does not create any proxies by its own - unless specified by you. Please consider your custom created proxy's security risks.
  • The package does not use Telemetry, nor Collect data Remotely, nor has Telemetry/Remote based Error collection on its own.
    • The package propogates errors for you to handle or collect errors/ data.

Library Features

Node CGI Embedded - run interpreted scripts that support cgi using nodejs
  • CGI file execution
    • Run any scripts that support CGI based serving/execution
    • Run multiple CGI executables/ Interpreters in one or multiple applications
    • Embed your own CGI/ Interpreted Language executables
    • Runs scripts with language interpretor binary (like php, python, ruby, etc) in your system
    • Runs scripts without language interpretor binary (like php, python, ruby, etc) in your system using their wasm packages
Node Web Proxy - run web proxies
  • Running Proxies
    • Run any host that serves a web app, using proxy
    • Run proxies for Application (Local / Remote)
    • Supports websocket implementation in web proxies
    • Run multiple protocol proxies (HTTP, UDP, TCP, Websockets, Socks) and multiple instances in one or multiple applications
Node Processes - Manage web servers, database processes, or other system processes or services
  • Manage Processes or Services
    • Allows running and closing process Executables
    • Allows managing Embedding Web Servers, which can run web applications through proxies [Todo] Testing for some embeddable servers
    • Allows managing Embedded Database servers [Todo] Testing for some embeddable servers
    • Should run smoothly with Unsupported proxy servers/ processes/ services (not widely tested)
  • Embedding
    • Multiple web servers in one or multiple applications
    • Multiple databases in one or multiple applications

Functionality Details

The script should support piping all files of below interpreted languages:
  • Python (2.x, 3.x) - py (for Python .py extension files. Needed for *nix systems)
  • Perl (Version Independent) - plc, pld, pl (for Perl .pl, .plc, .pld extension files)
  • PHP (Version Independent) - php (for .php extension files)
  • Ruby (Version Independent) - rb (for Ruby .rb extension files)
  • Node.js (Version Independent) - js (for Node.js .js extension files)
  • CGI - cgi (for CGI .cgi extension files) [Todo Testing]
The script should support piping all proxies of above languages and following:
  • Jsp (With Tomcat, or any webserver as proxy)
  • Aspx (With IIS, Apache, or any webserver as proxy)
  • [] Jsp (With Tomcat embedded) [Todo]
  • [] Aspx (With Nginx and Apache embedded) [Todo]
The script currently allows working with (starting, stopping, restarting using bash, bat scripts) following web servers:
  • IIS [Done]
  • Nginx [Done]
  • Apache HTTPD [Done]
  • Apache TomCat [Done]
  • Nginx (Allows Embed) [Done]
  • Apache HTTPD (Allows Embed) [Done]
  • Apache TomCat (Allows Embed) [Todo - Testing], should work based on current testing of other proxies
  • Mongoose [Todo - Testing], should work based on current testing of other proxies
  • Jetty [Todo - Testing], should work based on current testing of other proxies
  • Putty [Todo - Testing], should work based on current testing of other proxies
  • [] Mongoose (Allows Embed) [Todo - Testing]
  • [] Jetty (Allows Embed) [Todo - Testing]
  • Putty (Allows Embed) [Todo - Testing]
  • PHP development server using php -S
  • Ruby development server using rails server [Todo - Testing]
  • Python development server using py -m http.server
  • [] Other Proxy-able local/remote servers [InProgress]
The script currently allows working with (starting, stopping, restarting proxies) following web servers:
  • IIS [Done]
  • Nginx [Done]
  • Apache HTTPD [Done]
  • Apache TomCat [Done]
  • Nginx (Allows Embed) [Done]
  • Apache HTTPD (Allows Embed) [Done]
  • Apache TomCat (Allows Embed) [Todo - Testing], should work based on current testing of other proxies
  • Mongoose [Todo - Testing], should work based on current testing of other proxies
  • Jetty [Todo - Testing], should work based on current testing of other proxies
  • Putty [Todo - Testing], should work based on current testing of other proxies
  • [] Mongoose (Allows Embed) [Todo - Testing]
  • [] Jetty (Allows Embed) [Todo - Testing]
  • Putty (Allows Embed) [Todo - Testing]
  • PHP development server using php -S
  • Ruby development server using rails server [Todo - Testing]
  • Python development server using py -m http.server
  • [] Other Proxy-able local/remote servers [InProgress]
The script currently allows working with (starting, stopping, restarting) following web servers:
  • IIS [Done]
  • Nginx [Done]
  • Apache HTTPD [Done]
  • Apache TomCat [Done]
  • Nginx [Done]
  • Apache HTTPD [Done]
  • Apache TomCat [Todo - Testing], should work based on current testing of other proxies
  • Mongoose [Todo - Testing], should work based on current testing of other proxies
  • Jetty [Todo - Testing], should work based on current testing of other proxies
  • Putty [Todo - Testing], should work based on current testing of other proxies
  • [] Mongoose (Allows Embed) [Todo - Testing]
  • [] Jetty (Allows Embed) [Todo - Testing]
  • Putty (Allows Embed) [Todo - Testing]
  • PHP development server using php -S
  • Ruby development server using rails server [Todo - Testing]
  • Python development server using py -m http.server
  • [] Other Proxy-able local/remote servers [InProgress]
The script currently allows working with (starting, stopping, restarting) following databases and processes:
  • Mysql [Done]
  • MongoDB [Done]
  • [] PgSQL [Todo]
  • [] Redis [Todo]
  • bash, bat, ps scripts [Done]
  • Other Processes for your application support
Note:

This library is in active development. Issues, and feedbacks as github ticket are welcome.

Package Dependencies:
  • Environment and Library dependencies:

  • Extra needed dependencies to use language interpretors and libraries for php, perl, python, micropython, cpython, ruby, julia, cpp, golang, ocaml, lua, napi, wasm-run, r-lang, openssl with wasm files without having to install (or have) binaries in your system

    • bridge-wasm for running interpreted languages with wasm without having the binary in your system (installed/ present).
  • Application Dependencies:

    • Your app, you decide
    • Example/Demo has "express": "^4.17.1"
    • Alternatively, Use any other Nodejs framework you want to use for your app
Usage Demo:

This project contains example that demonstrates working with ExpressJS.

  • The demos for runing CGI/Interpreted scripts with node.js and express applications can be found in the folder demo app.
  • The demos for individual implementation of file, process, proxy, and utils modules can be found in the folder demo usage [todo]
Use case:

cgijs library has been created to address following use cases:

  • working with CGI / interpreted languages from any Node.js app framework
  • using any CGI / interpreted languages apps with electron as demonstrated in functioning desktop-cgi app

Technical Specifications

... * Wiki links to be added

Wiki

  • Getting started
    • Quick demo - CGI mode executable files
    • Quick demo - proxying to proxies/servers
    • Quick demo - proxying to proxy's websocket
    • Quick demo - proxying to udp, socks, http to socks proxy's websocket
  • Run CGI files using process module and binaries in the system
    • PHP (.php)
    • Perl (Perl any versions - .plc, .pld, .pl)
    • Python (Python2, Python3 - .py)
    • Ruby (.rb)
    • Node.js (.js)
  • Run CGI files using cgi-js wasm` module
    • PHP (.php)
    • Perl (Perl any versions - .plc, .pld, .pl)
    • Python (Python2, Python3 - .py)
    • Ruby (.rb)
    • Lua (.)
    • Rust (.)
    • GoLang (.go)
    • CPython (.py)
    • Julia (.)
    • R-Lang (.)
  • Run Proxy servers to connect to:
    • Any Local http/https/websocket Servers
    • Any Remote http/https/websocket Servers
    • Embedded Apache httpd, Apache tomcat, Nginx (http/https/websocket)
    • Embedded Mongoose http server (http/https)
  • Manage Embedded Servers (for desktop-cgi use case):
    • Embedded Apache httpd (http/https/websocket)
    • Embedded Apache tomcat (http/https/websocket)
    • Embedded Mongoose http server (http/https)
    • Embedded Nginx (http/https/websocket)
    • PHP inbuilt web development servers
    • Ruby inbuilt web development servers
    • Python inbuilt web development servers
  • Manage Embedded Database Servers (for desktop-cgi use case):
    • Embedded Mysql
    • Embedded MongoDB
    • Embedded PgSQL
    • Working with SQLite
  • Manage Processes (for desktop-cgi use case):
    • Other Processes or executable workings
  • Run and Manage embedded or non-embedded executables / processes on need for application
  • Working with config.json file for simpler implementation in apps

Current Status

  • In development [Testing for Desktop-CGI use case]
  • In development [Testing for language based development server]

Todo

Check .todo file for latest TODO list

License

The MIT License (MIT) - See LICENSE for further details

Copyright © 2019 - till library works: Ganesh B [email protected]

Please support the development in github repository through

- feature needs reporting,
- testing,
- issue reporting,
- contribution

Please use these styles for contributions

cgi-js's People

Contributors

ganeshkbhat avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

cgi-js's Issues

[REQUEST] [STYLE]: Tags for commit and pull requests to follow for standardization

Tags for commit and pull requests:

temp, working commit/feature, refactor, fix, test, perf, feat/milestone, build/tag, release

[Commit:temp]: Commiting temporary nd partial working code for xyz.
[Commit:feature]: Commit new functions and features for code for story xyz.
[Commit:test]: Commiting tests for new functions and features for code for story xyz.
[Commit:feat]: Commit to freeze a tag.
[Commit:tag]: Commit to create build version - a tag.
[Commit:build]: Commit to create build version - a tag.
[Commit:release]: Commit to create a release from commit tag xyz.

[REQUEST] Process for Pull Request

Please describe your request.
Add a clear process for sending a pull request.

Describe the solution you'd like
Process for Pull Request

Describe alternatives you've considered
None

Additional context
None

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.