diff --git a/docker/heimdall/Dockerfile b/docker/heimdall/Dockerfile deleted file mode 100644 index b7b8c040..00000000 --- a/docker/heimdall/Dockerfile +++ /dev/null @@ -1,85 +0,0 @@ -FROM alpine:3.15 -# -# Include dist -ADD dist/ /root/dist/ -# -# Get and install dependencies & packages -RUN apk -U --no-cache add \ - git \ - nginx \ - nginx-mod-http-headers-more \ - php7 \ - php7-cgi \ - php7-ctype \ - php7-fileinfo \ - php7-fpm \ - php7-json \ - php7-mbstring \ - php7-openssl \ - php7-pdo \ - php7-pdo_pgsql \ - php7-pdo_sqlite \ - php7-session \ - php7-sqlite3 \ - php7-tokenizer \ - php7-xml \ - php7-zip && \ -# -# Clone and setup Heimdall, Nginx - git clone https://github.com/linuxserver/heimdall && \ - cd heimdall && \ - git checkout 61a5a1a8b023771e0ff7c056add5537d20737e51 && \ - cd .. && \ - cp -R heimdall/. /var/lib/nginx/html && \ - rm -rf heimdall && \ - cd /var/lib/nginx/html && \ - cp .env.example .env && \ - # Fix error for ArrayInput in smyfony with regard to PHP7.4 (https://github.com/symfony/symfony/pull/32806/files) - sed -i "135s/.*/} elseif (0 === strpos(\$key, '-')) {/" /var/lib/nginx/html/vendor/symfony/console/Input/ArrayInput.php && \ - php7 artisan key:generate && \ -# -## Add previously configured content - mkdir -p /var/lib/nginx/html/storage/app/public/backgrounds/ \ - /var/lib/nginx/html/esvue && \ - tar xvfz /root/dist/esvue.tgz -C /var/lib/nginx/html/esvue && \ - cp /root/dist/app/bg1.jpg /var/lib/nginx/html/public/img/bg1.jpg && \ - cp /root/dist/app/t-pot.png /var/lib/nginx/html/public/img/heimdall-icon-small.png && \ - cp /root/dist/app/app.sqlite /var/lib/nginx/html/database/app.sqlite && \ - cp /root/dist/app/cyberchef.png /var/lib/nginx/html/storage/app/public/icons/ZotKKZA2QKplZhdoF3WLx4UdKKhLFamf3lSMcLkr.png && \ - cp /root/dist/app/esvue.png /var/lib/nginx/html/storage/app/public/icons/3aLDl0Kq42sTHSpIrJtmrOTThpvHoL0Zk2Ay13YT.png && \ - cp /root/dist/app/tsec.png /var/lib/nginx/html/storage/app/public/icons/RHwXCfCeGNDdhYgzlShL9o4NBFL2LHZWajgyeL0a.png && \ - cp /root/dist/app/spiderfoot.png /var/lib/nginx/html/storage/app/public/icons/s7uPe1frJqjv76oI6SNqNbWUsgU1GHYqRALMlwYb.png && \ - cp /root/dist/html/*.html /var/lib/nginx/html/public/ && \ - cp /root/dist/html/favicon.ico /var/lib/nginx/html/public/favicon-16x16.png && \ - cp /root/dist/html/favicon.ico /var/lib/nginx/html/public/favicon-32x32.png && \ - cp /root/dist/html/favicon.ico /var/lib/nginx/html/public/favicon-96x96.png && \ - cp /root/dist/html/favicon.ico /var/lib/nginx/html/public/favicon.ico && \ -# -## Change ownership, permissions - chown root:www-data -R /var/lib/nginx/html && \ - chmod 775 -R /var/lib/nginx/html/storage && \ - chmod 775 -R /var/lib/nginx/html/database && \ - sed -i "s/user = nobody/user = nginx/g" /etc/php7/php-fpm.d/www.conf && \ - sed -i "s/group = nobody/group = nginx/g" /etc/php7/php-fpm.d/www.conf && \ - sed -i "s#;upload_tmp_dir =#upload_tmp_dir = /var/lib/nginx/tmp#g" /etc/php7/php.ini && \ - sed -i "s/9000/64304/g" /etc/php7/php-fpm.d/www.conf && \ - sed -i "s/APP_NAME=Heimdall/APP_NAME=T-Pot/g" /var/lib/nginx/html/.env && \ -## Add Nginx / T-Pot specific configs - rm -rf /etc/nginx/conf.d/* /usr/share/nginx/html/* && \ - mkdir -p /etc/nginx/conf.d && \ - cp /root/dist/conf/nginx.conf /etc/nginx/ && \ - cp -R /root/dist/conf/ssl /etc/nginx/ && \ - cp /root/dist/conf/tpotweb.conf /etc/nginx/conf.d/ && \ - cp /root/dist/start.sh / && \ -## Pack database for first time usage - cd /var/lib/nginx && \ - tar cvfz first.tgz /var/lib/nginx/html/database /var/lib/nginx/html/storage && \ -# -# Clean up - apk del --purge \ - git && \ - rm -rf /root/* && \ - rm -rf /var/cache/apk/* -# -# Start nginx -CMD /start.sh && php-fpm7 && exec nginx -g 'daemon off;' diff --git a/docker/heimdall/dist/app/app.sqlite b/docker/heimdall/dist/app/app.sqlite deleted file mode 100755 index 6ea73855..00000000 Binary files a/docker/heimdall/dist/app/app.sqlite and /dev/null differ diff --git a/docker/heimdall/dist/app/bg1.jpg b/docker/heimdall/dist/app/bg1.jpg deleted file mode 100644 index 1130ed2e..00000000 Binary files a/docker/heimdall/dist/app/bg1.jpg and /dev/null differ diff --git a/docker/heimdall/dist/app/cyberchef.png b/docker/heimdall/dist/app/cyberchef.png deleted file mode 100644 index eb182286..00000000 Binary files a/docker/heimdall/dist/app/cyberchef.png and /dev/null differ diff --git a/docker/heimdall/dist/app/esvue.png b/docker/heimdall/dist/app/esvue.png deleted file mode 100644 index 63e5cd77..00000000 Binary files a/docker/heimdall/dist/app/esvue.png and /dev/null differ diff --git a/docker/heimdall/dist/app/spiderfoot.png b/docker/heimdall/dist/app/spiderfoot.png deleted file mode 100644 index f2ac38f5..00000000 Binary files a/docker/heimdall/dist/app/spiderfoot.png and /dev/null differ diff --git a/docker/heimdall/dist/app/t-pot.png b/docker/heimdall/dist/app/t-pot.png deleted file mode 100644 index 0349351c..00000000 Binary files a/docker/heimdall/dist/app/t-pot.png and /dev/null differ diff --git a/docker/heimdall/dist/start.sh b/docker/heimdall/dist/start.sh deleted file mode 100755 index 6e986628..00000000 --- a/docker/heimdall/dist/start.sh +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/ash -if [ "$(ls /var/lib/nginx/html/database)" = "" ] && [ "$HEIMDALL_PERSIST" = "YES" ]; - then - tar xvfz /var/lib/nginx/first.tgz -C / -fi -if [ "$HEIMDALL_PERSIST" = "YES" ]; - then - chmod 770 -R /var/lib/nginx/html/database /var/lib/nginx/html/storage - chown root:www-data -R /var/lib/nginx/html/database /var/lib/nginx/html/storage -fi diff --git a/docker/honeypots/Dockerfile b/docker/honeypots/Dockerfile index 2531025f..09d15029 100644 --- a/docker/honeypots/Dockerfile +++ b/docker/honeypots/Dockerfile @@ -29,9 +29,8 @@ RUN apk -U add \ /var/log/honeypots && \ cd /opt/ && \ git clone https://github.com/qeeqbox/honeypots && \ - #git clone https://github.com/t3chn0m4g3/honeypots && \ cd honeypots && \ - #git checkout 7c654a3ef2c564ae6f1247bf302d652037080163 && \ + git checkout b88cbbd5aa1d2724c6f7de5d723f0d0e753912bb && \ pip3 install --upgrade pip && \ pip3 install --ignore-installed hiredis packaging && \ pip3 install . && \ diff --git a/docker/honeypots/dist/config.json b/docker/honeypots/dist/config.json index e0e08630..790eebf0 100644 --- a/docker/honeypots/dist/config.json +++ b/docker/honeypots/dist/config.json @@ -1,219 +1,245 @@ { - "logs": "file,terminal,json,tpot", - "logs_location":"/var/log/honeypots/", - "syslog_address": "", - "syslog_facility": 0, - "postgres": "", - "db_options": [], - "filter": "", - "interface": "", - "honeypots": { - "dns": { - "port": 53, - "ip": "0.0.0.0", - "username": "administrator", - "password": "123456", - "log_file_name": "dns.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "ftp": { - "port": 21, - "ip": "0.0.0.0", - "username": "ftp", - "password": "anonymous", - "log_file_name": "ftp.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "httpproxy": { - "port": 8080, - "ip": "0.0.0.0", - "username": "admin", - "password": "admin", - "log_file_name": "httpproxy.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "http": { - "port": 80, - "ip": "0.0.0.0", - "username": "admin", - "password": "admin", - "log_file_name": "http.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "https": { - "port": 443, - "ip": "0.0.0.0", - "username": "admin", - "password": "admin", - "log_file_name": "https.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "imap": { - "port": 143, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "imap.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "mysql": { - "port": 3306, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "mysql.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "pop3": { - "port": 110, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "pop3.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "postgres": { - "port": 5432, - "ip": "0.0.0.0", - "username": "postgres", - "password": "123456", - "log_file_name": "postgres.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "redis": { - "port": 6379, - "ip": "0.0.0.0", - "username": "root", - "password": "", - "log_file_name": "redis.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "smb": { - "port": 445, - "ip": "0.0.0.0", - "username": "administrator", - "password": "123456", - "log_file_name": "smb.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "smtp": { - "port": 25, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "smtp.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "socks5": { - "port": 1080, - "ip": "0.0.0.0", - "username": "admin", - "password": "admin", - "log_file_name": "socks5.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "ssh": { - "port": 22, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "ssh.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "telnet": { - "port": 23, - "ip": "0.0.0.0", - "username": "root", - "password": "123456", - "log_file_name": "telnet.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "vnc": { - "port": 5900, - "ip": "0.0.0.0", - "username": "administrator", - "password": "123456", - "log_file_name": "vnc.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "elastic": { - "port": 9200, - "ip": "0.0.0.0", - "username": "elastic", - "password": "123456", - "log_file_name": "elastic.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "mssql": { - "port": 1433, - "ip": "0.0.0.0", - "username": "sa", - "password": "", - "log_file_name": "mssql.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "ldap": { - "port": 389, - "ip": "0.0.0.0", - "username": "administrator", - "password": "123456", - "log_file_name": "ldap.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "ntp": { - "port": 123, - "ip": "0.0.0.0", - "username": "administrator", - "password": "123456", - "log_file_name": "ntp.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "memcache": { - "port": 11211, - "ip": "0.0.0.0", - "username": "admin", - "password": "123456", - "log_file_name": "memcache.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "oracle": { - "port": 1521, - "ip": "0.0.0.0", - "username": "bi", - "password": "123456", - "log_file_name": "oracle.log", - "max_bytes": 10000, - "backup_count": 10 - }, - "snmp": { - "port": 161, - "ip": "0.0.0.0", - "username": "privUser", - "password": "123456", - "log_file_name": "snmp.log", - "max_bytes": 10000, - "backup_count": 10 - } - } + "logs":"file,terminal,json,tpot", + "logs_location":"/var/log/honeypots/", + "syslog_address":"", + "syslog_facility":0, + "postgres":"", + "db_options":[ + + ], + "filter":"", + "interface":"", + "honeypots":{ + "dns":{ + "port":53, + "ip":"0.0.0.0", + "username":"administrator", + "password":"123456", + "log_file_name":"dns.log", + "max_bytes":0, + "backup_count":10 + }, + "ftp":{ + "port":21, + "ip":"0.0.0.0", + "username":"ftp", + "password":"anonymous", + "log_file_name":"ftp.log", + "max_bytes":0, + "backup_count":10 + }, + "httpproxy":{ + "port":8080, + "ip":"0.0.0.0", + "username":"admin", + "password":"admin", + "log_file_name":"httpproxy.log", + "max_bytes":0, + "backup_count":10 + }, + "http":{ + "port":80, + "ip":"0.0.0.0", + "username":"admin", + "password":"admin", + "log_file_name":"http.log", + "max_bytes":0, + "backup_count":10 + }, + "https":{ + "port":443, + "ip":"0.0.0.0", + "username":"admin", + "password":"admin", + "log_file_name":"https.log", + "max_bytes":0, + "backup_count":10 + }, + "imap":{ + "port":143, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"imap.log", + "max_bytes":0, + "backup_count":10 + }, + "mysql":{ + "port":3306, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"mysql.log", + "max_bytes":0, + "backup_count":10 + }, + "pop3":{ + "port":110, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"pop3.log", + "max_bytes":0, + "backup_count":10 + }, + "postgres":{ + "port":5432, + "ip":"0.0.0.0", + "username":"postgres", + "password":"123456", + "log_file_name":"postgres.log", + "max_bytes":0, + "backup_count":10 + }, + "redis":{ + "port":6379, + "ip":"0.0.0.0", + "username":"root", + "password":"", + "log_file_name":"redis.log", + "max_bytes":0, + "backup_count":10 + }, + "smb":{ + "port":445, + "ip":"0.0.0.0", + "username":"administrator", + "password":"123456", + "log_file_name":"smb.log", + "max_bytes":0, + "backup_count":10 + }, + "smtp":{ + "port":25, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"smtp.log", + "max_bytes":0, + "backup_count":10 + }, + "socks5":{ + "port":1080, + "ip":"0.0.0.0", + "username":"admin", + "password":"admin", + "log_file_name":"socks5.log", + "max_bytes":0, + "backup_count":10 + }, + "ssh":{ + "port":22, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"ssh.log", + "max_bytes":0, + "backup_count":10 + }, + "telnet":{ + "port":23, + "ip":"0.0.0.0", + "username":"root", + "password":"123456", + "log_file_name":"telnet.log", + "max_bytes":0, + "backup_count":10 + }, + "vnc":{ + "port":5900, + "ip":"0.0.0.0", + "username":"administrator", + "password":"123456", + "log_file_name":"vnc.log", + "max_bytes":0, + "backup_count":10 + }, + "elastic":{ + "port":9200, + "ip":"0.0.0.0", + "username":"elastic", + "password":"123456", + "log_file_name":"elastic.log", + "max_bytes":0, + "backup_count":10 + }, + "mssql":{ + "port":1433, + "ip":"0.0.0.0", + "username":"sa", + "password":"", + "log_file_name":"mssql.log", + "max_bytes":0, + "backup_count":10 + }, + "ldap":{ + "port":389, + "ip":"0.0.0.0", + "username":"administrator", + "password":"123456", + "log_file_name":"ldap.log", + "max_bytes":0, + "backup_count":10 + }, + "ntp":{ + "port":123, + "ip":"0.0.0.0", + "username":"administrator", + "password":"123456", + "log_file_name":"ntp.log", + "max_bytes":0, + "backup_count":10 + }, + "memcache":{ + "port":11211, + "ip":"0.0.0.0", + "username":"admin", + "password":"123456", + "log_file_name":"memcache.log", + "max_bytes":0, + "backup_count":10 + }, + "oracle":{ + "port":1521, + "ip":"0.0.0.0", + "username":"bi", + "password":"123456", + "log_file_name":"oracle.log", + "max_bytes":0, + "backup_count":10 + }, + "snmp":{ + "port":161, + "ip":"0.0.0.0", + "username":"privUser", + "password":"123456", + "log_file_name":"snmp.log", + "max_bytes":0, + "backup_count":10 + } + }, + "custom_filter":{ + "honeypots":{ + "change":{ + "server":"protocol" + }, + "contains":[ + "protocol", + "action", + "src_ip", + "src_port", + "dest_ip", + "dest_port" + ], + "remove":[ + + ], + "options":[ + "remove_errors", + "remove_init", + "remove_word_server" + ] + } + } } + diff --git a/docker/nginx/Dockerfile b/docker/nginx/Dockerfile new file mode 100644 index 00000000..150055dc --- /dev/null +++ b/docker/nginx/Dockerfile @@ -0,0 +1,33 @@ +FROM alpine:3.15 +# +# Include dist +ADD dist/ /root/dist/ +# +# Get and install dependencies & packages +RUN apk -U --no-cache add \ + nginx \ + nginx-mod-http-headers-more \ + && \ +# +## Setup T-Pot Landing Page, Eleasticvue + cp -R /root/dist/html/* /var/lib/nginx/html/ && \ + cd /var/lib/nginx/html/esvue && \ + tar xvfz esvue.tgz && \ + rm esvue.tgz && \ +# +## Change ownership, permissions + chown root:www-data -R /var/lib/nginx/html && \ +# +## Add Nginx / T-Pot specific configs + rm -rf /etc/nginx/conf.d/* /usr/share/nginx/html/* && \ + mkdir -p /etc/nginx/conf.d && \ + cp /root/dist/conf/nginx.conf /etc/nginx/ && \ + cp -R /root/dist/conf/ssl /etc/nginx/ && \ + cp /root/dist/conf/tpotweb.conf /etc/nginx/conf.d/ && \ +# +# Clean up + rm -rf /root/* && \ + rm -rf /var/cache/apk/* +# +# Start nginx +CMD nginx -g 'daemon off;' diff --git a/docker/heimdall/dist/conf/nginx.conf b/docker/nginx/dist/conf/nginx.conf similarity index 100% rename from docker/heimdall/dist/conf/nginx.conf rename to docker/nginx/dist/conf/nginx.conf diff --git a/docker/heimdall/dist/conf/ssl/dhparam4096.pem b/docker/nginx/dist/conf/ssl/dhparam4096.pem similarity index 100% rename from docker/heimdall/dist/conf/ssl/dhparam4096.pem rename to docker/nginx/dist/conf/ssl/dhparam4096.pem diff --git a/docker/heimdall/dist/conf/ssl/gen-cert.sh b/docker/nginx/dist/conf/ssl/gen-cert.sh similarity index 100% rename from docker/heimdall/dist/conf/ssl/gen-cert.sh rename to docker/nginx/dist/conf/ssl/gen-cert.sh diff --git a/docker/heimdall/dist/conf/ssl/gen-dhparam.sh b/docker/nginx/dist/conf/ssl/gen-dhparam.sh similarity index 100% rename from docker/heimdall/dist/conf/ssl/gen-dhparam.sh rename to docker/nginx/dist/conf/ssl/gen-dhparam.sh diff --git a/docker/heimdall/dist/conf/tpotweb.conf b/docker/nginx/dist/conf/tpotweb.conf similarity index 89% rename from docker/heimdall/dist/conf/tpotweb.conf rename to docker/nginx/dist/conf/tpotweb.conf index 6a77b964..63051827 100644 --- a/docker/heimdall/dist/conf/tpotweb.conf +++ b/docker/nginx/dist/conf/tpotweb.conf @@ -8,12 +8,11 @@ server { ### Basic server settings ######################### listen 64297 ssl http2; - #index tpotweb.html; - index index.php; + index index.html; ssl_protocols TLSv1.3; server_name example.com; error_page 300 301 302 400 401 402 403 404 500 501 502 503 504 /error.html; - root /var/lib/nginx/html/public; + root /var/lib/nginx/html; ############################################## @@ -86,14 +85,14 @@ server { auth_basic_user_file /etc/nginx/nginxpasswd; - ############ - ### Heimdall - ############ + ############################# + ### T-Pot Landing Page & Apps + ############################# location / { auth_basic "closed site"; auth_basic_user_file /etc/nginx/nginxpasswd; - try_files $uri $uri/ /index.php?$query_string; + try_files $uri $uri/ /index.html?$args; } location ^~ /elasticvue { @@ -102,13 +101,6 @@ server { try_files $uri $uri/ /index.html?$args; } - location ~ \.php$ { - fastcgi_split_path_info ^(.+\.php)(/.+)$; - fastcgi_pass 127.0.0.1:64304; - fastcgi_index index.php; - include fastcgi_params; - fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; - } ################# ### Proxied sites diff --git a/docker/nginx/dist/html/License b/docker/nginx/dist/html/License new file mode 100644 index 00000000..61d18602 --- /dev/null +++ b/docker/nginx/dist/html/License @@ -0,0 +1,674 @@ +GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. \ No newline at end of file diff --git a/docker/nginx/dist/html/README-ES-MX.md b/docker/nginx/dist/html/README-ES-MX.md new file mode 100644 index 00000000..b3086690 --- /dev/null +++ b/docker/nginx/dist/html/README-ES-MX.md @@ -0,0 +1,248 @@ +![image](assets/img/header.png) + + +

+ + donation + + + + live-preview + +

+ +
+ +## πŸ‘‡ Índice +- [πŸ‘‡ Índice](#-Γ­ndice) +- [✨ CaracterΓ­sticas](#-caracterΓ­sticas) +- [πŸš€ Usos](#-usos) + - [Como pΓ‘gina de inicio](#como-pΓ‘gina-de-inicio) + - [Como una nueva pestaΓ±a](#como-una-nueva-pestaΓ±a) +- [🎨 PersonalizaciΓ³n](#-personalizaciΓ³n) + - [πŸ‘‹ General: Nombre, Imagen De Fondo y Saludos](#-general-nombre-imagen-de-fondo-y-saludos) + - [🏷️ Botones de Enlace****](#️-botones-de-enlace) + - [πŸ“‘ Lista de enlaces](#-lista-de-enlaces) + - [β›ˆοΈ Clima: Clave De La Api, Iconos y Grupos](#️-clima-clave-de-la-api-iconos-y-grupos) + - [πŸ’› Colores](#-colores) + - [πŸŒ‘ Cambio automatico de tema](#-cambio-automatico-de-tema) + + +## ✨ CaracterΓ­sticas + +- **ConfiguraciΓ³n Sencilla** de archivos. +- **Modo Claro/Obscuro** puedes alternarlos y se guardara en tu almacenamiento local. +- **Fecha y Hora**, puedes utilizar el formato de 24 horas (predeterminado) o el de 12 horas. +- **Saludos** fΓ‘ciles de modificar. +- **Variables** para colores y tamaΓ±os de fuente personalizados en el cΓ³digo del archivo `style.css`. +- **Iconos** todos los iconos provienen de [Feather Icons](https://feathericons.com/) (Otros los hice yo mismo, tomando los iconos de Feather Icons como base). +- **Archivos Modulares** de JavaScript para una lectura sencilla. + +## πŸš€ Usos + +#### Como pΓ‘gina de inicio + +1. Haz un Fork de este repositorio +2. Activa el servicio de GitHub Pages `Settings > GitHub Pages > Source [rama master] > Save` +3. ConfigΓΊrala como pΓ‘gina de inicio: + - Haz click en el botΓ³n MenΓΊ, selecciona Opciones, selecciona Preferencias + - Haz click en el panel de inicio. + - Haz click en el menΓΊ al lado de Inicio y Nuevas Ventanas. Elige la opciΓ³n de mostrar URL's personalizadas, despuΓ©s, aΓ±ade el enlace de tu GitHub Pages. + +#### Como una nueva pestaΓ±a + +Puedes utilizar distintos Add-ons/Extensiones para ello + +- Si usas Firefox: [Custom New Tab Page](https://addons.mozilla.org/en-US/firefox/addon/custom-new-tab-page/?src=search) +- Si usas Chromium (Brave, Vivaldi, Chrome): [Custom New Tab URL](https://chrome.google.com/webstore/detail/custom-new-tab-url/mmjbdbjnoablegbkcklggeknkfcjkjia) + +## 🎨 PersonalizaciΓ³n + +Casi todas la personalizaciΓ³n puede ser configurada desde el archivo `config.js`: + +### πŸ‘‹ General: Nombre, Imagen De Fondo y Saludos + +Para cambiar el nombre por defecto, los saludos y si deseas tener una imagen de fondo o abrir los enlaces en una nueva pestaΓ±a, edita las primeras configuraciones en el archivo `config.js`. + +```js + // General + name: 'John', + imageBackground: false, + openInNewTab: true, + + // Saludos + greetingMorning: 'Good morning!', + greetingAfternoon: 'Good afternoon,', + greetingEvening: 'Good evening,', + greetingNight: 'Go to Sleep!', + +``` + +> Puedes cambiar el fondo, sustituyendo el archivo `background.jpg` en la carpeta `assets`. + +![](assets/img/previewbg.png) + +### 🏷️ Botones de Enlace**** + +Para editar los botones solo tienes que cambiar la siguiente lista en el archivo `config.js` eligiendo un enlace, un icono proveniente de [Feather Icons](https://feathericons.com/) y un nombre: + +```js +cards: [ + { + id: '1', + name: 'Github', + icon: 'github', + link: 'https://github.com/', + }, + { + id: '2', + name: 'Mail', + icon: 'mail', + link: 'https://mail.protonmail.com/', + }, + { + id: '3', + name: 'Todoist', + icon: 'trello', + link: 'https://calendar.google.com/calendar/r', + }, + { + id: '4', + name: 'Calendar', + icon: 'calendar', + link: 'https://calendar.google.com/calendar/r', + }, + { + id: '5', + name: 'Reddit', + icon: 'bookmark', + link: 'https://reddit.com', + }, + { + id: '6', + name: 'Odysee', + icon: 'youtube', + link: 'https://odysee.com/', + }, + ], +``` + +### πŸ“‘ Lista de enlaces + +Lo mismo pasa con la lista de enlaces, puedes cambiar la lista de iconos (tambiΓ©n provenientes de [Feather Icons](https://feathericons.com/)) y los enlaces: + +```js + //Iconos + firstListIcon: 'music', + secondListIcon: 'coffee', + + // Enlaces + lists: { + firstList: [ + { + name: 'Inspirational', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Classic', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Oldies', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Rock', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + ], + secondList: [ + { + name: 'Linkedin', + link: 'https://linkedin.com/', + }, + { + name: 'Figma', + link: 'https://figma.com/', + }, + { + name: 'Dribbble', + link: 'https://dribbble.com', + }, + { + name: 'Telegram', + link: 'https://webk.telegram.org', + }, + ], + }, +``` + +### β›ˆοΈ Clima: Clave De La Api, Iconos y Grupos + +Para configurar el widget del clima necesitaras una clave de API proveniente de: `https://openweathermap.org/`. Una vez que hayas obtenido tu clave, necesitaras configurar tu latitud y longitud, para ello puedes usar: `https://www.latlong.net/` para obtenerlas. + +Finalmente, escoge un set de iconos: + +![](assets/img/icons.png) + +- **Nord** Usa el esquema de colores Nord si te encantan los colores agradables a la vista. +- **OneDark** (_Predeterminado_) Usa el esquema de colores One Dark Pro. +- **Dark** Para usuarios que solo usan temas claros y quieren un look minimalista. +- **White** Para usuarios que solo usan temas oscuros y quieren un look minimalista. + +Finalmente, solo aΓ±Γ‘delos al archivo `config.js`. + +```js + // clima + weatherKey: 'InsertYourAPIKeyHere123456', + weatherIcons: 'OneDark', + weatherUnit: 'C', + weatherLatitude: '37.774929', + weatherLongitude: '-122.419418', +``` + +### πŸ’› Colores + +En el archivo `app.css` puedes cambiar las variables para cualquiera de los temas (Oscuro y Claro): + +```css +/* Tema Claro */ + +:root { + --accent: #61b0f1; /* Hover color */ + --bg: #f5f5f5; /* Background color */ + --sbg: #e4e6e6; /* Cards color */ + --fg: #3a3a3a; /* Foreground color */ + --sfg: #3a3a3a; /* Sceondary Foreground color */ +} + +/* Tema Oscuro */ + +.darktheme { + --accent: #61b0f1; /* Hover color */ + --bg: #19171a; /* Background color */ + --sbg: #201e21; /* Cards color */ + --fg: #d8dee9; /* Foreground color */ + --sfg: #3a3a3a; /* Secondary Foreground color */ +} +``` + +### πŸŒ‘ Cambio automatico de tema + +The theme can be automatically changed by the OS' current theme or personalized hours +that you can change in the `config.js` file: + +```js + // Autochange + autoChangeTheme: true, + + // Autochabge by OS + changeThemeByOS: false, + + // Autochange by hour options (24hrs format, string must be in: hh:mm) + changeThemeByHour: true, // If it's true, it will use the values below: + hourDarkThemeActive: '18:30', // Turn on the dark theme after this hour + hourDarkThemeInactive: '07:00', // Turn off the dark theme after this hour and before the above hour +``` + +![](assets/img/subheader.png) diff --git a/docker/nginx/dist/html/README.md b/docker/nginx/dist/html/README.md new file mode 100644 index 00000000..b68014e0 --- /dev/null +++ b/docker/nginx/dist/html/README.md @@ -0,0 +1,252 @@ +![image](assets/img/header.png) + + +

+ + donation + + + + live-preview + + + + live-preview + +

+ +
+ +## πŸ‘‡ Index +- [πŸ‘‡ Index](#-index) +- [✨ Features](#-features) +- [πŸš€ Usage](#-usage) + - [As Home Page](#as-home-page) + - [As New Tab](#as-new-tab) +- [🎨 Customization](#-customization) + - [πŸ‘‹ General: Name, Image Background and Greetings](#-general-name-image-background-and-greetings) + - [🏷️ Button Links](#️-button-links) + - [πŸ“‘ List Links](#-list-links) + - [β›ˆοΈ Weather: Api Key, Icons and Unit](#️-weather-api-key-icons-and-unit) + - [πŸ’› Colors](#-colors) + - [πŸŒ‘ Auto change theme](#-auto-change-theme) + + +## ✨ Features + +- **Easy configuration** file. +- **Dark/Light** mode, you can toggle them and It'll be saved in local storage. +- **Clock and Date** format can be set to 24 hour (default) or 12 hour. +- **Greetings** are easy to modify. +- **Variables** for custom colors and font sizes in the `style.css` code. +- **Icons** all icons are from Feather Icons (Some others I made them with the Feather icons as a base) +- **Modular** javascript files for an easy read. + +## πŸš€ Usage + +#### As Home Page + +1. Fork this repo +2. Enable the Github Pages service `Settings > GitHub Pages > Source [master branch] > Save` +3. Set it as Home Page: + - Click the menu button. and select Options. Preferences. + - Click the Home panel. + - Click the menu next to Homepage and new windows and choose to show custom URLs and add your `Github Pages link` + +#### As New Tab + +You can use different Add-ons/Extensions for it + +- If you use Firefox: [Custom New Tab Page](https://addons.mozilla.org/en-US/firefox/addon/custom-new-tab-page/?src=search) +- If you use Chromium (Brave, Vivaldi, Chrome): [Custom New Tab URL](https://chrome.google.com/webstore/detail/custom-new-tab-url/mmjbdbjnoablegbkcklggeknkfcjkjia) + +## 🎨 Customization + +Almost all customization can be managed in the `config.js` file: + +### πŸ‘‹ General: Name, Image Background and Greetings + +To change the default name, the greetings and if you want to have an image background or open your links in new tabs, edit the first configs in the `config.js`. + +```js + // General + name: 'John', + imageBackground: false, + openInNewTab: true, + + // Greetings + greetingMorning: 'Good morning!', + greetingAfternoon: 'Good afternoon,', + greetingEvening: 'Good evening,', + greetingNight: 'Go to Sleep!', + +``` + +> You cah change the background by substituting the `background.jpg` file in `assets` folder. + +![](assets/img/previewbg.png) + +### 🏷️ Button Links + +To edit the buttons you just need to change the follow list in the `config.js` file by choosing a link, an icon from [Feather icons](https://feathericons.com/) and a name: + +```js +cards: [ + { + id: '1', + name: 'Github', + icon: 'github', + link: 'https://github.com/', + }, + { + id: '2', + name: 'Mail', + icon: 'mail', + link: 'https://mail.protonmail.com/', + }, + { + id: '3', + name: 'Todoist', + icon: 'trello', + link: 'https://calendar.google.com/calendar/r', + }, + { + id: '4', + name: 'Calendar', + icon: 'calendar', + link: 'https://calendar.google.com/calendar/r', + }, + { + id: '5', + name: 'Reddit', + icon: 'bookmark', + link: 'https://reddit.com', + }, + { + id: '6', + name: 'Odysee', + icon: 'youtube', + link: 'https://odysee.com/', + }, + ], +``` + +### πŸ“‘ List Links + +The same happens with the list links, you can change the list icon (also using feather icons) and the links: + +```js + //Icons + firstListIcon: 'music', + secondListIcon: 'coffee', + + // Links + lists: { + firstList: [ + { + name: 'Inspirational', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Classic', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Oldies', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + { + name: 'Rock', + link: 'https://www.youtube.com/watch?v=dQw4w9WgXcQ', + }, + ], + secondList: [ + { + name: 'Linkedin', + link: 'https://linkedin.com/', + }, + { + name: 'Figma', + link: 'https://figma.com/', + }, + { + name: 'Dribbble', + link: 'https://dribbble.com', + }, + { + name: 'Telegram', + link: 'https://webk.telegram.org', + }, + ], + }, +``` + +### β›ˆοΈ Weather: Api Key, Icons and Unit + +For setting up the Weather widget you'll need an API Key from: `https://openweathermap.org/`. Once you have your Key you'll need to set your latitude and longitude, you can use: `https://www.latlong.net/` to get them. + +Finally, choose an Icon set: + +![](assets/img/icons.png) + +- **Nord** Using the Nord Color Scheme and easy-to-eyes colors +- **OneDark** (_Default one_) Using the One Dark Pro color scheme +- **Dark** For White theme only users that want a minimalist look +- **White** For Dark theme only users that want a minimalist look + +Finally just add them to the `config.js` file. + +```js + // Weather + weatherKey: 'InsertYourAPIKeyHere123456', + weatherIcons: 'OneDark', + weatherUnit: 'C', + weatherLatitude: '37.774929', + weatherLongitude: '-122.419418', +``` + +### πŸ’› Colors + +In the `app.css` file you can change the variables for both themes (Dark and Light): + +```css +/* Light theme */ + +:root { + --accent: #61b0f1; /* Hover color */ + --bg: #f5f5f5; /* Background color */ + --sbg: #e4e6e6; /* Cards color */ + --fg: #3a3a3a; /* Foreground color */ + --sfg: #3a3a3a; /* Sceondary Foreground color */ +} + +/* Dark theme */ + +.darktheme { + --accent: #61b0f1; /* Hover color */ + --bg: #19171a; /* Background color */ + --sbg: #201e21; /* Cards color */ + --fg: #d8dee9; /* Foreground color */ + --sfg: #3a3a3a; /* Secondary Foreground color */ +} +``` + +### πŸŒ‘ Auto change theme + +The theme can be automatically changed by the OS' current theme or personalized hours +that you can change in the `config.js` file: + +```js + // Autochange + autoChangeTheme: true, + + // Autochabge by OS + changeThemeByOS: false, + + // Autochange by hour options (24hrs format, string must be in: hh:mm) + changeThemeByHour: true, // If it's true, it will use the values below: + hourDarkThemeActive: '18:30', // Turn on the dark theme after this hour + hourDarkThemeInactive: '07:00', // Turn off the dark theme after this hour and before the above hour +``` + +![](assets/img/subheader.png) \ No newline at end of file diff --git a/docker/nginx/dist/html/app.css b/docker/nginx/dist/html/app.css new file mode 100644 index 00000000..98015e20 --- /dev/null +++ b/docker/nginx/dist/html/app.css @@ -0,0 +1,174 @@ +/* +// β•”β•— ╔═╗╔╗╔╔╦╗╔═╗ +// β• β•©β•—β•‘β•£ β•‘β•‘β•‘ β•‘ β•‘ β•‘ +// β•šβ•β•β•šβ•β•β•β•šβ• β•© β•šβ•β• +*/ + +@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;700&display=swap'); + +/* V A R I A B L E S */ + +:root { + /* Fonts */ + --fsg: 12vh; /* Time and Greetings */ + --fsm: 8vh; /* Date */ + --fss: 3vh; /* Greetings and Weather widger */ + --fses: 2vh; /* Links List */ + + --iconsize: 3vh; + + /* Dark theme */ + --accent: #E20074; /* Hover color */ + --bg: #19171a; /* Background color */ + --sbg: #201e21a4; /* Cards color */ + --fg: #d8dee9; /* Foreground color */ + --sfg: #ffffff; /* Secondary Foreground color */ + + /* Image background */ + --imgbg: url(assets/background.jpg); + --imgcol: linear-gradient( + rgba(0, 0, 0, 0.1), + rgba(0, 0, 0, 0.1) + ); /* Filter color */ +} + + +/* S T Y L E S */ + +* { + margin: 0; + padding: 0; + box-sizing: border-box; + font-family: 'Open Sans', sans-serif; + transition: 0.2s ease-in-out; +} + +.notransition { + -webkit-transition: none; + -moz-transition: none; + -o-transition: none; + transition: none; +} + +.withImageBackground { + background-image: var(--imgcol), var(--imgbg); + background-size: cover; +} + +body { + width: 100vw; + height: 100vh; + background-color: var(--bg); + display: flex; + align-items: center; + justify-content: center; +} + +.container { + width: 145vh; + height: 85vh; + display: grid; + grid-template-columns: repeat(4, 1fr); + grid-template-rows: repeat(4, 1fr); + grid-gap: 30px; + padding: 20px; +} + +.card { + background-color: var(--sbg); + box-shadow: 0 5px 7px rgba(0, 0, 0, 0.4); + border-radius: 5px; +} + +.card:hover { + transform: translateY(-0.5rem); + box-shadow: 0 10px 10px rgba(226, 0, 116, 0.4); +} + +.timeBlock { + grid-row: 1 / span 2; + grid-column: 1 / span 2; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; +} + +.clock { + display: flex; + align-items: center; + justify-content: center; +} + +#hour, +#separator, +#minutes { + font-size: var(--fsg); + font-weight: bolder; + color: var(--fg); +} + +#greetings { + font-size: var(--fss); + color: var(--fg); +} + +.list { + display: flex; + align-items: center; + flex-direction: column; +} + +.list__1 { + grid-column: 1; + grid-row: 3 / span 2; +} +.list__2 { + grid-column: 2; + grid-row: 3 / span 2; +} +.list__head { + margin-top: 3vh; + margin-bottom: 2vh; + color: var(--fg); + width: var(--iconsize); + height: var(--iconsize); +} +.list__link { + text-decoration: none; + font-size: var(--fses); + color: var(--fg); + margin-top: 1vh; + padding: 8px 12px; + border-radius: 5px; + font-weight: bolder; + text-align: center; + width: 80%; +} +.list__link:hover { + background-color: var(--accent); + color: var(--sfg); +} + +/* M E D I A - Q U E R I E S */ + +@media only screen and (max-width: 68.75em) { + .container { + grid-gap: 20px; + padding: 40px; + } + + .timeBlock { + grid-row: 1 / span 2; + grid-column: 1 / span 4; + } + + #greetings { + font-size: var(--fss); + } + + .list { + display: none; + } + +} diff --git a/docker/nginx/dist/html/assets/.DS_Store b/docker/nginx/dist/html/assets/.DS_Store new file mode 100644 index 00000000..26858459 Binary files /dev/null and b/docker/nginx/dist/html/assets/.DS_Store differ diff --git a/docker/nginx/dist/html/assets/background.jpg b/docker/nginx/dist/html/assets/background.jpg new file mode 100644 index 00000000..a0be4e9b Binary files /dev/null and b/docker/nginx/dist/html/assets/background.jpg differ diff --git a/docker/nginx/dist/html/assets/icons/.DS_Store b/docker/nginx/dist/html/assets/icons/.DS_Store new file mode 100644 index 00000000..42c5e8de Binary files /dev/null and b/docker/nginx/dist/html/assets/icons/.DS_Store differ diff --git a/docker/heimdall/dist/app/tsec.png b/docker/nginx/dist/html/assets/icons/favicon.png similarity index 100% rename from docker/heimdall/dist/app/tsec.png rename to docker/nginx/dist/html/assets/icons/favicon.png diff --git a/docker/nginx/dist/html/assets/img/donation.png b/docker/nginx/dist/html/assets/img/donation.png new file mode 100644 index 00000000..43701588 Binary files /dev/null and b/docker/nginx/dist/html/assets/img/donation.png differ diff --git a/docker/nginx/dist/html/assets/img/header.png b/docker/nginx/dist/html/assets/img/header.png new file mode 100644 index 00000000..a526f83e Binary files /dev/null and b/docker/nginx/dist/html/assets/img/header.png differ diff --git a/docker/nginx/dist/html/assets/img/icons.png b/docker/nginx/dist/html/assets/img/icons.png new file mode 100644 index 00000000..6432f35f Binary files /dev/null and b/docker/nginx/dist/html/assets/img/icons.png differ diff --git a/docker/nginx/dist/html/assets/img/live.png b/docker/nginx/dist/html/assets/img/live.png new file mode 100644 index 00000000..2686929a Binary files /dev/null and b/docker/nginx/dist/html/assets/img/live.png differ diff --git a/docker/nginx/dist/html/assets/img/previewbg.png b/docker/nginx/dist/html/assets/img/previewbg.png new file mode 100644 index 00000000..465d616a Binary files /dev/null and b/docker/nginx/dist/html/assets/img/previewbg.png differ diff --git a/docker/nginx/dist/html/assets/img/spanish.png b/docker/nginx/dist/html/assets/img/spanish.png new file mode 100644 index 00000000..42c90c39 Binary files /dev/null and b/docker/nginx/dist/html/assets/img/spanish.png differ diff --git a/docker/nginx/dist/html/assets/img/subheader.png b/docker/nginx/dist/html/assets/img/subheader.png new file mode 100644 index 00000000..1148be3d Binary files /dev/null and b/docker/nginx/dist/html/assets/img/subheader.png differ diff --git a/docker/nginx/dist/html/assets/js/greeting.js b/docker/nginx/dist/html/assets/js/greeting.js new file mode 100644 index 00000000..8793d391 --- /dev/null +++ b/docker/nginx/dist/html/assets/js/greeting.js @@ -0,0 +1,27 @@ +// β”Œβ”€β”β”¬β”€β”β”Œβ”€β”β”Œβ”€β”β”Œβ”¬β”β”¬β”Œβ”β”Œβ”Œβ”€β”β”Œβ”€β” +// β”‚ β”¬β”œβ”¬β”˜β”œβ”€ β”œβ”€ β”‚ β”‚β”‚β”‚β”‚β”‚ ┬└─┐ +// β””β”€β”˜β”΄β””β”€β””β”€β”˜β””β”€β”˜ β”΄ β”΄β”˜β””β”˜β””β”€β”˜β””β”€β”˜ + +// Get the hour +const today = new Date(); +const hour = today.getHours(); + +// Here you can change your name +const name = CONFIG.name; + +// Here you can change your greetings +const gree1 = `${CONFIG.greetingNight}\xa0`; +const gree2 = `${CONFIG.greetingMorning}\xa0`; +const gree3 = `${CONFIG.greetingAfternoon}\xa0`; +const gree4 = `${CONFIG.greetingEvening}\xa0`; + +// Define the hours of the greetings +if (hour >= 23 || hour < 5) { + document.getElementById('greetings').innerText = gree1; +} else if (hour >= 6 && hour < 12) { + document.getElementById('greetings').innerText = gree2; +} else if (hour >= 12 && hour < 17) { + document.getElementById('greetings').innerText = gree3; +} else { + document.getElementById('greetings').innerText = gree4; +} diff --git a/docker/nginx/dist/html/assets/js/lists.js b/docker/nginx/dist/html/assets/js/lists.js new file mode 100644 index 00000000..ab2ee020 --- /dev/null +++ b/docker/nginx/dist/html/assets/js/lists.js @@ -0,0 +1,46 @@ +// ┬ β”¬β”Œβ”€β”β”Œβ”¬β”β”Œβ”€β” +// β”‚ │└─┐ β”‚ └─┐ +// β”΄β”€β”˜β”΄β””β”€β”˜ β”΄ β””β”€β”˜ + +// Print the first List +const printFirstList = () => { + let icon = ``; + const position = 'beforeend'; + list_1.insertAdjacentHTML(position, icon); + for (const link of CONFIG.lists.firstList) { + // List item + let item = ` + ${link.name} + `; + const position = 'beforeend'; + list_1.insertAdjacentHTML(position, item); + } +}; + +// Print the second List +const printSecondList = () => { + let icon = ``; + const position = 'beforeend'; + list_2.insertAdjacentHTML(position, icon); + for (const link of CONFIG.lists.secondList) { + // List item + let item = ` + ${link.name} + `; + const position = 'beforeend'; + list_2.insertAdjacentHTML(position, item); + } +}; + +printFirstList(); +printSecondList(); diff --git a/docker/nginx/dist/html/assets/js/theme.js b/docker/nginx/dist/html/assets/js/theme.js new file mode 100644 index 00000000..d8d9c936 --- /dev/null +++ b/docker/nginx/dist/html/assets/js/theme.js @@ -0,0 +1,7 @@ +// β”Œβ”¬β”β”¬ β”¬β”Œβ”€β”β”Œβ”¬β”β”Œβ”€β” +// β”‚ β”œβ”€β”€β”œβ”€ β”‚β”‚β”‚β”œβ”€ +// β”΄ β”΄ β”΄β””β”€β”˜β”΄ β”΄β””β”€β”˜ + +if (CONFIG.imageBackground) { + document.body.classList.add('withImageBackground'); +} \ No newline at end of file diff --git a/docker/nginx/dist/html/assets/js/time.js b/docker/nginx/dist/html/assets/js/time.js new file mode 100644 index 00000000..71f3c21f --- /dev/null +++ b/docker/nginx/dist/html/assets/js/time.js @@ -0,0 +1,36 @@ +// β”Œβ”¬β”β”¬β”Œβ”¬β”β”Œβ”€β” +// β”‚ β”‚β”‚β”‚β”‚β”œβ”€ +// β”΄ β”΄β”΄ β”΄β””β”€β”˜ + +window.onload = displayClock(); +// Clock function +function displayClock() { + const monthNames = [ + 'Jan', + 'Feb', + 'Mar', + 'Apr', + 'May', + 'Jun', + 'Jul', + 'Aug', + 'Sep', + 'Oct', + 'Nov', + 'Dec', + ]; + + // Get clock elements + var d = new Date(); + var mm = monthNames[d.getMonth()]; + var dd = d.getDate(); + var min = (mins = ('0' + d.getMinutes()).slice(-2)); + var hh = d.getHours(); + var ampm = ''; + + // Display clock elements + document.getElementById('hour').innerText = hh; + document.getElementById('separator').innerHTML = ' : '; + document.getElementById('minutes').innerText = min + ampm; + setTimeout(displayClock, 1000); +} diff --git a/docker/heimdall/dist/html/cockpit.html b/docker/nginx/dist/html/cockpit.html similarity index 100% rename from docker/heimdall/dist/html/cockpit.html rename to docker/nginx/dist/html/cockpit.html diff --git a/docker/nginx/dist/html/config.js b/docker/nginx/dist/html/config.js new file mode 100644 index 00000000..6e61cc72 --- /dev/null +++ b/docker/nginx/dist/html/config.js @@ -0,0 +1,71 @@ +// β•”β•— ╔═╗╔╗╔╔╦╗╔═╗ +// β• β•©β•—β•‘β•£ β•‘β•‘β•‘ β•‘ β•‘ β•‘ +// β•šβ•β•β•šβ•β•β•β•šβ• β•© β•šβ•β• +// β”Œβ”€β”β”Œβ”€β”β”Œβ”β”Œβ”Œβ”€β”β”¬β”Œβ”€β”β”¬ β”¬β”¬β”€β”β”Œβ”€β”β”Œβ”¬β”β”¬β”Œβ”€β”β”Œβ”β”Œ +// β”‚ β”‚ β”‚β”‚β”‚β”‚β”œβ”€ β”‚β”‚ ┬│ β”‚β”œβ”¬β”˜β”œβ”€β”€ β”‚ β”‚β”‚ β”‚β”‚β”‚β”‚ +// β””β”€β”˜β””β”€β”˜β”˜β””β”˜β”” β”΄β””β”€β”˜β””β”€β”˜β”΄β””β”€β”΄ β”΄ β”΄ β”΄β””β”€β”˜β”˜β””β”˜ + +const CONFIG = { + // β”Œβ” β”Œβ”€β”β”Œβ”€β”β”¬β”Œβ”€β”β”Œβ”€β” + // β”œβ”΄β”β”œβ”€β”€β””β”€β”β”‚β”‚ └─┐ + // β””β”€β”˜β”΄ β”΄β””β”€β”˜β”΄β””β”€β”˜β””β”€β”˜ + + // General + imageBackground: true, + openInNewTab: true, + twelveHourFormat: false, + + // Greetings + greetingMorning: 'Good morning β˜•', + greetingAfternoon: 'Good afternoon 🍯', + greetingEvening: 'Good evening 😁', + greetingNight: 'Go to Sleep πŸ₯±', + + // ┬ β”¬β”Œβ”€β”β”Œβ”¬β”β”Œβ”€β” + // β”‚ │└─┐ β”‚ └─┐ + // β”΄β”€β”˜β”΄β””β”€β”˜ β”΄ β””β”€β”˜ + + //Icons + firstListIcon: 'home', + secondListIcon: 'external-link', + + // Links + lists: { + firstList: [ + { + name: 'Cockpit', + link: '/cockpit.html', + }, + { + name: 'Cyberchef', + link: '/cyberchef/', + }, + { + name: 'Elasticvue', + link: '/elasticvue/', + }, + { + name: 'Kibana', + link: '/kibana/', + }, + { + name: 'Spiderfoot', + link: '/spiderfoot/', + }, + ], + secondList: [ + { + name: 'SecurityMeter', + link: 'https://sicherheitstacho.eu', + }, + { + name: 'T-Pot @ GitHub', + link: 'https://github.com/dtag-dev-sec/tpotce/', + }, + { + name: 'T-Pot ReadMe', + link: 'https://github.com/telekom-security/tpotce/blob/master/README.md', + }, + ], + }, +}; diff --git a/docker/heimdall/dist/html/error.html b/docker/nginx/dist/html/error.html similarity index 100% rename from docker/heimdall/dist/html/error.html rename to docker/nginx/dist/html/error.html diff --git a/docker/heimdall/dist/esvue.tgz b/docker/nginx/dist/html/esvue/esvue.tgz similarity index 100% rename from docker/heimdall/dist/esvue.tgz rename to docker/nginx/dist/html/esvue/esvue.tgz diff --git a/docker/heimdall/dist/html/favicon.ico b/docker/nginx/dist/html/favicon.ico similarity index 100% rename from docker/heimdall/dist/html/favicon.ico rename to docker/nginx/dist/html/favicon.ico diff --git a/docker/nginx/dist/html/index.html b/docker/nginx/dist/html/index.html new file mode 100644 index 00000000..00eb6881 --- /dev/null +++ b/docker/nginx/dist/html/index.html @@ -0,0 +1,61 @@ + + + + + T-Pot + + + + + + + + +
+ + +
+
+
+
+
+
+
+
+ + + +
+ +
+
+ + + + + + + + + + + + + + + + diff --git a/docker/nginx/dist/html/package.json b/docker/nginx/dist/html/package.json new file mode 100644 index 00000000..868e8c82 --- /dev/null +++ b/docker/nginx/dist/html/package.json @@ -0,0 +1,7 @@ +{ + "name": "bento", + "version": "1.2.0", + "description": "🍱 Minimalist, elegant and hackable startpage inspired by the Bento box!", + "author": "Miguel Ávila", + "license": "ISC" +} \ No newline at end of file diff --git a/docker/heimdall/docker-compose.yml b/docker/nginx/docker-compose.yml similarity index 97% rename from docker/heimdall/docker-compose.yml rename to docker/nginx/docker-compose.yml index d965df47..27db5a2c 100644 --- a/docker/heimdall/docker-compose.yml +++ b/docker/nginx/docker-compose.yml @@ -27,7 +27,7 @@ services: - "64297:64297" - "127.0.0.1:64304:64304" image: "dtagdevsec/nginx:2203" - # read_only: true + #read_only: true volumes: - /data/nginx/cert/:/etc/nginx/cert/:ro - /data/nginx/conf/nginxpasswd:/etc/nginx/nginxpasswd:ro diff --git a/etc/compose/hive_sensor.yml b/etc/compose/hive_sensor.yml new file mode 100644 index 00000000..63553562 --- /dev/null +++ b/etc/compose/hive_sensor.yml @@ -0,0 +1,514 @@ +# T-Pot (Hive-Sensor) +# Do not erase ports sections, these are used by /opt/tpot/bin/rules.sh to setup iptables ACCEPT rules for NFQ (honeytrap / glutton) +version: '2.3' + +networks: + adbhoney_local: + citrixhoneypot_local: + conpot_local_IEC104: + conpot_local_guardian_ast: + conpot_local_ipmi: + conpot_local_kamstrup_382: + cowrie_local: + cyberchef_local: + dicompot_local: + dionaea_local: + elasticpot_local: + heralding_local: + honeysap_local: + logstash_local: + mailoney_local: + medpot_local: + rdpy_local: + tanner_local: + ewsposter_local: + +services: + +################## +#### Honeypots +################## + +# Adbhoney service + adbhoney: + container_name: adbhoney + restart: always + networks: + - adbhoney_local + ports: + - "5555:5555" + image: "dtagdevsec/adbhoney:2203" + read_only: true + volumes: + - /data/adbhoney/log:/opt/adbhoney/log + - /data/adbhoney/downloads:/opt/adbhoney/dl + +# Ciscoasa service + ciscoasa: + container_name: ciscoasa + restart: always + tmpfs: + - /tmp/ciscoasa:uid=2000,gid=2000 + network_mode: "host" + ports: + - "5000:5000/udp" + - "8443:8443" + image: "dtagdevsec/ciscoasa:2203" + read_only: true + volumes: + - /data/ciscoasa/log:/var/log/ciscoasa + +# CitrixHoneypot service + citrixhoneypot: + container_name: citrixhoneypot + restart: always + networks: + - citrixhoneypot_local + ports: + - "443:443" + image: "dtagdevsec/citrixhoneypot:2203" + read_only: true + volumes: + - /data/citrixhoneypot/logs:/opt/citrixhoneypot/logs + +# Conpot IEC104 service + conpot_IEC104: + container_name: conpot_iec104 + restart: always + environment: + - CONPOT_CONFIG=/etc/conpot/conpot.cfg + - CONPOT_JSON_LOG=/var/log/conpot/conpot_IEC104.json + - CONPOT_LOG=/var/log/conpot/conpot_IEC104.log + - CONPOT_TEMPLATE=IEC104 + - CONPOT_TMP=/tmp/conpot + tmpfs: + - /tmp/conpot:uid=2000,gid=2000 + networks: + - conpot_local_IEC104 + ports: + - "161:161/udp" + - "2404:2404" + image: "dtagdevsec/conpot:2203" + read_only: true + volumes: + - /data/conpot/log:/var/log/conpot + +# Conpot guardian_ast service + conpot_guardian_ast: + container_name: conpot_guardian_ast + restart: always + environment: + - CONPOT_CONFIG=/etc/conpot/conpot.cfg + - CONPOT_JSON_LOG=/var/log/conpot/conpot_guardian_ast.json + - CONPOT_LOG=/var/log/conpot/conpot_guardian_ast.log + - CONPOT_TEMPLATE=guardian_ast + - CONPOT_TMP=/tmp/conpot + tmpfs: + - /tmp/conpot:uid=2000,gid=2000 + networks: + - conpot_local_guardian_ast + ports: + - "10001:10001" + image: "dtagdevsec/conpot:2203" + read_only: true + volumes: + - /data/conpot/log:/var/log/conpot + +# Conpot ipmi + conpot_ipmi: + container_name: conpot_ipmi + restart: always + environment: + - CONPOT_CONFIG=/etc/conpot/conpot.cfg + - CONPOT_JSON_LOG=/var/log/conpot/conpot_ipmi.json + - CONPOT_LOG=/var/log/conpot/conpot_ipmi.log + - CONPOT_TEMPLATE=ipmi + - CONPOT_TMP=/tmp/conpot + tmpfs: + - /tmp/conpot:uid=2000,gid=2000 + networks: + - conpot_local_ipmi + ports: + - "623:623/udp" + image: "dtagdevsec/conpot:2203" + read_only: true + volumes: + - /data/conpot/log:/var/log/conpot + +# Conpot kamstrup_382 + conpot_kamstrup_382: + container_name: conpot_kamstrup_382 + restart: always + environment: + - CONPOT_CONFIG=/etc/conpot/conpot.cfg + - CONPOT_JSON_LOG=/var/log/conpot/conpot_kamstrup_382.json + - CONPOT_LOG=/var/log/conpot/conpot_kamstrup_382.log + - CONPOT_TEMPLATE=kamstrup_382 + - CONPOT_TMP=/tmp/conpot + tmpfs: + - /tmp/conpot:uid=2000,gid=2000 + networks: + - conpot_local_kamstrup_382 + ports: + - "1025:1025" + - "50100:50100" + image: "dtagdevsec/conpot:2203" + read_only: true + volumes: + - /data/conpot/log:/var/log/conpot + +# Cowrie service + cowrie: + container_name: cowrie + restart: always + tmpfs: + - /tmp/cowrie:uid=2000,gid=2000 + - /tmp/cowrie/data:uid=2000,gid=2000 + networks: + - cowrie_local + ports: + - "22:22" + - "23:23" + image: "dtagdevsec/cowrie:2203" + read_only: true + volumes: + - /data/cowrie/downloads:/home/cowrie/cowrie/dl + - /data/cowrie/keys:/home/cowrie/cowrie/etc + - /data/cowrie/log:/home/cowrie/cowrie/log + - /data/cowrie/log/tty:/home/cowrie/cowrie/log/tty + +# Dicompot service +# Get the Horos Client for testing: https://horosproject.org/ +# Get Dicom images (CC BY 3.0): https://www.cancerimagingarchive.net/collections/ +# Put images (which must be in Dicom DCM format or it will not work!) into /data/dicompot/images + dicompot: + container_name: dicompot + restart: always + networks: + - dicompot_local + ports: + - "11112:11112" + image: "dtagdevsec/dicompot:2203" + read_only: true + volumes: + - /data/dicompot/log:/var/log/dicompot +# - /data/dicompot/images:/opt/dicompot/images + +# Dionaea service + dionaea: + container_name: dionaea + stdin_open: true + tty: true + restart: always + networks: + - dionaea_local + ports: + - "20:20" + - "21:21" + - "42:42" + - "69:69/udp" + - "81:81" + - "135:135" + # - "443:443" + - "445:445" + - "1433:1433" + - "1723:1723" + - "1883:1883" + - "3306:3306" + - "5060:5060" + - "5060:5060/udp" + - "5061:5061" + - "27017:27017" + image: "dtagdevsec/dionaea:2203" + read_only: true + volumes: + - /data/dionaea/roots/ftp:/opt/dionaea/var/dionaea/roots/ftp + - /data/dionaea/roots/tftp:/opt/dionaea/var/dionaea/roots/tftp + - /data/dionaea/roots/www:/opt/dionaea/var/dionaea/roots/www + - /data/dionaea/roots/upnp:/opt/dionaea/var/dionaea/roots/upnp + - /data/dionaea:/opt/dionaea/var/dionaea + - /data/dionaea/binaries:/opt/dionaea/var/dionaea/binaries + - /data/dionaea/log:/opt/dionaea/var/log + - /data/dionaea/rtp:/opt/dionaea/var/dionaea/rtp + +# ElasticPot service + elasticpot: + container_name: elasticpot + restart: always + networks: + - elasticpot_local + ports: + - "9200:9200" + image: "dtagdevsec/elasticpot:2203" + read_only: true + volumes: + - /data/elasticpot/log:/opt/elasticpot/log + +# Heralding service + heralding: + container_name: heralding + restart: always + tmpfs: + - /tmp/heralding:uid=2000,gid=2000 + networks: + - heralding_local + ports: + # - "21:21" + # - "22:22" + # - "23:23" + # - "25:25" + # - "80:80" + - "110:110" + - "143:143" + # - "443:443" + - "465:465" + - "993:993" + - "995:995" + # - "3306:3306" + # - "3389:3389" + - "1080:1080" + - "5432:5432" + - "5900:5900" + image: "dtagdevsec/heralding:2203" + read_only: true + volumes: + - /data/heralding/log:/var/log/heralding + +# HoneySAP service + honeysap: + container_name: honeysap + restart: always + networks: + - honeysap_local + ports: + - "3299:3299" + image: "dtagdevsec/honeysap:2203" + volumes: + - /data/honeysap/log:/opt/honeysap/log + +# Honeytrap service + honeytrap: + container_name: honeytrap + restart: always + tmpfs: + - /tmp/honeytrap:uid=2000,gid=2000 + network_mode: "host" + cap_add: + - NET_ADMIN + image: "dtagdevsec/honeytrap:2203" + read_only: true + volumes: + - /data/honeytrap/attacks:/opt/honeytrap/var/attacks + - /data/honeytrap/downloads:/opt/honeytrap/var/downloads + - /data/honeytrap/log:/opt/honeytrap/var/log + +# Mailoney service + mailoney: + container_name: mailoney + restart: always + environment: + - HPFEEDS_SERVER= + - HPFEEDS_IDENT=user + - HPFEEDS_SECRET=pass + - HPFEEDS_PORT=20000 + - HPFEEDS_CHANNELPREFIX=prefix + networks: + - mailoney_local + ports: + - "25:25" + image: "dtagdevsec/mailoney:2203" + read_only: true + volumes: + - /data/mailoney/log:/opt/mailoney/logs + +# Medpot service + medpot: + container_name: medpot + restart: always + networks: + - medpot_local + ports: + - "2575:2575" + image: "dtagdevsec/medpot:2203" + read_only: true + volumes: + - /data/medpot/log/:/var/log/medpot + +# Rdpy service + rdpy: + container_name: rdpy + extra_hosts: + - hpfeeds.example.com:127.0.0.1 + restart: always + environment: + - HPFEEDS_SERVER=hpfeeds.example.com + - HPFEEDS_IDENT=user + - HPFEEDS_SECRET=pass + - HPFEEDS_PORT=65000 + - SERVERID=id + networks: + - rdpy_local + ports: + - "3389:3389" + image: "dtagdevsec/rdpy:2203" + read_only: true + volumes: + - /data/rdpy/log:/var/log/rdpy + +#### Snare / Tanner +## Tanner Redis Service + tanner_redis: + container_name: tanner_redis + restart: always + tty: true + networks: + - tanner_local + image: "dtagdevsec/redis:2203" + read_only: true + +## PHP Sandbox service + tanner_phpox: + container_name: tanner_phpox + restart: always + tty: true + networks: + - tanner_local + image: "dtagdevsec/phpox:2203" + read_only: true + +## Tanner API Service + tanner_api: + container_name: tanner_api + restart: always + tmpfs: + - /tmp/tanner:uid=2000,gid=2000 + tty: true + networks: + - tanner_local + image: "dtagdevsec/tanner:2203" + read_only: true + volumes: + - /data/tanner/log:/var/log/tanner + command: tannerapi + depends_on: + - tanner_redis + +## Tanner Service + tanner: + container_name: tanner + restart: always + tmpfs: + - /tmp/tanner:uid=2000,gid=2000 + tty: true + networks: + - tanner_local + image: "dtagdevsec/tanner:2203" + command: tanner + read_only: true + volumes: + - /data/tanner/log:/var/log/tanner + - /data/tanner/files:/opt/tanner/files + depends_on: + - tanner_api + - tanner_phpox + +## Snare Service + snare: + container_name: snare + restart: always + tty: true + networks: + - tanner_local + ports: + - "80:80" + image: "dtagdevsec/snare:2203" + depends_on: + - tanner + + +################## +#### NSM +################## + +# Fatt service + fatt: + container_name: fatt + restart: always + network_mode: "host" + cap_add: + - NET_ADMIN + - SYS_NICE + - NET_RAW + image: "dtagdevsec/fatt:2203" + volumes: + - /data/fatt/log:/opt/fatt/log + +# P0f service + p0f: + container_name: p0f + restart: always + network_mode: "host" + image: "dtagdevsec/p0f:2203" + read_only: true + volumes: + - /data/p0f/log:/var/log/p0f + +# Suricata service + suricata: + container_name: suricata + restart: always + environment: + # For ET Pro ruleset replace "OPEN" with your OINKCODE + - OINKCODE=OPEN + # Loading externel Rules from URL + # - FROMURL="https://username:password@yoururl.com|https://username:password@otherurl.com" + network_mode: "host" + cap_add: + - NET_ADMIN + - SYS_NICE + - NET_RAW + image: "dtagdevsec/suricata:2203" + volumes: + - /data/suricata/log:/var/log/suricata + + +################## +#### Tools +################## + +# Logstash service + logstash: + container_name: logstash + restart: always + networks: + - logstash_local +# environment: +# - LS_JAVA_OPTS=-Xms2048m -Xmx2048m + env_file: + - /opt/tpot/etc/compose/elk_environment + mem_limit: 2g + image: "dtagdevsec/logstash:2203" + volumes: + - /data:/data + +# Ewsposter service + ewsposter: + container_name: ewsposter + restart: always + networks: + - ewsposter_local + environment: + - EWS_HPFEEDS_ENABLE=false + - EWS_HPFEEDS_HOST=host + - EWS_HPFEEDS_PORT=port + - EWS_HPFEEDS_CHANNELS=channels + - EWS_HPFEEDS_IDENT=user + - EWS_HPFEEDS_SECRET=secret + - EWS_HPFEEDS_TLSCERT=false + - EWS_HPFEEDS_FORMAT=json + env_file: + - /opt/tpot/etc/compose/elk_environment + image: "dtagdevsec/ewsposter:2203" + volumes: + - /data:/data + - /data/ews/conf/ews.ip:/opt/ewsposter/ews.ip diff --git a/etc/compose/sensor.yml b/etc/compose/sensor.yml index e5381300..fda5cdbd 100644 --- a/etc/compose/sensor.yml +++ b/etc/compose/sensor.yml @@ -475,21 +475,6 @@ services: #### Tools ################## -# Logstash service - logstash: - container_name: logstash - restart: always - networks: - - logstash_local -# environment: -# - LS_JAVA_OPTS=-Xms2048m -Xmx2048m - env_file: - - /opt/tpot/etc/compose/elk_environment - mem_limit: 2g - image: "dtagdevsec/logstash:2203" - volumes: - - /data:/data - # Ewsposter service ewsposter: container_name: ewsposter