Skip to content

Commit 2bb54b7

Browse files
committed
🚀 Initial commit
0 parents  commit 2bb54b7

File tree

10 files changed

+451
-0
lines changed

10 files changed

+451
-0
lines changed

.editorconfig

+8
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
root = true
2+
3+
[*]
4+
end_of_line = lf
5+
insert_final_newline = true
6+
indent_style = space
7+
indent_size = 2
8+
trim_trailing_whitespace = true

.github/CODE_OF_CONDUCT.md

+128
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,128 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, gendercharacteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, religion, or genderidentity
10+
and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
- Demonstrating empathy and kindness toward other people.
21+
- Being respectful of differing opinions, viewpoints, and experiences.
22+
- Giving and gracefully accepting constructive feedback.
23+
- Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience.
25+
- Focusing on what is best not just for us as individuals, but for the
26+
overall community.
27+
28+
Examples of unacceptable behavior include:
29+
30+
- The use of improper language or imagery, and genderattention or
31+
advances of any kind.
32+
- Trolling, insulting or derogatory comments, and personal or political attacks.
33+
- Public or private harassment.
34+
- Publishing others' private information, such as a physical or email
35+
address, without their explicit permission.
36+
- Other conduct which could reasonably be considered inappropriate in a
37+
professional setting.
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official e-mail address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
<info@kloud.email>.
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series
86+
of actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or
93+
permanent ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within
113+
the community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.0, available at
119+
<https://www.contributor-covenant.org/version/2/0/code_of_conduct.html>.
120+
121+
Community Impact Guidelines were inspired by [Mozilla's code of conduct
122+
enforcement ladder](https://github.com/mozilla/diversity).
123+
124+
[homepage]: https://www.contributor-covenant.org
125+
126+
For answers to common questions about this code of conduct, see the FAQ at
127+
<https://www.contributor-covenant.org/faq>. Translations are available at
128+
<https://www.contributor-covenant.org/translations>.

.github/workflows/build.yaml

+54
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
---
2+
name: 👷‍♂️ Build
3+
4+
on:
5+
push:
6+
tags:
7+
- v*
8+
9+
jobs:
10+
docker:
11+
name: 🐳 Docker Build
12+
runs-on: ubuntu-latest
13+
14+
permissions:
15+
contents: read
16+
packages: write
17+
18+
steps:
19+
- name: 📁 Checkout repository
20+
uses: actions/checkout@v4
21+
22+
- uses: docker/setup-qemu-action@v3
23+
- uses: docker/setup-buildx-action@v3
24+
25+
- name: 🔑 Login to GHCR
26+
uses: docker/login-action@v3
27+
with:
28+
registry: ghcr.io
29+
username: ${{ github.repository_owner }}
30+
password: ${{ secrets.GITHUB_TOKEN }}
31+
32+
- name: 📃 Docker metadata
33+
id: meta
34+
uses: docker/metadata-action@v5
35+
with:
36+
images: ghcr.io/${{ github.repository }}
37+
flavor: |
38+
latest=false
39+
tags: |
40+
type=raw,value=latest
41+
type=semver,pattern=v{{version}}
42+
type=semver,pattern=v{{major}}.{{minor}}
43+
44+
- name: 🐳 Docker Build & Push
45+
uses: docker/build-push-action@v5
46+
id: docker_build
47+
with:
48+
cache-from: type=gha
49+
cache-to: type=gha,mode=max
50+
context: .
51+
push: true
52+
provenance: false
53+
labels: ${{ steps.meta.outputs.labels }}
54+
tags: ${{ steps.meta.outputs.tags }}

.gitignore

Whitespace-only changes.

Dockerfile

+54
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
ARG php_version=8.3
2+
3+
FROM dunglas/frankenphp:1.1-php${php_version} AS base
4+
WORKDIR /app
5+
6+
ENV SERVER_NAME=:80
7+
ARG user=laravel
8+
9+
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
10+
COPY --chmod=755 src/entrypoint.sh /entrypoint.sh
11+
COPY src/php.ini "${PHP_INI_DIR}/php.ini"
12+
13+
RUN apt-get update \
14+
&& apt-get satisfy -y --no-install-recommends \
15+
"curl (>=7.88)" \
16+
"supervisor (>=4.2)" \
17+
"unzip (>=6.0)" \
18+
&& rm -rf /var/lib/apt/lists/*
19+
20+
RUN useradd \
21+
--uid 1000 \
22+
--shell /bin/bash \
23+
"${user}" \
24+
&& setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/frankenphp \
25+
&& chown -R "${user}:${user}" \
26+
/app \
27+
/data/caddy \
28+
/config/caddy \
29+
&& mv "${PHP_INI_DIR}/php.ini-production" "${PHP_INI_DIR}/php.ini"
30+
31+
RUN install-php-extensions \
32+
curl \
33+
gd \
34+
intl \
35+
pcntl \
36+
pdo_pgsql \
37+
opcache \
38+
redis \
39+
zip
40+
41+
USER ${user}
42+
43+
COPY --chown=${user}:${user} src/artisan artisan
44+
45+
RUN mkdir -p \
46+
bootstrap/cache \
47+
storage/framework/cache \
48+
storage/framework/sessions \
49+
storage/framework/testing \
50+
storage/framework/views \
51+
storage/logs \
52+
&& chmod -R a+rw storage
53+
54+
ENTRYPOINT ["/entrypoint.sh"]

LICENSE

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
MIT License
2+
3+
Copyright (c) 2024 KloudKIT
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in all
13+
copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
SOFTWARE.

README.md

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
# Laravel Docker Base
2+
3+
> Docker base image for Laravel production applications
4+
5+
## Environment Variables
6+
7+
| `env` | Default | Mode |
8+
| ------------------------------ | ------- | --------- |
9+
| `CONTAINER_MANUAL_SETUP` || `*` |
10+
| `CONTAINER_MODE` | `"app"` | `*` |
11+
| `CONTAINER_PORT` | `8000` | app |
12+
| `CONTAINER_SCHEDULER_INTERVAL` | `60` | scheduler |
13+
| `CONTAINER_WORKER_DELAY` | `10` | worker |
14+
| `CONTAINER_WORKER_SLEEP` | `5` | worker |
15+
| `CONTAINER_WORKER_TRIES` | `3` | worker |
16+
| `CONTAINER_WORKER_TIMEOUT` | `300` | worker |

src/artisan

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
#!/usr/bin/env php
2+
<?php
3+
4+
use Symfony\Component\Console\Input\ArgvInput;
5+
6+
define('LARAVEL_START', microtime(true));
7+
8+
require __DIR__.'/vendor/autoload.php';
9+
10+
$status = (require_once __DIR__.'/bootstrap/app.php')
11+
->handleCommand(new ArgvInput);
12+
13+
exit($status);

src/entrypoint.sh

+70
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
#!/bin/bash
2+
3+
set -e
4+
5+
: "${CONTAINER_MODE:=app}"
6+
: "${CONTAINER_PORT:=8000}"
7+
: "${CONTAINER_WORKER_DELAY:=10}"
8+
: "${CONTAINER_WORKER_SLEEP:=5}"
9+
: "${CONTAINER_WORKER_TIMEOUT:=300}"
10+
: "${CONTAINER_WORKER_TRIES:=3}"
11+
: "${CONTAINER_SCHEDULER_INTERVAL:=60}"
12+
: "${APP_ENV:=production}"
13+
14+
ARTISAN="php -d variables_order=EGPCS /app/artisan"
15+
16+
_setup() {
17+
if [ -n "${CONTAINER_MANUAL_SETUP}" ]; then
18+
echo DEBUG: Skipping setup...
19+
20+
return
21+
fi
22+
23+
echo DEBUG: Preparing application...
24+
25+
${ARTISAN} storage:link || true
26+
27+
${ARTISAN} optimize || true
28+
${ARTISAN} config:cache || true
29+
${ARTISAN} route:cache || true
30+
${ARTISAN} view:cache || true
31+
${ARTISAN} events:cache || true
32+
33+
${ARTISAN} migrate --force || true
34+
}
35+
36+
_run() {
37+
case "${CONTAINER_MODE}" in
38+
app)
39+
echo INFO: Running octane...
40+
exec "${ARTISAN}" octane:frankenphp --host=0.0.0.0 --port="${CONTAINER_PORT}"
41+
;;
42+
worker)
43+
echo INFO: Running the queue...
44+
exec "${ARTISAN}" queue:work -vv \
45+
--no-interaction \
46+
--tries="${CONTAINER_WORKER_TRIES}" \
47+
--sleep="${CONTAINER_WORKER_SLEEP}" \
48+
--timeout="${CONTAINER_WORKER_TIMEOUT}" \
49+
--delay="${CONTAINER_WORKER_DELAY}"
50+
;;
51+
horizon)
52+
echo INFO: Running horizon...
53+
exec "${ARTISAN}" horizon
54+
;;
55+
scheduler)
56+
while true; do
57+
echo "INFO: Running scheduled tasks."
58+
"${ARTISAN}" schedule:run --verbose --no-interaction &
59+
sleep "${CONTAINER_SCHEDULER_INTERVAL}s"
60+
done
61+
;;
62+
*)
63+
echo "Could not match the container mode [${CONTAINER_MODE}]"
64+
exit 1
65+
;;
66+
esac
67+
}
68+
69+
_setup
70+
_run

0 commit comments

Comments
 (0)