walnut
Small, light, and secure iot application framework.
Features
- IOT Application server written in Node.js
- Small memory footprint
- Secure
- Uses JWT, not Cookies*
- HTTPS-only
- AES, RSA, and ECDSA encryption and signing
- Safe against CSRF, XSS, and SQL injection
- Safe against Compression attacks
 
- Multi-Tentated Application Management
- Built-in OAuth2 & OAuth3 support
- Facebook Connect
- Google Plus
 
*Cookies are used only for GETs and only where using a token would be less secure such as images which would otherwise require the token to be passed into the img src. They are also scoped such that CSRF attacks are not possible.
In Progress
- Static Asset Serving via Caddy
- HTTPS Certificates provisioned via Let's Encrypt
- HTTPS Key Pinning
- Heroku (pending completion of PostgreSQL support)
- GunDB Support
- OpenID support
Structure
Currently being tested with Ubuntu, Raspbian, and Debian on Digital Ocean, Raspberry Pi, and Heroku.
/srv/walnut/
├── setup.sh (in-progress)
├── core
│   ├── bin
│   ├── boot
│   ├── holepunch
│   └── lib
├── node_modules
├── packages
│   ├── apis
│   ├── pages
│   └── services
├── certs
|   └── live
│       └── example.com
│           ├── fullchain.pem
│           └── privkey.pem
└── var
- corecontains all walnut code
- node_modulesis a flat installation of all dependencies
- certsis a directory for Let's Encrypt (or custom) certificates
- varis a directory for database files and such
- packagescontains 3 types of packages
LICENSE
Apache-2.0
See LICENSE
Description
				
					Languages
				
				
								
								
									JavaScript
								
								83.6%
							
						
							
								
								
									HTML
								
								8.9%
							
						
							
								
								
									Shell
								
								4.6%
							
						
							
								
								
									CSS
								
								2.9%