-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit c9fc1a9
Showing
10 changed files
with
2,911 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
# This workflow uses actions that are not certified by GitHub. | ||
# They are provided by a third-party and are governed by | ||
# separate terms of service, privacy policy, and support | ||
# documentation. | ||
|
||
# GitHub recommends pinning actions to a commit SHA. | ||
# To get a newer version, you will need to update the SHA. | ||
# You can also reference a tag or branch, but the action may change without warning. | ||
|
||
name: Publish Docker image | ||
|
||
on: | ||
release: | ||
types: [published] | ||
|
||
jobs: | ||
push_to_registry: | ||
name: Push Docker image to Docker Hub | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Check out the repo | ||
uses: actions/checkout@v3 | ||
|
||
- name: Log in to Docker Hub | ||
uses: docker/login-action@f4ef78c080cd8ba55a85445d5b36e214a81df20a | ||
with: | ||
username: ${{ secrets.DOCKER_USERNAME }} | ||
password: ${{ secrets.DOCKER_PASSWORD }} | ||
|
||
- name: Extract metadata (tags, labels) for Docker | ||
id: meta | ||
uses: docker/metadata-action@9ec57ed1fcdbf14dcef7dfbe97b2010124a938b7 | ||
with: | ||
images: my-docker-hub-namespace/my-docker-hub-repository | ||
|
||
- name: Build and push Docker image | ||
uses: docker/build-push-action@3b5e8027fcad23fda98b2e3ac259d8d67585f671 | ||
with: | ||
context: . | ||
file: ./Dockerfile | ||
push: true | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
FROM debian:bookworm-slim | ||
|
||
|
||
LABEL org.opencontainers.image.source="https://github.com/HackerspaceKRK/phorge-docker" | ||
LABEL org.opencontainers.image.authors="alufers <[email protected]>" | ||
LABEL org.opencontainers.image.title="Phorge" | ||
LABEL org.opencontainers.image.description="Phorge is a Phabricator fork with a focus on performance and stability." | ||
|
||
ARG PHORGE_SHA=98dfac53ba721467a32b96641f3a18d428fb5441 | ||
ARG ARCANIST_SHA=788098096e113f34f0fafef23e4d16a2e80d64ca | ||
|
||
|
||
ENV GIT_USER=git | ||
ENV MYSQL_PORT=3306 | ||
ENV PROTOCOL=http | ||
|
||
|
||
EXPOSE 8022 80 443 | ||
|
||
# TODO: Once Phorge is updated to support PHP 8.0, | ||
# we can use PHP from debian repo instead of sury.org | ||
|
||
RUN apt-get update -y && apt-get install -y wget lsb-release && \ | ||
wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg && \ | ||
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" >> /etc/apt/sources.list.d/php.list && \ | ||
apt-get update -y && \ | ||
apt-get -y install \ | ||
mercurial subversion sudo apt-transport-https ca-certificates wget git \ | ||
php7.4 php7.4-mysql php7.4-gd php7.4-curl php7.4-apcu php7.4-cli php7.4-json php7.4-mbstring php7.4-fpm php7.4-zip php-pear \ | ||
nginx supervisor procps python3-pygments imagemagick curl | ||
|
||
RUN mkdir -p /var/www/phorge/phorge \ | ||
mkdir -p /var/www/phorge/arcanist \ | ||
&& cd /var/www/phorge/phorge && git init \ | ||
&& git remote add origin https://we.phorge.it/source/phorge.git \ | ||
&& git fetch --depth=1 origin $PHORGE_SHA \ | ||
&& git checkout FETCH_HEAD \ | ||
&& cd /var/www/phorge/arcanist && git init \ | ||
&& git remote add origin https://we.phorge.it/source/arcanist.git \ | ||
&& git fetch --depth=1 origin master \ | ||
&& git checkout FETCH_HEAD | ||
|
||
|
||
# #copy nginx config | ||
COPY ./configs/nginx-ph.conf /etc/nginx/sites-available/phorge.conf | ||
COPY ./configs/nginx.conf /etc/nginx/nginx.conf | ||
# add phorge to nginx sites-enabled and remove default | ||
RUN ln -s /etc/nginx/sites-available/phorge.conf /etc/nginx/sites-enabled/phorge.conf \ | ||
&& rm /etc/nginx/sites-enabled/default | ||
|
||
|
||
#copy php config | ||
COPY ./configs/www.conf /etc/php/7.4/fpm/pool.d/www.conf | ||
COPY ./configs/php.ini /etc/php/7.4/fpm/php.ini | ||
COPY ./configs/php-fpm.conf /etc/php/7.4/fpm/php-fpm.conf | ||
|
||
#copy supervisord config | ||
COPY ./configs/supervisord.conf /etc/supervisord.conf | ||
COPY ./scripts/startup.sh /startup.sh | ||
|
||
RUN mkdir -p /run/php && chown www-data:www-data /run/php \ | ||
&& chmod +x /startup.sh | ||
|
||
# #copy startup script | ||
RUN mkdir -p /var/repo/ && rm -rf /var/cache/apt | ||
CMD [ "/startup.sh" ] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
# README | ||
|
||
Dockerfile for running Phorge in a container. Based on: https://github.com/cooperspencer/phorge | ||
|
||
## Differences from the original Dockerfile | ||
|
||
- Use debian 12 (bookworm) | ||
- Remove ssh server support | ||
- Fetch Phorge commits by sha instead of downloading the latest one at build time | ||
- Add mysql configuration as per Phorge suggestions | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
server { | ||
server_name www.phorge.local; | ||
return 301 $scheme://phorge.local$request_uri; | ||
} | ||
|
||
server { | ||
listen 80 default_server; | ||
server_name phorge.local; | ||
root /var/www/phorge/phorge/webroot/; | ||
|
||
location / { | ||
index index.php; | ||
rewrite ^/(.*)$ /index.php?__path__=/$1 last; | ||
} | ||
|
||
location /index.php { | ||
fastcgi_pass unix:/run/php/php7.4-fpm.sock; | ||
fastcgi_index index.php; | ||
|
||
#required if PHP was built with --enable-force-cgi-redirect | ||
fastcgi_param REDIRECT_STATUS 200; | ||
|
||
#variables to make the $_SERVER populate in PHP | ||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; | ||
fastcgi_param QUERY_STRING $query_string; | ||
fastcgi_param REQUEST_METHOD $request_method; | ||
fastcgi_param CONTENT_TYPE $content_type; | ||
fastcgi_param CONTENT_LENGTH $content_length; | ||
|
||
fastcgi_param SCRIPT_NAME $fastcgi_script_name; | ||
|
||
fastcgi_param GATEWAY_INTERFACE CGI/1.1; | ||
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; | ||
|
||
fastcgi_param REMOTE_ADDR $remote_addr; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
user www-data; | ||
worker_processes auto; | ||
pid /run/nginx.pid; | ||
include /etc/nginx/modules-enabled/*.conf; | ||
|
||
events { | ||
worker_connections 768; | ||
# multi_accept on; | ||
} | ||
|
||
http { | ||
|
||
## | ||
# Basic Settings | ||
## | ||
|
||
sendfile on; | ||
tcp_nopush on; | ||
tcp_nodelay on; | ||
keepalive_timeout 65; | ||
types_hash_max_size 2048; | ||
client_max_body_size 256M; | ||
# server_tokens off; | ||
|
||
# server_names_hash_bucket_size 64; | ||
# server_name_in_redirect off; | ||
|
||
include /etc/nginx/mime.types; | ||
default_type application/octet-stream; | ||
|
||
## | ||
# SSL Settings | ||
## | ||
|
||
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE | ||
ssl_prefer_server_ciphers on; | ||
|
||
## | ||
# Logging Settings | ||
## | ||
|
||
access_log /var/log/nginx/access.log; | ||
error_log /var/log/nginx/error.log; | ||
|
||
## | ||
# Gzip Settings | ||
## | ||
|
||
gzip on; | ||
|
||
# gzip_vary on; | ||
# gzip_proxied any; | ||
# gzip_comp_level 6; | ||
# gzip_buffers 16 8k; | ||
# gzip_http_version 1.1; | ||
# gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; | ||
|
||
## | ||
# Virtual Host Configs | ||
## | ||
|
||
include /etc/nginx/conf.d/*.conf; | ||
include /etc/nginx/sites-enabled/*; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
;;;;;;;;;;;;;;;;;;;;; | ||
; FPM Configuration ; | ||
;;;;;;;;;;;;;;;;;;;;; | ||
|
||
; All relative paths in this configuration file are relative to PHP's install | ||
; prefix (/usr). This prefix can be dynamically changed by using the | ||
; '-p' argument from the command line. | ||
|
||
;;;;;;;;;;;;;;;;;; | ||
; Global Options ; | ||
;;;;;;;;;;;;;;;;;; | ||
|
||
[global] | ||
; Pid file | ||
; Note: the default prefix is /var | ||
; Default Value: none | ||
; Warning: if you change the value here, you need to modify systemd | ||
; service PIDFile= setting to match the value here. | ||
pid = /run/php/php7.4-fpm.pid | ||
|
||
; Error log file | ||
; If it's set to "syslog", log is sent to syslogd instead of being written | ||
; into a local file. | ||
; Note: the default prefix is /var | ||
; Default Value: log/php-fpm.log | ||
error_log = /var/log/php7.4-fpm.log | ||
|
||
; syslog_facility is used to specify what type of program is logging the | ||
; message. This lets syslogd specify that messages from different facilities | ||
; will be handled differently. | ||
; See syslog(3) for possible values (ex daemon equiv LOG_DAEMON) | ||
; Default Value: daemon | ||
;syslog.facility = daemon | ||
|
||
; syslog_ident is prepended to every message. If you have multiple FPM | ||
; instances running on the same server, you can change the default value | ||
; which must suit common needs. | ||
; Default Value: php-fpm | ||
;syslog.ident = php-fpm | ||
|
||
; Log level | ||
; Possible Values: alert, error, warning, notice, debug | ||
; Default Value: notice | ||
;log_level = notice | ||
|
||
; Log limit on number of characters in the single line (log entry). If the | ||
; line is over the limit, it is wrapped on multiple lines. The limit is for | ||
; all logged characters including message prefix and suffix if present. However | ||
; the new line character does not count into it as it is present only when | ||
; logging to a file descriptor. It means the new line character is not present | ||
; when logging to syslog. | ||
; Default Value: 1024 | ||
;log_limit = 4096 | ||
|
||
; Log buffering specifies if the log line is buffered which means that the | ||
; line is written in a single write operation. If the value is false, then the | ||
; data is written directly into the file descriptor. It is an experimental | ||
; option that can potentionaly improve logging performance and memory usage | ||
; for some heavy logging scenarios. This option is ignored if logging to syslog | ||
; as it has to be always buffered. | ||
; Default value: yes | ||
;log_buffering = no | ||
|
||
; If this number of child processes exit with SIGSEGV or SIGBUS within the time | ||
; interval set by emergency_restart_interval then FPM will restart. A value | ||
; of '0' means 'Off'. | ||
; Default Value: 0 | ||
;emergency_restart_threshold = 0 | ||
|
||
; Interval of time used by emergency_restart_interval to determine when | ||
; a graceful restart will be initiated. This can be useful to work around | ||
; accidental corruptions in an accelerator's shared memory. | ||
; Available Units: s(econds), m(inutes), h(ours), or d(ays) | ||
; Default Unit: seconds | ||
; Default Value: 0 | ||
;emergency_restart_interval = 0 | ||
|
||
; Time limit for child processes to wait for a reaction on signals from master. | ||
; Available units: s(econds), m(inutes), h(ours), or d(ays) | ||
; Default Unit: seconds | ||
; Default Value: 0 | ||
;process_control_timeout = 0 | ||
|
||
; The maximum number of processes FPM will fork. This has been designed to control | ||
; the global number of processes when using dynamic PM within a lot of pools. | ||
; Use it with caution. | ||
; Note: A value of 0 indicates no limit | ||
; Default Value: 0 | ||
; process.max = 128 | ||
|
||
; Specify the nice(2) priority to apply to the master process (only if set) | ||
; The value can vary from -19 (highest priority) to 20 (lowest priority) | ||
; Note: - It will only work if the FPM master process is launched as root | ||
; - The pool process will inherit the master process priority | ||
; unless specified otherwise | ||
; Default Value: no set | ||
; process.priority = -19 | ||
|
||
; Send FPM to background. Set to 'no' to keep FPM in foreground for debugging. | ||
; Default Value: yes | ||
;daemonize = yes | ||
|
||
; Set open file descriptor rlimit for the master process. | ||
; Default Value: system defined value | ||
;rlimit_files = 1024 | ||
|
||
; Set max core size rlimit for the master process. | ||
; Possible Values: 'unlimited' or an integer greater or equal to 0 | ||
; Default Value: system defined value | ||
;rlimit_core = 0 | ||
|
||
; Specify the event mechanism FPM will use. The following is available: | ||
; - select (any POSIX os) | ||
; - poll (any POSIX os) | ||
; - epoll (linux >= 2.5.44) | ||
; - kqueue (FreeBSD >= 4.1, OpenBSD >= 2.9, NetBSD >= 2.0) | ||
; - /dev/poll (Solaris >= 7) | ||
; - port (Solaris >= 10) | ||
; Default Value: not set (auto detection) | ||
;events.mechanism = epoll | ||
|
||
; When FPM is built with systemd integration, specify the interval, | ||
; in seconds, between health report notification to systemd. | ||
; Set to 0 to disable. | ||
; Available Units: s(econds), m(inutes), h(ours) | ||
; Default Unit: seconds | ||
; Default value: 10 | ||
;systemd_interval = 10 | ||
|
||
;;;;;;;;;;;;;;;;;;;; | ||
; Pool Definitions ; | ||
;;;;;;;;;;;;;;;;;;;; | ||
|
||
; Multiple pools of child processes may be started with different listening | ||
; ports and different management options. The name of the pool will be | ||
; used in logs and stats. There is no limitation on the number of pools which | ||
; FPM can handle. Your system will tell you anyway :) | ||
|
||
; Include one or more files. If glob(3) exists, it is used to include a bunch of | ||
; files from a glob(3) pattern. This directive can be used everywhere in the | ||
; file. | ||
; Relative path can also be used. They will be prefixed by: | ||
; - the global prefix if it's been set (-p argument) | ||
; - /usr otherwise | ||
include=/etc/php/7.4/fpm/pool.d/*.conf |
Oops, something went wrong.