+++ /dev/null
-/opt/nb/lib/css
\ No newline at end of file
+++ /dev/null
-/*
-@import "/jquery/jquery-ui.css";
-::-moz-selection { background: #5babdf; color: #fff; text-shadow: none; }
-::selection { background: #5babdf; color: #fff; text-shadow: none; }
-*/
-
-/*
-See http://blog.javierusobiaga.com/stop-using-the-viewport-tag-until-you-know-ho
-@viewport{ zoom: 1.0; width: 320px; }
-@-ms-viewport{ width: 320px; zoom: 1.0; }
-border: solid 1px black;
- width: auto;
-*/
-
-html {
- background-color: #333;
- font: 100% 'Trebuchet MS', sans-serif;
-}
-
-body {
- color: #fff;
- display: table;
- margin-left: auto;
- margin-right: auto;
- padding-left: 1em;
- padding-right: 1em;
-}
-
-#content {
- width: 100%;
-}
-
-ul {
- padding: 0;
- margin: 0;
-}
-
-li {
- list-style:none;
- padding: 0 0 0 0.3em;
-}
-
-a[href] {
- text-decoration: none;
- color: #2A83BA;
-}
-
-hr {
- clear: both;
- margin: 0;
- padding: 0.5px 0;
- border: none;
- background-color: #f4f4f4;
-}
-
-table { border-collapse: collapse; }
-td, th { padding: 0.2em 0.7em; }
-th { font-size: 0.8em; }
-select.Z,
-textarea,
-input:not([type]),
-input[type=''],
-input[type='text'] {
- box-shadow: 0 0 5px 0 #eee;
- border-radius: 4px;
- border: solid 1px #eee;
- padding: 0.4em;
-}
-
-.block,
-h1 a,
-.rows th a,
-.rad, .border, object, iframe, pre, .t2d tr {
- background-color: #f8f8f8;
- margin-bottom: 0.5em;
- color: #444;
-}
-
-/*
- Radius / Corners
-*/
-
-table.block,
-table.rad {
- border-collapse: separate;
- border-spacing: 0;
-}
-
-.block,
-.rad {
- padding: 0.2em 0.1em;
- border-radius: 4px;
- -webkit-border-radius: 4px;
- -moz-border-radius: 4px;
-}
-
-.block,
-.border {
- border: solid 1px #ccc;
-}
-
-/*
-td.name,
-td.email,
-td.phone {
- white-space: nowrap;
-}
-*/
-
-.rows div.list a {
- list-style: disc inside none;
- display: list-item;
- /*
- background:
- url()
- no-repeat
- left center
- ;
- */
-}
-.rows div.list a.revision {
- text-transform: capitalize;
- list-style-type: circle;
-}
-/*
-.rows div.list a.revision:before {
- content: ">";
-}
-*/
-.rows div.list {
- white-space: nowrap;
- margin: 0;
- padding: 0 0.3em;
- max-width: 10em;
- height: 3.5em;
- overflow: scroll;
- border: solid 1px #ddd;
- /*
- opacity: 0.5;
- */
- border-radius: 4px;
- -webkit-border-radius: 4px;
- -moz-border-radius: 4px;
-}
-
-.small { font-size: 70%; }
-
-.db h1 {
- display: inline-block;
- padding: 0 0.2em;
-}
-
-/*
-table.border { border-bottom: none; }
-table.border td, table.border th { border-bottom: solid 1px #eee; }
-*/
-table.block th, table.block td,
-table.border th, table.border td {
- border-bottom: solid 1px #eee;
-}
-
-table.block tr:last-child td, table.border tr:last-child td { border-bottom: none; }
-/*
-table.border tr.row:hover td:not([class~=action]) {
-*/
-table.block tr:hover td,
-table.border tr.row:hover td {
- background-color: #f1f1f1;
-}
-
-div.rows .row li {
- border-bottom: solid 0.1em #fafafa;
-}
-
-.options input[name="debug"] {
- width: 2em;
-}
-
-/*
- Markdown
-*/
-.db div.md {
- /*
- display: inline-block;
- margin-left: 25%;
- padding: 0.1em;
- margin-top: -50px;
- padding: 0;
- padding: 0.3em;
- float: right;
- */
- display: inline-block;
-}
-
-/*
-.db div.md p { margin: 0; padding: 0.2em 0.8em; }
-*/
-
-.inherit {
- font-size: inherit;
- font-family: inherit;
- background-color: #fff;
- border: none;
-}
-
-/*
- Criterias
- width: 16em;
-*/
-.menu {
- font-size: 80%;
- clear: both;
-}
-
-.menu select,
-.menu input:not([type=button]):not([type=password]):not([type=submit]) {
- max-width: 8em;
-}
-
-.menu span {
- border: solid 1px #f4f4f4;
- /*
- display: inline-block;
- max-width: 28em;
- */
-}
-
-.options {
- border-bottom: solid 1px #f4f4f4;
- margin-bottom: 0.1em;
-}
-
-@media (min-width: 400px) {
- #_responsive {
- content: none;
- }
- .t2d-th { display: none; }
-
- .menu .buttons {
- margin-left: auto;
- margin-right: auto;
- display: inline-block;
- }
-
- .menu .label {
- display: inline-block;
- }
-
- .menu .label label {
- display: inline-block;
- text-align: right;
- white-space: nowrap;
- }
-
- .db div.md { float: right; }
-
-
-}
-
-@media (max-width: 400px) {
- #_responsive {
- content: "400";
- }
- .menu .buttons {
- display: block;
- }
- .label {
- display: block;
- }
- .label label {
- min-width: 25%;
- display: inline-block;
- vertical-align: middle;
- }
-
- .t2d {
- /*
- */
- border: none;
- border-radius: 0;
- -webkit-border-radius: 0;
- -moz-border-radius: 0;
- box-shadow: none;
- -webkit-box-shadow: none;
- -moz-box-shadow: none;
- background-color: inherit;
- }
- .t2d thead { display: none; }
- .t2d tbody tr, .t2d tbody td { display: block; }
- .t2d tr {
- margin-bottom: 0.4em;
- border-radius: 4px;
- -webkit-border-radius: 4px;
- -moz-border-radius: 4px;
- padding: 0.2em 0.1em;
- }
- .t2d-th { min-width: 25%; display: inline-block; }
-
-}
-/* <<< @media */
-
-.button {
- background-color: #ddd;
- border: none;
- color: #444;
-}
-
-.menu, .nav, .rows,
-.center {
- margin-left: auto;
- margin-right: auto;
- display: table;
-}
-
-/*
-table.rows {
- overflow: auto;
-}
-*/
-
-/*
-.debug {
- max-width: 800px;
- display: block;
- overflow: scroll;
-}
-*/
-/*
- See: http://www.ajaxload.info/
-*/
-.loading {
- background:
- url()
- no-repeat
- left center;
-}
+++ /dev/null
-$(document).ready(function(){
-
-var nb = new NB({
- 'ready': true,
- 'resize': {
- 'media_id': '_responsive',
- 'table2div': 'table.rows',
- 'maximize': '.embed',
- 'resize_width': 'table, div',
- },
- 'debug': true,
-});
-
-var TABLE = $(':input[name="table"], #table, form select.tables').first().val();
-var DB = $(':input[name="db"], #db, form select.dbs').first().val();
-var PARAMS = $.param($(
- ':input[value!=""][name="db"]:first'
- +',:input[value!=""][name="table"]:first'
- +',:input[value!=""][name="debug"]:first'
-));
-
-$('a.delete').href2delete('.nav',/(\d+)( \/ )(\d+)/);
-
-//var rb = document.getElementById('nav_bottom'); var rt = document.getElementById('nav_top'); if (rb && rt) rt.innerHTML = rb.innerHTML;
-$('.rows').each(function(){
- var rows = $(this);
- var nav = rows.next('.nav.bottom');
- if (nav) {
- //console.log ( nav.html() );
- rows.before(nav.clone().attr('id','').removeClass('bottom').addClass('top'));
- }
-});
-
-//$('<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>').prependTo('.criterias');
-var buttons = '<span class="buttons">'
- //+'<input type="submit" class="button submit" value="GO"/>'
- +'<input type="button" class="button table_add" value="Add" onclick="window.location = \'?action=edit&'+PARAMS+'\';"/>'
-// NB 03.04.16 +'<input type="button" class="button table_add" value="Add" onclick="window.location = \'?action=edit&table=\'+$(\'#table\').val()"/>'
- //+'<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>'
- +'<a href="#" class="button" onclick="nb.form_clear($(this).closest(\'form\')[0])">X</a>'
-+'</span>';
-//$('.options .buttons').append( $('<input type="button" onclick="nb.form_clear($(this).closest(\'form\')[0])" value="X"/>') );
-$('.db form.menu .options').append( $(buttons) );
-
-// Class
-$('.nav, table.rows, center.rows .row, div.rows .row, .db.edit .fields, .menu, div.md').addClass('border rad');
-//$('.rows .doc').addClass('rad');
-$(':submit, :button, :reset').addClass('button');
-$('body > h1, .err').addClass('rad');
-
-// Replace with queries
-var sql = {
- "SELECT '@id (' || count(*) || ')' FROM @id": ".menu .tables li a, .menu .tables li span",
-};
-for (var k in sql) { sql2html(k,sql[k]); }
-/*
-console.log($('#db-table-replace').text().split(' '));
-*/
-if ($('#db-table-replace').length>0) $.each($('#db-table-replace').text().split(' '),function(i,v){
- v = v.split('.');
- var r = v[0];
- var t = v[1];
- var f = v[2];
- //console.log('.rows td.'+f+', .rows span.'+f+' | '+'SELECT '+f+' FROM '+t+" WHERE id='@id'");
- sql2html('SELECT '+f+' FROM '+t+" WHERE id='@id'",'.rows td.'+r+', .rows span.'+r);
- //console.log('SELECT '+f+' FROM '+t+" WHERE id='@id'"+" | "+'.rows td.'+r+', .rows span.'+r);
-});
-/*
-$('td.revision a').addClass('button').css('margin','0.1em auto');
-$('td.revision').css('text-align','center');
-*/
-
-// Path truncate
-nb.e2links('.rows td.doc, .rows span.doc, .rows td.url, .rows span.url');
-
-// Truncate
-$('.rows .description').each(function(){
- $(this).text( nb.str_trunc($(this).text(),30) );
-});
-
-// Auto submit
-$('.db form.menu select').on('change',function(e){
- //if ($(this).attr('name') == 'tables') alert(this.parentElement);
- if ($(this).attr('class') == 'dbs') return false;
- if ($(this).attr('name') == 'tables') nb.form_clear(this.parentElement);
- //if ($(this).attr('name') == 'format' && $(this).val().match(/table/)) alert('zaza');
- //if ($(this).attr('name') == 'format') alert($(this).val());
- //console.log ($(this).attr('name'));
- return $(this).closest('form').submit();
-});
-
-/*
- <<< End
- Functions >>>
-*/
-
-function zaza(sql) {
-console.log(db);
- $.ajax({
- type: 'GET',
- url: 'index.php',
- data: {
- format: "json",
- header: "0",
- table: sql,
- //table: encodeURI(sql),
- },
- contentType: 'application/json; charset=utf-8',
- dataType: 'json',
- success: function(data) {
- console.log(data);
- },
- error: function() {
- alert('Error loading '+url);
- }
- });
-return;
- var url = 'index.php?format=json&header=0&table='+encodeURI(sql);
- //alert(url);
- var jqxhr = $.getJSON(url,function() {
- //console.log( "success" );
- })
- .done(function(data) {
- //console.log(data);
- $.each( data, function(i,rec) {
- console.log(rec['idtenant']);
- });
- console.log( "second success" );
- })
- .fail(function() {
- //console.log( "error" );
- })
- .always(function() {
- //console.log( "complete" );
- });
-}
-
-function sql2url(sql) {
- var db = DB;
- return 'index.php?format=csv&header=0'
- +(typeof db != 'undefined' ? '&db='+encodeURI(db) : '')
- +'&table='+encodeURI(sql)
- ;
-}
-
-function sql2html(sql,dom) {
- //console.log('BUGGGGGGGGG !!!'); return;
-// TODO - NB 09.04.16 if (!this.cache) this.cache = {};
-
- $(dom).each(function(){
-
- item = $(this)
- id = $(this).text(); if ((typeof id == 'undefined') || id == '' ) return;
- url = sql2url(sql.replace(/@id/g,id.trim().replace("'","\\'")));
- //console.log('dom='+dom+' id='+id+' url='+url);
- //$(this).addClass('loading');
- $(this).load(url,function(){$(this).removeClass('loading')});
- return;
-
- });
- return $(dom);
- /*
- id = $(dom); if (id.length == 0) return;
- id = id.html(); if (typeof id == 'undefined') return;
-
- sql = sql.replace(/@id/,id.replace("'","\\'"));
-
- console.log('dom='+dom+' id='+id+' sql='+sql);
- $.ajax({
-
- type: "GET",
- url: sql2url(sql),
- // data: "table=" + sql, // appears as $_GET['id'] @ ur backend side
- success: function(data) {
- // data is ur summary
- if (data == '') return;
- //data = data.replace('@id',id);
- console.log(' '+dom+'=<'+data.trim()+'>');
- //$(dom).html(data);
- }
-
- });
- */
-}
-
-}); // $(document).ready(function(){
+++ /dev/null
-version: '2'
-services:
- app:
- image: php:7.0-fpm-alpine
- environment:
- NB_ROOT: /opt/nb
- volumes:
- #- ./../../../..:/opt/nb
- - ./../../../../..:/opt
- - ./../../../../www/dbq:/var/www/html
- - /private/etc/dbq:/etc/dbq
- #- ./:/var/www/html
- #- ./../../../../lib/php/db:/var/www/html
- command: "echo . $NB_ROOT/etc/profile > /etc/profile.d/nb.sh"
- php:
- build: ../../php/
- volumes_from:
- - app
- expose:
- - 9000
-
- nginx:
- build:
- context: ../../nginx/
- args:
- - WWW_ROOT=$NB_ROOT/www/dbq
- #image: nginx:latest
- volumes_from:
- - php
- ports:
- - "8080:80"
- links:
- - php
+++ /dev/null
-<?php
-require_once('/opt/nb/lib/php/db/page.php');
-?>
+++ /dev/null
-/opt/nb/lib/jquery
\ No newline at end of file
+++ /dev/null
-/opt/nb/lib/js
\ No newline at end of file
+++ /dev/null
-docker-compose up --force-recreate --build --remove-orphans -d
+++ /dev/null
-#
-# NB 03.11.16
-#
-# __DOCKER_RUN --expose 30865 -v $(test -e /private && echo /private)/etc/csync2.cfg:/etc/csync2.cfg -v $(test -e /private && echo /private)/etc/csync2.key:/etc/csync2.key
-# _DOCKER_RUN --expose 30865 -v $(test -e /private && echo /private)/etc:/etc
-FROM debian
-ENV DEBIAN_FRONTEND noninteractive
-
-#ADD /private/etc/csync2.cfg /etc/csync2.cfg
-#ADD /private/etc/csync2.key /etc/csync2.key
-
-RUN apt-get -q=2 update && apt-get -q=2 -y install csync2 && apt-get clean
-#RUN rm -rf /var/lib/apt/lists/*
-#CMD cd $HOME && /bin/bash --login
-EXPOSE 30865:30865
-ADD ./etc/csync2.cfg /etc/csync2.cfg
-ADD ./etc/csync2.key /etc/csync2.key
-ENTRYPOINT /usr/sbin/csync2 -ii
+++ /dev/null
-FROM nginx:alpine
-
-ARG WWW_ROOT
-ENV WWW_ROOT=${WWW_ROOT:-/var/www/html}
-
-ARG FASTCGI_PASS
-ENV FASTCGI_PASS=${FASTCGI_PASS:-php:9000}
-
-COPY ./default.conf /etc/nginx/conf.d/default.conf
-
-# Set DOCUMENT_ROOT
-RUN test "$WWW_ROOT" && sed -i -e 's,^\([\t ]*root \).*$,\1'$WWW_ROOT';,' /etc/nginx/conf.d/default.conf
-
-# Set FASTCGI_PASS
-RUN test "$FASTCGI_PASS" && sed -i -e 's,^\([\t ]*fastcgi_pass[\t ]*\).*,\1'$FASTCGI_PASS';,' /etc/nginx/conf.d/default.conf
-
-# Create default index.html
-RUN mkdir -p $WWW_ROOT && echo '<html><head><title>Welcom to Nginx Php Fpm</title></head><body><h1>Welcom to Nginx Php Fpm</h1><p>You are connected to '$FASTCGI_PASS'</p></body></html>' > $WWW_ROOT/index.html
-
-# Run daemon
-CMD nginx -g "daemon off; error_log /dev/stdout info;"
+++ /dev/null
-server {
- listen 80 default_server;
- root /var/www/html;
- index index.html index.php;
-
- charset utf-8;
-
- location = /favicon.ico { access_log off; log_not_found off; }
- location = /robots.txt { access_log off; log_not_found off; }
-
- #access_log off;
- #error_log /var/log/nginx/error.log error;
-
- error_log /dev/stderr error;
- access_log /dev/stdout main;
- sendfile off;
-
- client_max_body_size 100m;
-
- location ~ /\.ht {
- deny all;
- }
-
- location / {
- try_files $uri $uri/ /index.php?$query_string;
- }
-
- location ~ /index\.php$ {
- #location index.php {
- fastcgi_split_path_info ^(.+\.php)(/.+)$;
- fastcgi_pass php:9000;
- fastcgi_index index.php;
- include fastcgi_params;
- fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
- fastcgi_intercept_errors off;
- fastcgi_buffer_size 16k;
- fastcgi_buffers 4 16k;
- }
-}
+++ /dev/null
-# DOCKER_RUN --privileged -v $(test -e /private && echo /private)/etc/openvpn:/etc/openvpn
-FROM alpine:latest
-RUN apk update && apk add openvpn
-ADD ./docker-start.sh /etc/init.d/docker-start.sh
-RUN chmod 755 /etc/init.d/docker-start.sh
-CMD "/etc/init.d/docker-start.sh"
+++ /dev/null
-#!/usr/bin/env sh
-
-[ -e /dev/net ] || mkdir -p /dev/net
-[ -e /dev/net/tun ] || mknod /dev/net/tun c 10 200
-
-if [ -e /etc/openvpn/server.conf ]; then
- CONF=/etc/openvpn/server.conf
- IP=$(grep '^server .*$' /etc/openvpn/server.conf | awk '{print $2}')
- iptables -t nat -A POSTROUTING -s ${IP}/24 -o eth0 -j MASQUERADE
-
-elif [ -e /etc/openvpn/client.conf ]; then
- CONF=/etc/openvpn/client.conf
-
-else
-
- echo "No server or client config file"
- exit
-
-fi
-
-/usr/sbin/openvpn --cd /etc/openvpn --config $CONF --script-security 2
+++ /dev/null
-FROM alpine
-
-# Install packages
-RUN set -ex && apk --no-cache add wget perl spawn-fcgi fcgiwrap
-
-#COPY http://nginxlibrary.com/downloads/perl-fcgi/fastcgi-wrapper /usr/bin/fastcgi-wrapper.pl
-#RUN chmod 755 /usr/bin/fastcgi-wrapper.pl
-#COPY ./init.d/* /etc/init.d/
-# Home page
-#RUN mkdir -p /var/www/html && echo '<html><head><title>Welcom to php:7.0-fpm-alpine</title></head><body><h1>Welcom to php:7.0-fpm-alpine</h1></body></html>' > /var/www/html/index.php
-
-# Conf
-
-EXPOSE 8999
-#ENTRYPOINT /usr/bin/fastcgi-wrapper.pl
-ENTRYPOINT /usr/bin/fcgiwrap -s 127.0.0.1:8999
+++ /dev/null
-#!/bin/sh
-### BEGIN INIT INFO
-# Provides: perl-fcgi
-# Required-Start: $local_fs $remote_fs $network $syslog $named
-# Required-Stop: $local_fs $remote_fs $network $syslog $named
-# Default-Start: 2 3 4 5
-# Default-Stop: 0 1 6
-# Short-Description: starts the perl-fcgi
-# Description: starts perl-fcgi using start-stop-daemon
-### END INIT INFO
-PERL_SCRIPT=/usr/bin/fastcgi-wrapper.pl
-RETVAL=0
-case "$1" in
- start)
- $PERL_SCRIPT >/var/log/perl-fcgi.log 2>&1
- RETVAL=$?
- ;;
- stop)
- killall -9 /usr/bin/perl
- RETVAL=$?
- ;;
- restart)
- $0 stop
- $0 start
- RETVAL=$?
- ;;
- *)
- echo "Usage: perl-fastcgi {start|stop|restart}"
- exit 1
- ;;
-esac
-exit $RETVAL
+++ /dev/null
-FROM php:7.0-fpm-alpine
-RUN mkdir /opt
-
-# Install php packages and extentions
-RUN set -ex && apk --no-cache add postgresql-dev sqlite sqlite-dev bash perl perl-uri libmcrypt-dev
-RUN docker-php-ext-install -j$(grep ^proc /proc/cpuinfo |wc -l) mcrypt pdo pdo_mysql pdo_sqlite pdo_sqlite pdo_pgsql pgsql mcrypt
-
-# Home page
-RUN mkdir -p /var/www/html && echo '<html><head><title>Welcom to php:7.0-fpm-alpine</title></head><body><h1>Welcom to php:7.0-fpm-alpine</h1></body></html>' > /var/www/html/index.php
-
-# Conf
-COPY ./php-fpm.d/* /usr/local/etc/php-fpm.d/
-RUN rm -f /usr/local/etc/php-fpm.d/www.conf.default
-
-EXPOSE 9000
-#CMD ["/usr/local/bin/php", "-a"]
-ENTRYPOINT /usr/local/sbin/php-fpm
+++ /dev/null
-[socket]
-user = www-data
-group = www-data
-listen = /var/run/php5-fpm.sock
-listen.owner = www-data
-listen.group = www-data
-pm = dynamic
-pm.max_children = 5
-pm.start_servers = 2
-pm.min_spare_servers = 1
-pm.max_spare_servers = 3
-chdir = /
+++ /dev/null
-[www]
-user = www-data
-group = www-data
-listen = 127.0.0.1:9000
-pm = dynamic
-pm.max_children = 5
-pm.start_servers = 2
-pm.min_spare_servers = 1
-pm.max_spare_servers = 3