This is my first go project. This database is written for data exchange between programs. New save/load function added to write/read whole database from disk! NEW: added IP whitelist: "whitelist.config" in which you can set all allowed client IPs!
NEW: added "json-export" command to export the data base into a ".json" file. NEW: now single quotes: ' are used for data! NEW: added Json import! NEW: now you have to set two ports. The first one is for direct access with a program like nc or other programs. The second is for the new web browser formular to save/load data.
NEW: in the web form the form is always visible. also after commands are executed.
Added blacklisting IPs if there are more than 3 failed logins via TLS/SSL.
NEW: TLS/SSL connections with authentication. To create a SSL certificate with name "cert.pem":
$ openssl req -x509 -nodes -days 365 -newkey rsa:4096 -keyout cert.pem -out cert.pem
Create a password file user and password with: "createuser" program. The name of the users file is: "users.config". It stores the user name and the password hashes and the salt. It has two entry lines for each user!
There is a "settings.l1db" file. It stores the path for all databases. You need to set an existing path there. I did set a directory "l1vmgodata" in my "/home" directory. You have to change this:
l1vmgodata database
:database-root "/home/stefan/l1vmgodata/"
:link '0'
Run with TLS/SSL on:
$ ./l1vmgodata 127.0.0.1 2000 tls=on off
Use TLS/SSL conection:
$ openssl s_client -connect 127.0.0.1:2000 -brief
Login with:
login :username 'password'
You can connect via nc too:
$ nc localhost 2000 2001
And in your web browser:
127.0.0.1:2001
Via nc you can send the "store data" command:
store data :test '12345'
OK
get key :test
12345
The commands are:
store data
store data new
get key
get regex key
get value
get regex value
remove
close
save
load
json-export
json-import
csv-export
csv-import
csv-table-export
csv-table-import
erase all
usage
exit
set-link
rem-link
get-links-number
get-link-name
Store data:
store data :foobar 'test 1234'
A faster command is "store data new". It does not check if a key is already used. You have to take care of it! It is exponentially faster than "store data"!
store data new :foobar 'test 1234'
Get key/remove:
get key :foobar
test 1234
Get value:
get value 'test 1234'
foobar
Get regex key:
get regex key :foo.
foobar
Save example:
save 'test.db'
OK
Load:
load 'test.db'
OK
Close client connection:
close
OK
Export database into ".json" file:
json-export 'test.json'
Import database from ".json" file:
json-import 'test.json'
Erase all data entries. Handle with care:
erase all
OK
Get data usage:
usage
USAGE 0.00% : 1 of 10000
Set links between key values. You can save multiple links between data. Here are the commands:
Set link:
store data :water-n 'water'
OK
store data :water-chem 'H2O'
OK
set-link :water-n 'water-chem'
OK
Get links total number:
get-links-number :water-n ''
1
Get link index 0:
get-link-name :water-n '0'
water-chem
Remove link:
rem-link :water-n 'water-chem'
OK
I did add web.go
webinterface for browser.
You can store and load data in the web browser with the commands like above!
The save and load functions use the value entry as the filename!
exit command to quit the database
CSV table export. The data must be stored like this (chem.l1db):
l1vmgodata database
:1-1-substance "water"
:link '0'
:1-2-chemical "H2O"
:link '0'
:1-3-boiling "100"
:link '0'
:2-1-substance "iron"
:link '0'
:2-2-chemical "Fe"
:link '0'
:2-3-boiling "3070"
:link '0'
So here 1-1-substance "water" is index 1 key 1. And the 1-3-boiling is the last key of index 1.
The CSV table looks like this:
substance, chemical, boiling
water, H2O, 100
iron, Fe, 3070
CSV table import. Now you can import CSV tables also. The entries are named like in a CSV table export. See above.