mirror of
https://github.com/hoellen/dockerfiles.git
synced 2025-04-20 04:19:18 +00:00
UNMAINTENED
This commit is contained in:
parent
88ac35c10b
commit
62d689c54b
@ -1,77 +0,0 @@
|
||||
FROM alpine:edge
|
||||
|
||||
ARG MPFR_VERSION=3.1.5
|
||||
ARG MPC_VERSION=1.0.3
|
||||
|
||||
ARG GPG_MPFR="07F3 DBBE CC1A 3960 5078 094D 980C 1976 98C3 739D"
|
||||
ARG GPG_MPC="AD17 A21E F8AE D8F1 CC02 DBD9 F7D5 C9BF 765C 61E3"
|
||||
ARG SHA1_MPC="b8be66396c726fdc36ebb0f692ed8a8cca3bcc66"
|
||||
|
||||
ENV UID=991 GID=991
|
||||
|
||||
RUN BUILD_DEPS=" \
|
||||
build-base \
|
||||
libtool \
|
||||
libffi-dev \
|
||||
libressl-dev \
|
||||
python-dev \
|
||||
gmp-dev \
|
||||
mariadb-dev \
|
||||
py2-pip \
|
||||
tar \
|
||||
gnupg" \
|
||||
&& apk -U upgrade && apk add \
|
||||
${BUILD_DEPS} \
|
||||
libffi \
|
||||
gmp \
|
||||
libressl \
|
||||
python \
|
||||
py-setuptools \
|
||||
openssh-client \
|
||||
mariadb-client-libs \
|
||||
tini \
|
||||
su-exec \
|
||||
&& cd /tmp && wget -q http://www.mpfr.org/mpfr-current/mpfr-${MPFR_VERSION}.tar.gz \
|
||||
&& echo "Verifying authenticity of mpfr-${MPFR_VERSION}.tar.gz..." \
|
||||
&& wget -q http://www.mpfr.org/mpfr-current/mpfr-${MPFR_VERSION}.tar.gz.asc \
|
||||
&& gpg --recv-keys 98C3739D \
|
||||
&& FINGERPRINT="$(LANG=C gpg --verify mpfr-${MPFR_VERSION}.tar.gz.asc mpfr-${MPFR_VERSION}.tar.gz 2>&1 \
|
||||
| sed -n "s#Primary key fingerprint: \(.*\)#\1#p")" \
|
||||
&& if [ -z "${FINGERPRINT}" ]; then echo "Warning! Invalid GPG signature!" && exit 1; fi \
|
||||
&& if [ "${FINGERPRINT}" != "${GPG_MPFR}" ]; then echo "Warning! Wrong GPG fingerprint!" && exit 1; fi \
|
||||
&& echo "All seems good, now unpacking mpfr-${MPFR_VERSION}.tar.gz..." \
|
||||
&& tar xzf mpfr-${MPFR_VERSION}.tar.gz && cd mpfr-${MPFR_VERSION} \
|
||||
&& ./configure && make && make install \
|
||||
&& cd /tmp && wget -q ftp://ftp.gnu.org/gnu/mpc/mpc-${MPC_VERSION}.tar.gz \
|
||||
&& echo "Verifying both integrity and authenticity of mpc-${MPC_VERSION}.tar.gz..." \
|
||||
&& CHECKSUM=$(sha1sum mpc-${MPC_VERSION}.tar.gz | awk '{print $1}') \
|
||||
&& if [ "${CHECKSUM}" != "${SHA1_MPC}" ]; then echo "Warning! Checksum does not match!" && exit 1; fi \
|
||||
&& wget -q ftp://ftp.gnu.org/gnu/mpc/mpc-${MPC_VERSION}.tar.gz.sig \
|
||||
&& gpg --recv-keys 0xF7D5C9BF765C61E3 \
|
||||
&& FINGERPRINT="$(LANG=C gpg --verify mpc-${MPC_VERSION}.tar.gz.sig mpc-${MPC_VERSION}.tar.gz 2>&1 \
|
||||
| sed -n "s#Primary key fingerprint: \(.*\)#\1#p")" \
|
||||
&& if [ -z "${FINGERPRINT}" ]; then echo "Warning! Invalid GPG signature!" && exit 1; fi \
|
||||
&& if [ "${FINGERPRINT}" != "${GPG_MPC}" ]; then echo "Warning! Wrong GPG fingerprint!" && exit 1; fi \
|
||||
&& echo "All seems good, now unpacking mpc-${MPC_VERSION}.tar.gz..." \
|
||||
&& tar xzf mpc-${MPC_VERSION}.tar.gz && cd mpc-${MPC_VERSION} \
|
||||
&& ./configure --with-mpfr-lib=/usr/local/lib --with-mpfr-include=/usr/local/include \
|
||||
&& make && make install \
|
||||
&& mkdir /cowrie && cd /cowrie \
|
||||
&& wget -qO- https://github.com/micheloosterhof/cowrie/archive/master.tar.gz | tar xz --strip 1 \
|
||||
&& pip install --no-cache -r requirements.txt \
|
||||
&& pip install --no-cache mysql-python \
|
||||
&& mv cowrie.cfg.dist cowrie.cfg \
|
||||
&& apk del ${BUILD_DEPS} \
|
||||
&& rm -rf /var/cache/apk/* /tmp/* /root/.gnupg
|
||||
|
||||
COPY run.sh /usr/local/bin/run.sh
|
||||
|
||||
RUN chmod +x /usr/local/bin/run.sh
|
||||
|
||||
VOLUME /cowrie/log /cowrie/dl /custom
|
||||
|
||||
EXPOSE 2222
|
||||
|
||||
LABEL maintainer="Wonderfall <wonderfall@targaryen.house>"
|
||||
|
||||
CMD ["run.sh"]
|
@ -1,60 +0,0 @@
|
||||
### wonderfall/cowrie
|
||||
|
||||
#### What is this?
|
||||
Cowrie is a medium interaction SSH honeypot designed to log brute force attacks and the shell interaction performed by the attacker. Cowrie is based on Kippo.
|
||||
|
||||
#### Build-time variables
|
||||
- **MPFR_VERSION** : GNU MPFR version.
|
||||
- **MPC_VERSION** : GNU MPC version.
|
||||
- **GPG_** : fingerprints of signing keys.
|
||||
- **SHA_** : fingerprints of tarballs
|
||||
|
||||
#### Environment variables
|
||||
- **UID** *(default : 991)*
|
||||
- **GID** *(default : 991)*
|
||||
|
||||
#### How to configure
|
||||
You should provide your own configuration file from this base : https://raw.githubusercontent.com/micheloosterhof/cowrie/master/cowrie.cfg.dist
|
||||
You can mount this single file to your Docker container.
|
||||
|
||||
#### Volumes
|
||||
- **/cowrie/dl** : where downloads are stored.
|
||||
- **/cowrie/log** : cowrie and tty sessions logs.
|
||||
- **/cowrie/cowrie.cfg** : cowrie configuration file. **Provide yours!**
|
||||
- **/custom** : customize cowrie structure with your own files
|
||||
|
||||
#### Docker compose (example)
|
||||
```
|
||||
cowrie:
|
||||
image: wonderfall/cowrie
|
||||
links: ### MySQL output
|
||||
- cowrie-db:cowrie-db ### MySQL output
|
||||
ports:
|
||||
- "2222:2222"
|
||||
volumes:
|
||||
- /mnt/cowrie/dl:/cowrie/dl
|
||||
- /mnt/cowrie/log:/cowrie/log
|
||||
- /mnt/cowrie/custom:/custom
|
||||
- /mnt/cowrie/cowrie.cfg:/cowrie/cowrie.cfg
|
||||
environment:
|
||||
- GID=1000
|
||||
- UID=1000
|
||||
|
||||
### MySQL output
|
||||
# First, you'll have to initialise tables with a .sql file
|
||||
# mkdir -p /mnt/cowrie/sql
|
||||
# wget https://raw.githubusercontent.com/micheloosterhof/cowrie/master/doc/sql/mysql.sql -P /mnt/cowrie/sql/cowrie.sql
|
||||
# It needs also to be configured in the cowrie.cfg file
|
||||
|
||||
cowrie-db:
|
||||
image: mariadb:10
|
||||
volumes:
|
||||
- /mnt/cowrie/db:/var/lib/mysql
|
||||
- /mnt/cowrie/sql:/docker-entrypoint-initdb.d
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=supersecretpassword
|
||||
- MYSQL_DATABASE=cowrie
|
||||
- MYSQL_USER=cowrie
|
||||
- MYSQL_PASSWORD=supersecretpassword
|
||||
```
|
||||
|
@ -1,12 +0,0 @@
|
||||
#!/bin/sh
|
||||
cd /cowrie
|
||||
|
||||
rm twistd.pid &>/dev/null
|
||||
mkdir -p /cowrie/log/tty &>/dev/null
|
||||
cp -R /custom/* /cowrie &>/dev/null
|
||||
chown -R $UID:$GID /cowrie
|
||||
|
||||
COWRIEDIR=$(dirname $0)
|
||||
export PYTHONPATH=${PYTHONPATH}:${COWRIEDIR}
|
||||
|
||||
exec su-exec $UID:$GID /sbin/tini -- twistd -n -l /cowrie/log/cowrie.log cowrie
|
@ -1,30 +0,0 @@
|
||||
FROM wonderfall/nginx-php:7.1
|
||||
|
||||
ARG FRESHRSS_VER=1.8.0
|
||||
|
||||
ENV UID=991 GID=991 \
|
||||
UPLOAD_MAX_SIZE=10M \
|
||||
MEMORY_LIMIT=128M \
|
||||
CRON_PERIOD=30m
|
||||
|
||||
RUN apk -U add --no-cache \
|
||||
tar \
|
||||
libressl \
|
||||
ca-certificates \
|
||||
&& mkdir freshrss && cd freshrss \
|
||||
&& wget -qO- https://github.com/FreshRSS/FreshRSS/archive/${FRESHRSS_VER}.tar.gz | tar xz --strip 1 \
|
||||
&& mv data data_tmp
|
||||
|
||||
COPY rootfs /
|
||||
|
||||
RUN chmod +x /usr/local/bin/run.sh /etc/s6.d/*/* /etc/s6.d/.s6-svscan/*
|
||||
|
||||
VOLUME /freshrss/data /php/session
|
||||
|
||||
EXPOSE 8888
|
||||
|
||||
LABEL maintainer="Wonderfall <wonderfall@targaryen.house>" \
|
||||
description="A free, self-hostable aggregator" \
|
||||
version="FreshRSS ${FRESHRSS_VER}"
|
||||
|
||||
CMD ["run.sh"]
|
@ -1,24 +0,0 @@
|
||||
## wonderfall/freshrss
|
||||
|
||||
A free, self-hostable aggregator : https://github.com/FreshRSS/FreshRSS
|
||||
|
||||
#### Features
|
||||
- Based on Alpine Linux (wonderfall/nginx-php image)
|
||||
- Bundled with nginx and PHP7.1.
|
||||
- Automatic feed update (frequency at 30 minutes by default)
|
||||
|
||||
#### Build-time variables
|
||||
- **FRESHRSS_VER** : version of FreshRSS
|
||||
|
||||
#### Environment variables
|
||||
- **UID** : user id
|
||||
- **GID** : group id
|
||||
- **MEMORY_LIMIT** : php memory limit *(default : 128M)*
|
||||
- **UPLOAD_MAX_SIZE** : maximum upload size *(default : 10M)*
|
||||
- **CRON_PERIOD** : feed update frequency *(default : 30m)*
|
||||
|
||||
#### Volumes
|
||||
- **/freshrss/data**
|
||||
|
||||
#### Ports
|
||||
- **8888** [(reverse proxy!)](https://github.com/hardware/mailserver/wiki/Reverse-proxy-configuration)
|
@ -1,6 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
while true; do
|
||||
php -f /freshrss/app/actualize_script.php
|
||||
sleep <CRON_PERIOD>
|
||||
done
|
@ -1,33 +0,0 @@
|
||||
server {
|
||||
listen 8888;
|
||||
root /freshrss;
|
||||
index index.php index.html;
|
||||
|
||||
location ~* \.(jpg|jpeg|gif|css|png|js|map|woff|woff2|ttf|svg|eot)$ {
|
||||
expires 30d;
|
||||
access_log off;
|
||||
}
|
||||
|
||||
location ~ ^/(data|cfg|tmp) {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location ~* /(.*)\.(?:markdown|md|twig|yaml|yml|ht|htaccess|ini)$ {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location ~ /\. {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location / {
|
||||
try_files $uri $uri/ /index.php;
|
||||
}
|
||||
|
||||
location ~ \.php$ {
|
||||
fastcgi_index index.php;
|
||||
fastcgi_pass unix:/php/run/php-fpm.sock;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
include /nginx/conf/fastcgi_params;
|
||||
}
|
||||
}
|
@ -1,8 +0,0 @@
|
||||
#!/bin/sh
|
||||
sed -i -e "s/<UPLOAD_MAX_SIZE>/$UPLOAD_MAX_SIZE/g" /nginx/conf/nginx.conf /php/etc/php-fpm.conf \
|
||||
-e "s/<MEMORY_LIMIT>/$MEMORY_LIMIT/g" /php/etc/php-fpm.conf \
|
||||
-e "s/<CRON_PERIOD>/$CRON_PERIOD/g" /etc/s6.d/cron/run
|
||||
|
||||
[ ! "$(ls -A /freshrss/data)" ] && cp -R /freshrss/data_tmp/* /freshrss/data/
|
||||
chown -R $UID:$GID /freshrss /nginx /php /tmp /etc/s6.d
|
||||
exec su-exec $UID:$GID /bin/s6-svscan /etc/s6.d
|
@ -1,43 +0,0 @@
|
||||
FROM alpine:3.6
|
||||
|
||||
ARG VERSION=1.14.0
|
||||
|
||||
ENV GHOST_NODE_VERSION_CHECK=false \
|
||||
NODE_ENV=production \
|
||||
GID=991 UID=991 \
|
||||
ADDRESS=https://my-ghost-blog.com \
|
||||
ENABLE_ISSO=False \
|
||||
ISSO_HOST=isso.domain.tld \
|
||||
ISSO_AVATAR=false \
|
||||
ISSO_VOTE=false
|
||||
|
||||
WORKDIR /ghost
|
||||
|
||||
RUN apk -U --no-cache add \
|
||||
bash \
|
||||
ca-certificates \
|
||||
grep \
|
||||
libressl \
|
||||
nodejs-current \
|
||||
nodejs-current-npm \
|
||||
s6 \
|
||||
su-exec \
|
||||
vim \
|
||||
&& wget -q https://github.com/TryGhost/Ghost/releases/download/${VERSION}/Ghost-${VERSION}.zip -P /tmp \
|
||||
&& unzip -q /tmp/Ghost-${VERSION}.zip -d /ghost \
|
||||
&& npm install --production \
|
||||
&& mv content/themes/casper casper
|
||||
|
||||
COPY rootfs /
|
||||
|
||||
RUN chmod +x /usr/local/bin/* /etc/s6.d/*/* /etc/s6.d/.s6-svscan/*
|
||||
|
||||
EXPOSE 2368
|
||||
|
||||
VOLUME /ghost/content
|
||||
|
||||
LABEL description="Ghost CMS ${VERSION}" \
|
||||
maintainer="Wonderfall <wonderfall@targaryen.house>"
|
||||
|
||||
ENTRYPOINT ["run.sh"]
|
||||
CMD ["/bin/s6-svscan", "/etc/s6.d"]
|
@ -1,44 +0,0 @@
|
||||
## wonderfall/ghost
|
||||
|
||||

|
||||
|
||||
**Breaking changes if you're upgrading from 0.x. Please export your current data, and import them again in a new 1.x blog. You also have to move your images to the new volume if you want to keep them. Disqus is also not supported, please move to Isso, a much better comments system. Sorry for the mess!**
|
||||
|
||||
#### What is this? What features?
|
||||
- A **simple** Ghost CMS build made for production.
|
||||
- Based on Alpine Linux so it's lightweight!
|
||||
- Bundled with latest node.js available (version check is disabled).
|
||||
- Offers Isso integration.
|
||||
|
||||
#### Build-time variables
|
||||
- **VERSION** : version of Ghost.
|
||||
|
||||
#### Environment variables
|
||||
- **GID** : ghost user id *(default : 991)*
|
||||
- **UID** : ghost group id *(default : 991)*
|
||||
- **ADDRESS** : your domain (with *http(s)://*) *(default : https://my-ghost-blog.com)*
|
||||
- **ENABLE_ISSO** : enables Isso support if set to *True* *(default : False)*
|
||||
- **ISSO_HOST**, **ISSO_AVATAR**, **ISSO_VOTE** : Isso settings (*True* or *False*)
|
||||
|
||||
#### Volumes
|
||||
- **/ghost/content** : contents of your blog
|
||||
|
||||
### Ports
|
||||
- **2368** [(reverse proxy!)](https://github.com/hardware/mailserver/wiki/Reverse-proxy-configuration)
|
||||
|
||||
### How to configure?
|
||||
Everything you need is in `/ghost/content/ghost.conf` (also mounted on your host...).
|
||||
|
||||
### docker-compose.yml sample
|
||||
|
||||
```
|
||||
ghost-myblog:
|
||||
image: wonderfall/ghost:1
|
||||
container_name: ghost-myblog
|
||||
environment:
|
||||
- UID=8100
|
||||
- GID=8100
|
||||
- ADDRESS=https://myblog.com
|
||||
volumes:
|
||||
- /mnt/docker/myblog:/ghost/content
|
||||
```
|
@ -1,2 +0,0 @@
|
||||
#!/bin/sh
|
||||
exit 0
|
@ -1,5 +0,0 @@
|
||||
#!/bin/sh
|
||||
cd /ghost
|
||||
NODE_ENV=development node_modules/.bin/knex-migrator init
|
||||
NODE_ENV=development node_modules/.bin/knex-migrator migrate
|
||||
exec npm start
|
@ -1,47 +0,0 @@
|
||||
#!/bin/bash
|
||||
echo
|
||||
echo ">>> wonderfall/ghost container <<<"
|
||||
echo
|
||||
|
||||
echo "> Initializing content folder..."
|
||||
cd content
|
||||
mkdir apps data images themes logs adapters &>/dev/null
|
||||
rm -rf /ghost/content/themes/casper &>/dev/null
|
||||
cp -r /ghost/casper themes/casper &>/dev/null
|
||||
cd /ghost
|
||||
|
||||
if [ ! -f /ghost/content/ghost.conf ]; then
|
||||
echo
|
||||
echo "INFO : No configuration file was provided, an example will be used"
|
||||
echo " You can access and modify it in the volume you mounted"
|
||||
echo " Restart in order to apply your changes!"
|
||||
echo
|
||||
mv /usr/local/etc/ghost.example.conf /ghost/content/ghost.conf
|
||||
fi
|
||||
|
||||
if [ ! -f /ghost/config.production.json ]; then
|
||||
ln -s content/ghost.conf config.production.json
|
||||
fi
|
||||
|
||||
echo "> Applying preferences..."
|
||||
|
||||
sed -i -e "s|https://my-ghost-blog.com|${ADDRESS}|g" /ghost/content/ghost.conf
|
||||
|
||||
if [ "$ENABLE_ISSO" == "True" ] && ! grep -q 'isso' /ghost/content/themes/casper/post.hbs; then
|
||||
cd /usr/local/etc
|
||||
sed -i -e "/\/author/r isso.conf" /ghost/content/themes/casper/post.hbs
|
||||
sed -i -e '/isso-thread/{n;d}' /ghost/content/themes/casper/post.hbs
|
||||
sed -i -e "s/<HOST>/$ISSO_HOST/g" \
|
||||
-e "s/<AVATAR>/$ISSO_AVATAR/g" \
|
||||
-e "s/<VOTE>/$ISSO_VOTE/g" /ghost/content/themes/casper/post.hbs
|
||||
fi
|
||||
|
||||
echo "> Updating permissions..."
|
||||
chown -R ${UID}:${GID} /ghost /etc/s6.d
|
||||
|
||||
echo "> Executing process..."
|
||||
if [ '$@' == '' ]; then
|
||||
exec su-exec ${UID}:${GID} /bin/s6-svscan /etc/s6.d
|
||||
else
|
||||
exec su-exec ${UID}:${GID} "$@"
|
||||
fi
|
@ -1,16 +0,0 @@
|
||||
|
||||
<div id="disqus_thread"></div>
|
||||
<script type="text/javascript">
|
||||
var disqus_shortname = '<SHORTNAME>';
|
||||
var disqus_identifier = '{{post.id}}';
|
||||
|
||||
/* * * DON'T EDIT BELOW THIS LINE * * */
|
||||
(function() {
|
||||
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
|
||||
dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
|
||||
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
|
||||
})();
|
||||
</script>
|
||||
<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
|
||||
<a href="http://disqus.com" class="dsq-brlink">comments powered by <span class="logo-disqus">Disqus</span></a>
|
||||
|
@ -1,21 +0,0 @@
|
||||
{
|
||||
"url": "https://my-ghost-blog.com",
|
||||
|
||||
"server": {
|
||||
"host": "0.0.0.0",
|
||||
"port": "2368"
|
||||
},
|
||||
|
||||
"database": {
|
||||
"client": "sqlite3",
|
||||
"connection": {
|
||||
"filename": "content/data/ghost-dev.db"
|
||||
},
|
||||
"useNullAsDefault": true,
|
||||
"debug": false
|
||||
},
|
||||
|
||||
"mail": {
|
||||
"transport": "Direct"
|
||||
}
|
||||
}
|
@ -1,7 +0,0 @@
|
||||
</footer>
|
||||
<script data-isso="//<HOST>/"
|
||||
data-isso-avatar="<AVATAR>"
|
||||
data-isso-vote="<VOTE>"
|
||||
src="//<HOST>/js/embed.min.js"></script>
|
||||
|
||||
<section id="isso-thread"></section>
|
@ -1,47 +0,0 @@
|
||||
FROM alpine:edge
|
||||
|
||||
ENV GID=991 UID=991
|
||||
|
||||
RUN echo "@testing https://nl.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories \
|
||||
&& BUILD_DEPS="tar libressl ca-certificates" \
|
||||
&& apk -U upgrade && apk add \
|
||||
$BUILD_DEPS \
|
||||
nginx \
|
||||
s6 \
|
||||
su-exec \
|
||||
coreutils \
|
||||
bind-tools \
|
||||
php7-fpm@testing \
|
||||
php7-mysqlnd@testing \
|
||||
php7-pdo@testing \
|
||||
php7-pdo_mysql@testing \
|
||||
php7-openssl@testing \
|
||||
php7-gd@testing \
|
||||
php7-curl@testing \
|
||||
php7-phar@testing \
|
||||
php7-dom@testing \
|
||||
&& mkdir kippo-graph && cd kippo-graph \
|
||||
&& wget -qO- https://github.com/ikoniaris/kippo-graph/archive/master.tar.gz | tar xz --strip 1 \
|
||||
&& chmod 777 generated-graphs \
|
||||
&& mv config.php.dist config.php \
|
||||
&& rm /kippo-graph/include/maxmind/GeoLite2-City.mmdb /kippo-graph/include/maxmind/geoip2.phar \
|
||||
&& wget -q https://geolite.maxmind.com/download/geoip/database/GeoLite2-City.mmdb.gz -P /kippo-graph/include/maxmind \
|
||||
&& gzip -d /kippo-graph/include/maxmind/GeoLite2-City.mmdb.gz \
|
||||
&& wget -q https://github.com/maxmind/GeoIP2-php/releases/download/v2.4.5/geoip2.phar -P /kippo-graph/include/maxmind \
|
||||
&& apk del $BUILD_DEPS \
|
||||
&& rm -f /var/cache/apk/*
|
||||
|
||||
COPY nginx.conf /etc/nginx/nginx.conf
|
||||
COPY php-fpm.conf /etc/php7/php-fpm.conf
|
||||
COPY run.sh /usr/local/bin/run.sh
|
||||
COPY s6.d /etc/s6.d
|
||||
|
||||
RUN chmod +x /usr/local/bin/run.sh /etc/s6.d/*/* /etc/s6.d/.s6-svscan/*
|
||||
|
||||
VOLUME /kippo-graph/generated-graphs
|
||||
|
||||
EXPOSE 8888
|
||||
|
||||
LABEL maintainer="Wonderfall <wonderfall@targaryen.house>"
|
||||
|
||||
CMD ["run.sh"]
|
@ -1,29 +0,0 @@
|
||||
### wonderfall/kippo-graph
|
||||
|
||||

|
||||
|
||||
#### What is this?
|
||||
Kippo-Graph is a full featured script to visualize statistics for a Kippo based SSH honeypot.
|
||||
|
||||
#### Environment variables
|
||||
- **UID** *(default : 991)*
|
||||
- **GID** *(default : 991)*
|
||||
|
||||
#### How to configure
|
||||
You should provide your own configuration file from this base : https://github.com/ikoniaris/kippo-graph/blob/master/config.php.dist
|
||||
You can mount this single file to your Docker container.
|
||||
|
||||
#### Docker compose (example)
|
||||
```
|
||||
kippo-graph:
|
||||
image: wonderfall/kippo-graph
|
||||
links:
|
||||
- cowrie-db:cowrie-db
|
||||
volumes:
|
||||
- /mnt/kippo-graph/config.php:/kippo-graph/config.php
|
||||
- /mnt/cowrie/log:/opt/cowrie/log
|
||||
environment:
|
||||
- GID=991
|
||||
- UID=991
|
||||
```
|
||||
|
@ -1,84 +0,0 @@
|
||||
worker_processes auto;
|
||||
pid /tmp/nginx.pid;
|
||||
daemon off;
|
||||
|
||||
events {
|
||||
worker_connections 1024;
|
||||
use epoll;
|
||||
}
|
||||
|
||||
http {
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
|
||||
access_log off;
|
||||
error_log /tmp/ngx_error.log error;
|
||||
|
||||
sendfile on;
|
||||
keepalive_timeout 15;
|
||||
keepalive_disable msie6;
|
||||
keepalive_requests 100;
|
||||
tcp_nopush on;
|
||||
tcp_nodelay on;
|
||||
server_tokens off;
|
||||
|
||||
fastcgi_temp_path /tmp/fastcgi 1 2;
|
||||
client_body_temp_path /tmp/client_body 1 2;
|
||||
proxy_temp_path /tmp/proxy 1 2;
|
||||
uwsgi_temp_path /tmp/uwsgi 1 2;
|
||||
scgi_temp_path /tmp/scgi 1 2;
|
||||
|
||||
gzip on;
|
||||
gzip_comp_level 5;
|
||||
gzip_min_length 512;
|
||||
gzip_buffers 4 8k;
|
||||
gzip_proxied any;
|
||||
gzip_vary on;
|
||||
gzip_disable "msie6";
|
||||
gzip_types
|
||||
text/css
|
||||
text/javascript
|
||||
text/xml
|
||||
text/plain
|
||||
text/x-component
|
||||
application/javascript
|
||||
application/x-javascript
|
||||
application/json
|
||||
application/xml
|
||||
application/rss+xml
|
||||
application/vnd.ms-fontobject
|
||||
font/truetype
|
||||
font/opentype
|
||||
image/svg+xml;
|
||||
|
||||
server {
|
||||
listen 8888;
|
||||
root /kippo-graph;
|
||||
index index.php index.html;
|
||||
|
||||
location ~ ^/(data|cfg|tmp) {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location ~* /(.*)\.(?:markdown|md|twig|yaml|yml|ht|htaccess|ini)$ {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location ~ /\. {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location / {
|
||||
try_files $uri $uri/ /index.php;
|
||||
}
|
||||
|
||||
location ~ \.php$ {
|
||||
fastcgi_index index.php;
|
||||
fastcgi_pass unix:/tmp/php-fpm.sock;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
include /etc/nginx/fastcgi_params;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
@ -1,11 +0,0 @@
|
||||
[global]
|
||||
daemonize = no
|
||||
|
||||
[www]
|
||||
listen = /tmp/php-fpm.sock
|
||||
pm = dynamic
|
||||
pm.max_children = 5
|
||||
pm.start_servers = 2
|
||||
pm.min_spare_servers = 1
|
||||
pm.max_spare_servers = 3
|
||||
chdir = /
|
@ -1,3 +0,0 @@
|
||||
#!/bin/sh
|
||||
chown -R $UID:$GID /kippo-graph /etc/nginx /etc/php7 /var/log /var/lib/nginx /tmp /etc/s6.d
|
||||
exec su-exec $UID:$GID /bin/s6-svscan /etc/s6.d
|
@ -1,3 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
exit 0
|
@ -1,2 +0,0 @@
|
||||
#!/bin/sh
|
||||
exec nginx
|
@ -1,2 +0,0 @@
|
||||
#!/bin/sh
|
||||
exec php-fpm7
|
@ -1,38 +0,0 @@
|
||||
FROM wonderfall/nginx-php:7.1
|
||||
|
||||
ARG MEDIAWIKI_VER=1.29
|
||||
ARG SUB_VERSION=1
|
||||
|
||||
ENV UID=991 GID=991 \
|
||||
UPLOAD_MAX_SIZE=10M \
|
||||
MEMORY_LIMIT=128M
|
||||
|
||||
RUN apk -U add \
|
||||
tar \
|
||||
libressl \
|
||||
ca-certificates \
|
||||
git \
|
||||
lua \
|
||||
coreutils \
|
||||
diffutils \
|
||||
build-base \
|
||||
autoconf \
|
||||
&& pecl install apcu \
|
||||
&& mkdir mediawiki && cd mediawiki \
|
||||
&& wget -qO- https://releases.wikimedia.org/mediawiki/${MEDIAWIKI_VER}/mediawiki-${MEDIAWIKI_VER}.${SUB_VERSION}.tar.gz | tar xz --strip 1 \
|
||||
&& apk del build-base autoconf \
|
||||
&& rm -rf /var/cache/apk/*
|
||||
|
||||
COPY rootfs /
|
||||
|
||||
RUN chmod +x /usr/local/bin/run.sh /etc/s6.d/*/* /etc/s6.d/.s6-svscan/*
|
||||
|
||||
VOLUME /config /skins /extensions /mediawiki/images /php/session
|
||||
|
||||
EXPOSE 8888
|
||||
|
||||
LABEL maintainer="Wonderfall <wonderfall@targaryen.house>" \
|
||||
description="MediaWiki is a free software open source wiki package written in PHP" \
|
||||
version="MediaWiki ${MEDIAWIKI_VER}.${SUB_VERSION}"
|
||||
|
||||
CMD ["run.sh"]
|
@ -1,69 +0,0 @@
|
||||
## wonderfall/mediawiki
|
||||
|
||||
Host your own Wiki!
|
||||
|
||||
#### Features
|
||||
- Based on Alpine Linux (wonderfall/nginx-php image)
|
||||
- Bundled with nginx and PHP7.1.
|
||||
|
||||
#### Build-time variables
|
||||
- **MEDIAWIKI_VER** : Mediawiki version
|
||||
- **SUB_VERSION** : Mediawiki subversion
|
||||
|
||||
#### Environment variables
|
||||
- **UID** : privatebin user id
|
||||
- **GID** : privatebin group id
|
||||
- **MEMORY_LIMIT** : php memorny limit *(default : 128M)*
|
||||
- **UPLOAD_MAX_SIZE** : maximum upload size *(default : 10M)*
|
||||
|
||||
#### Volumes
|
||||
- /mediawiki/images
|
||||
- /extensions
|
||||
- /skins
|
||||
- /config
|
||||
- /mediawiki/custom
|
||||
|
||||
#### Ports
|
||||
- **8888** [(reverse proxy!)](https://github.com/hardware/mailserver/wiki/Reverse-proxy-configuration)
|
||||
|
||||
#### docker-compose.yml sample
|
||||
|
||||
```
|
||||
mywiki:
|
||||
image: wonderfall/mediawiki
|
||||
container_name: mywiki
|
||||
links:
|
||||
- mywiki-db:mywiki-db
|
||||
- mywiki-parsoid:mywiki-parsoid
|
||||
environment:
|
||||
- UPLOAD_MAX_SIZE=20M
|
||||
- MEMORY_LIMIT=512M
|
||||
- UID=1668
|
||||
- GID=1668
|
||||
volumes:
|
||||
- /mnt/mywiki/images:/mediawiki/images
|
||||
- /mnt/mywiki/extensions:/extensions
|
||||
- /mnt/mywiki/skins:/skins
|
||||
- /mnt/mywiki/config:/config
|
||||
- /mnt/mywiki/custom:/mediawiki/custom
|
||||
|
||||
mywiki-db:
|
||||
image: mariadb:10.1
|
||||
container_name: mywiki-db
|
||||
volumes:
|
||||
- /mnt/mywiki/db:/var/lib/mysql
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=supersecret
|
||||
- MYSQL_DATABASE=mywiki
|
||||
- MYSQL_USER=mywiki
|
||||
- MYSQL_PASSWORD=supersecret
|
||||
|
||||
mywiki-parsoid:
|
||||
image: wonderfall/parsoid
|
||||
container_name: mywiki-parsoid
|
||||
environment:
|
||||
- UID=1669
|
||||
- GID=1669
|
||||
- ADDRESS=https://wiki.domain.com/
|
||||
- DOMAIN=mywiki-parsoid
|
||||
```
|
@ -1,43 +0,0 @@
|
||||
server {
|
||||
listen 8888;
|
||||
root /mediawiki;
|
||||
index index.php index.html;
|
||||
|
||||
client_body_timeout 60;
|
||||
|
||||
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
|
||||
try_files $uri /index.php;
|
||||
expires max;
|
||||
log_not_found off;
|
||||
}
|
||||
|
||||
location ^~ /cache/ {
|
||||
deny all;
|
||||
}
|
||||
|
||||
location /dumps {
|
||||
root /mediawiki/local;
|
||||
}
|
||||
|
||||
location / {
|
||||
try_files $uri $uri/ @rewrite;
|
||||
}
|
||||
|
||||
location @rewrite {
|
||||
rewrite ^/(.*)$ /index.php;
|
||||
}
|
||||
|
||||
location ^~ /maintenance/ {
|
||||
return 403;
|
||||
}
|
||||
|
||||
location ^~ /images/ {}
|
||||
|
||||
location ~ \.php$ {
|
||||
fastcgi_index index.php;
|
||||
fastcgi_pass unix:/php/run/php-fpm.sock;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
include /nginx/conf/fastcgi_params;
|
||||
try_files $uri @rewrite;
|
||||
}
|
||||
}
|
@ -1,4 +0,0 @@
|
||||
extension=apcu.so
|
||||
apc.enabled=1
|
||||
apc.shm_size=<APC_SHM_SIZE>
|
||||
apc.ttl=7200
|
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
sed -i -e "s/<UPLOAD_MAX_SIZE>/$UPLOAD_MAX_SIZE/g" /nginx/conf/nginx.conf /php/etc/php-fpm.conf \
|
||||
-e "s/<MEMORY_LIMIT>/$MEMORY_LIMIT/g" /php/etc/php-fpm.conf \
|
||||
-e "s/<APC_SHM_SIZE>/$APC_SHM_SIZE/g" /php/conf.d/apcu.ini
|
||||
|
||||
chown -R $UID:$GID /mediawiki /nginx /php /tmp /etc/s6.d
|
||||
|
||||
if [ -f /config/LocalSettings.php ] && [ ! -f /mediawiki/LocalSettings.php ]; then
|
||||
ln -s /config/LocalSettings.php /mediawiki/LocalSettings.php
|
||||
fi
|
||||
|
||||
cp -r /skins/* /mediawiki/skins/
|
||||
cp -r /extensions/* /mediawiki/extensions/
|
||||
|
||||
exec su-exec $UID:$GID /bin/s6-svscan /etc/s6.d
|
@ -1,28 +0,0 @@
|
||||
FROM alpine:3.6
|
||||
|
||||
ENV NODE_ENV=production \
|
||||
GID=991 UID=991 \
|
||||
INTERFACE=0.0.0.0 \
|
||||
PORT=8000 \
|
||||
ADDRESS=http://localhost/w/ \
|
||||
DOMAIN=localhost
|
||||
|
||||
RUN apk -U --no-cache add \
|
||||
ca-certificates \
|
||||
libressl \
|
||||
nodejs-current \
|
||||
nodejs-current-npm \
|
||||
s6 \
|
||||
git \
|
||||
su-exec \
|
||||
&& git clone https://gerrit.wikimedia.org/r/p/mediawiki/services/parsoid --depth=1 \
|
||||
&& cd parsoid && npm install
|
||||
|
||||
COPY rootfs /
|
||||
|
||||
RUN chmod +x /usr/local/bin/* /etc/s6.d/*/* /etc/s6.d/.s6-svscan/*
|
||||
|
||||
EXPOSE 8000
|
||||
|
||||
ENTRYPOINT ["run.sh"]
|
||||
CMD ["/bin/s6-svscan", "/etc/s6.d"]
|
@ -1,28 +0,0 @@
|
||||
## wonderfall/parsoid
|
||||
|
||||
#### What is this? What features?
|
||||
- A **simple** Parsoid image.
|
||||
- Based on Alpine Linux so it's lightweight!
|
||||
- Bundled with latest node.js available (version check is disabled).
|
||||
|
||||
#### Build-time variables
|
||||
- **VERSION** : version of Ghost.
|
||||
|
||||
#### Environment variables
|
||||
- **GID** : ghost user id *(default : 991)*
|
||||
- **UID** : ghost group id *(default : 991)*
|
||||
- **ADDRESS** : your address *(default : http://localhost/w/)*
|
||||
- **DOMAIN** : name of the container *(default : localhost)*
|
||||
|
||||
### docker-compose.yml sample
|
||||
|
||||
```
|
||||
mywiki-parsoid:
|
||||
image: wonderfall/parsoid
|
||||
container_name: mywiki-parsoid
|
||||
environment:
|
||||
- UID=1669
|
||||
- GID=1669
|
||||
- ADDRESS=https://wiki.domain.com/
|
||||
- DOMAIN=mywiki-parsoid
|
||||
```
|
@ -1,2 +0,0 @@
|
||||
#!/bin/sh
|
||||
exit 0
|
@ -1,3 +0,0 @@
|
||||
#!/bin/sh
|
||||
cd /parsoid
|
||||
exec node bin/server.js
|
@ -1,19 +0,0 @@
|
||||
#!/bin/sh
|
||||
echo
|
||||
echo ">>> wonderfall/parsoid container <<<"
|
||||
echo
|
||||
|
||||
cd /parsoid
|
||||
cp config.example.yaml config.yaml
|
||||
sed -i "s|http://localhost/w/|$ADDRESS|g" config.yaml
|
||||
sed -i "s|domain: 'localhost'|domain: '$DOMAIN'|g" config.yaml
|
||||
|
||||
echo "> Updating permissions..."
|
||||
chown -R ${UID}:${GID} /parsoid /etc/s6.d
|
||||
|
||||
echo "> Executing process..."
|
||||
if [ '$@' == '' ]; then
|
||||
exec su-exec ${UID}:${GID} /bin/s6-svscan /etc/s6.d
|
||||
else
|
||||
exec su-exec ${UID}:${GID} "$@"
|
||||
fi
|
@ -1,16 +0,0 @@
|
||||
|
||||
<div id="disqus_thread"></div>
|
||||
<script type="text/javascript">
|
||||
var disqus_shortname = '<SHORTNAME>';
|
||||
var disqus_identifier = '{{post.id}}';
|
||||
|
||||
/* * * DON'T EDIT BELOW THIS LINE * * */
|
||||
(function() {
|
||||
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
|
||||
dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
|
||||
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
|
||||
})();
|
||||
</script>
|
||||
<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
|
||||
<a href="http://disqus.com" class="dsq-brlink">comments powered by <span class="logo-disqus">Disqus</span></a>
|
||||
|
@ -1,21 +0,0 @@
|
||||
{
|
||||
"url": "https://my-ghost-blog.com",
|
||||
|
||||
"server": {
|
||||
"host": "0.0.0.0",
|
||||
"port": "2368"
|
||||
},
|
||||
|
||||
"database": {
|
||||
"client": "sqlite3",
|
||||
"connection": {
|
||||
"filename": "content/data/ghost-dev.db"
|
||||
},
|
||||
"useNullAsDefault": true,
|
||||
"debug": false
|
||||
},
|
||||
|
||||
"mail": {
|
||||
"transport": "Direct"
|
||||
}
|
||||
}
|
@ -1,7 +0,0 @@
|
||||
</footer>
|
||||
<script data-isso="//<HOST>/"
|
||||
data-isso-avatar="<AVATAR>"
|
||||
data-isso-vote="<VOTE>"
|
||||
src="//<HOST>/js/embed.min.js"></script>
|
||||
|
||||
<section id="isso-thread"></section>
|
@ -1,16 +0,0 @@
|
||||
FROM alpine:3.6
|
||||
|
||||
ENV UID=991 GID=991
|
||||
|
||||
RUN apk -U --no-cache add \
|
||||
pgbouncer \
|
||||
tini \
|
||||
su-exec
|
||||
|
||||
COPY run.sh /usr/local/bin/run.sh
|
||||
|
||||
RUN chmod +x /usr/local/bin/run.sh
|
||||
|
||||
VOLUME /etc/pgbouncer
|
||||
|
||||
CMD ["run.sh"]
|
@ -1,10 +0,0 @@
|
||||
## wonderfall/pgbouncer
|
||||
|
||||
Minimal image for [PgBouncer](https://pgbouncer.github.io/).
|
||||
|
||||
### Volumes
|
||||
- /etc/pgbouncer
|
||||
|
||||
### Environment variables
|
||||
- **GID** : user id *(default : 991)*
|
||||
- **UID** : group id *(default : 991)*
|
@ -1,4 +0,0 @@
|
||||
#!/bin/sh
|
||||
mkdir /run/pgbouncer
|
||||
chown -R $UID:$GID /etc/pgbouncer /var/log/pgbouncer /run/pgbouncer
|
||||
exec su-exec $UID:$GID /sbin/tini -- pgbouncer /etc/pgbouncer/pgbouncer.ini
|
Loading…
x
Reference in New Issue
Block a user