initial commit
This commit is contained in:
commit
835f683c48
36
Dockerfile
Normal file
36
Dockerfile
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
ARG NODE_VERSION=14
|
||||||
|
FROM node:${NODE_VERSION}-alpine
|
||||||
|
RUN apk add --no-cache make pkgconfig gcc g++ python3 libx11-dev libxkbfile-dev libsecret-dev chromium
|
||||||
|
ARG version=latest
|
||||||
|
WORKDIR /home/theia
|
||||||
|
ADD $version.package.json ./package.json
|
||||||
|
ARG GITHUB_TOKEN
|
||||||
|
RUN yarn --pure-lockfile && \
|
||||||
|
NODE_OPTIONS="--max_old_space_size=4096" yarn theia build && \
|
||||||
|
yarn theia download:plugins && \
|
||||||
|
yarn --production && \
|
||||||
|
yarn autoclean --init && \
|
||||||
|
echo *.ts >> .yarnclean && \
|
||||||
|
echo *.ts.map >> .yarnclean && \
|
||||||
|
echo *.spec.* >> .yarnclean && \
|
||||||
|
yarn autoclean --force && \
|
||||||
|
yarn cache clean
|
||||||
|
|
||||||
|
FROM node:${NODE_VERSION}-alpine
|
||||||
|
# See : https://github.com/theia-ide/theia-apps/issues/34
|
||||||
|
RUN addgroup theia && \
|
||||||
|
adduser -G theia -s /bin/sh -D theia;
|
||||||
|
RUN chmod g+rw /home && \
|
||||||
|
mkdir -p /home/project && \
|
||||||
|
chown -R theia:theia /home/theia && \
|
||||||
|
chown -R theia:theia /home/project;
|
||||||
|
RUN apk add --no-cache git openssh bash libsecret chromium tor iptables
|
||||||
|
ENV HOME /home/theia
|
||||||
|
WORKDIR /home/theia
|
||||||
|
COPY --from=0 --chown=theia:theia /home/theia /home/theia
|
||||||
|
EXPOSE 3000
|
||||||
|
ENV SHELL=/bin/bash \
|
||||||
|
THEIA_DEFAULT_PLUGINS=local-dir:/home/theia/plugins
|
||||||
|
ENV USE_LOCAL_GIT true
|
||||||
|
#USER theia
|
||||||
|
ENTRYPOINT [ "node", "/home/theia/src-gen/backend/main.js", "/home/project", "--hostname=0.0.0.0" ]
|
21
README.md
Normal file
21
README.md
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# docker-theia
|
||||||
|
|
||||||
|
### Simple docker to start theia project with tor network
|
||||||
|
|
||||||
|
## Install
|
||||||
|
|
||||||
|
$ git clone --recurse-submodules https://git.manalejandro.com/ale/docker-theia
|
||||||
|
$ cd docker-theia && cp Dockerfile theia-apps/theia-docker/
|
||||||
|
$ docker compose build
|
||||||
|
|
||||||
|
## Start
|
||||||
|
|
||||||
|
$ docker compose up -d
|
||||||
|
|
||||||
|
## Stop
|
||||||
|
|
||||||
|
$ docker compose down
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
MIT
|
30
docker-compose.yml
Normal file
30
docker-compose.yml
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
services:
|
||||||
|
theia:
|
||||||
|
build: ./theia-apps/theia-docker
|
||||||
|
hostname: theia
|
||||||
|
container_name: theia
|
||||||
|
restart: always
|
||||||
|
entrypoint:
|
||||||
|
- /bin/bash
|
||||||
|
- /entrypoint.sh
|
||||||
|
mem_limit: 500000000
|
||||||
|
volumes:
|
||||||
|
- ./entrypoint.sh:/entrypoint.sh:ro
|
||||||
|
- ./torrc:/etc/tor/torrc:ro
|
||||||
|
- ./iptables.rules:/etc/iptables/iptables.rules:ro
|
||||||
|
- ./public-project:/home/project
|
||||||
|
expose:
|
||||||
|
- 3000
|
||||||
|
cap_add:
|
||||||
|
- NET_ADMIN
|
||||||
|
networks:
|
||||||
|
mynet:
|
||||||
|
ipv4_address: 172.16.16.101
|
||||||
|
|
||||||
|
networks:
|
||||||
|
mynet:
|
||||||
|
driver: bridge
|
||||||
|
ipam:
|
||||||
|
config:
|
||||||
|
- subnet: 172.16.16.0/24
|
||||||
|
|
4
entrypoint.sh
Executable file
4
entrypoint.sh
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
iptables-restore /etc/iptables/iptables.rules
|
||||||
|
su tor -s /bin/bash -c 'tor -f /etc/tor/torrc'
|
||||||
|
su -c 'node /home/theia/src-gen/backend/main.js /home/project --hostname=0.0.0.0' theia
|
69
iptables.rules
Normal file
69
iptables.rules
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
*filter
|
||||||
|
:INPUT DROP [0:0]
|
||||||
|
:FORWARD DROP [0:0]
|
||||||
|
:OUTPUT DROP [0:0]
|
||||||
|
|
||||||
|
# Allow related/established traffic
|
||||||
|
-A INPUT -m conntrack --ctstate ESTABLISHED -j ACCEPT
|
||||||
|
# Allow traffic on local loopback
|
||||||
|
-A INPUT -i lo -j ACCEPT
|
||||||
|
# Allow ICMP packets
|
||||||
|
-A INPUT -p icmp -j ACCEPT
|
||||||
|
# Allow connections to Tor Proxy
|
||||||
|
-A INPUT -p tcp --dport 9050 -m state --state NEW -j ACCEPT
|
||||||
|
-A INPUT -p udp --dport 5353 -m state --state NEW -j ACCEPT
|
||||||
|
# Log dropped packets
|
||||||
|
#-A INPUT -j LOG --log-prefix "Dropped INPUT packet: " --log-level 7 --log-uid
|
||||||
|
-A INPUT -p tcp -d 172.16.16.101/32 --dport 3000 -m state --state NEW -j ACCEPT
|
||||||
|
|
||||||
|
# Don't allow any packet forwarding
|
||||||
|
|
||||||
|
# Block invalid traffic
|
||||||
|
-A OUTPUT -m state --state INVALID -j DROP
|
||||||
|
# Allow related/established traffic
|
||||||
|
-A OUTPUT -m conntrack --ctstate ESTABLISHED -j ACCEPT
|
||||||
|
# Allow outbound connection for the tor-router user to the Tor directory servers and network
|
||||||
|
-A OUTPUT -m owner -o eth0 --uid-owner 100 -p tcp -m tcp --tcp-flags FIN,SYN,RST,ACK SYN -m state --state NEW -j ACCEPT
|
||||||
|
# Allow traffic on local loopback
|
||||||
|
-A OUTPUT -d 127.0.0.1/32 -o lo -j ACCEPT
|
||||||
|
# Allow connections to local transparent listener
|
||||||
|
-A OUTPUT -d 127.0.0.1/32 -p tcp --syn --dport 9040 -j ACCEPT
|
||||||
|
# Log all other dropped packets
|
||||||
|
#-A OUTPUT -j LOG --log-prefix "Dropped OUTPUT packet: " --log-level 7 --log-uid
|
||||||
|
-A OUTPUT -s 172.16.16.101/32 -p tcp --syn --sport 3000 -j ACCEPT
|
||||||
|
|
||||||
|
COMMIT
|
||||||
|
|
||||||
|
*nat
|
||||||
|
:PREROUTING ACCEPT [0:0]
|
||||||
|
:INPUT ACCEPT [0:0]
|
||||||
|
:OUTPUT ACCEPT [0:0]
|
||||||
|
:POSTROUTING ACCEPT [0:0]
|
||||||
|
|
||||||
|
# Skip pre-routing if interface is WAN or local
|
||||||
|
-A PREROUTING -i eth0 -j RETURN
|
||||||
|
-A PREROUTING -i lo -j RETURN
|
||||||
|
# Redirect all .onion addresses
|
||||||
|
-A PREROUTING -d 10.192.0.0/10 -p tcp --syn -j REDIRECT --to-ports 9040
|
||||||
|
# Redirect UDP DNS traffic to internal DNS server
|
||||||
|
-A PREROUTING -p udp --dport 5353 -j REDIRECT --to-ports 5353
|
||||||
|
-A PREROUTING -p udp --dport 53 -j REDIRECT --to-ports 5353
|
||||||
|
# Skip pre-routing if destination is private or reserved
|
||||||
|
-A PREROUTING -d 0.0.0.0/8,10.0.0.0/8,100.64.0.0/10,127.0.0.0/8,169.254.0.0/16,172.16.0.0/12,192.0.0.0/24,192.0.2.0/24,192.88.99.0/24,192.168.0.0/16,198.18.0.0/15,198.51.100.0/24,203.0.113.0/24,224.0.0.0/4,240.0.0.0/4,255.255.255.255/32 -j RETURN
|
||||||
|
# Redirect remaining TCP traffic
|
||||||
|
-A PREROUTING -p tcp --syn -j REDIRECT --to-ports 9040
|
||||||
|
|
||||||
|
# Redirect all .onion addresses
|
||||||
|
-A OUTPUT -d 10.192.0.0/10 -p tcp --syn -j REDIRECT --to-ports 9040
|
||||||
|
# Redirect all DNS traffic
|
||||||
|
-A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 5353
|
||||||
|
# Allow the tor-router to bypass transparent routing
|
||||||
|
-A OUTPUT -m owner --uid-owner 100 -j RETURN
|
||||||
|
# Don't transparently redirect traffic out of the loopback
|
||||||
|
-A OUTPUT -o lo -j RETURN
|
||||||
|
# Don't redirect if destination is private or reserved
|
||||||
|
-A OUTPUT -d 0.0.0.0/8,10.0.0.0/8,100.64.0.0/10,127.0.0.0/8,169.254.0.0/16,172.16.0.0/12,192.0.0.0/24,192.0.2.0/24,192.88.99.0/24,192.168.0.0/16,198.18.0.0/15,198.51.100.0/24,203.0.113.0/24,224.0.0.0/4,240.0.0.0/4,255.255.255.255/32 -j RETURN
|
||||||
|
# Redirect remaining TCP traffic
|
||||||
|
-A OUTPUT -p tcp --syn -j REDIRECT --to-ports 9040
|
||||||
|
|
||||||
|
COMMIT
|
1
theia-apps
Submodule
1
theia-apps
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 2a18f975c3a0860ab3dcd3d9c0ce125259ff003a
|
15
torrc
Normal file
15
torrc
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
RunAsDaemon 1
|
||||||
|
|
||||||
|
# Setup Tor SOCKS Proxy
|
||||||
|
SocksPort 9050
|
||||||
|
SocksListenAddress 0.0.0.0
|
||||||
|
|
||||||
|
# Setup DNS server
|
||||||
|
DNSPort 5353
|
||||||
|
DNSListenAddress 0.0.0.0
|
||||||
|
|
||||||
|
# Setup Tor Transparent Routing
|
||||||
|
TransPort 9040
|
||||||
|
TransListenAddress 0.0.0.0
|
||||||
|
VirtualAddrNetworkIPv4 10.192.0.0/10
|
||||||
|
AutomapHostsOnResolve 1
|
Loading…
x
Reference in New Issue
Block a user