Compare commits
No commits in common. "main" and "v1.14.3-3" have entirely different histories.
@ -1,23 +0,0 @@
|
|||||||
# Changelog
|
|
||||||
|
|
||||||
{{ range .Versions -}}
|
|
||||||
## {{ if .Tag.Previous }}[{{ .Tag.Name }}]({{ $.Info.RepositoryURL }}/compare/{{ .Tag.Previous.Name }}...{{ .Tag.Name }}){{ else }}{{ .Tag.Name }}{{ end }} ({{ datetime "2006-01-02" .Tag.Date }})
|
|
||||||
|
|
||||||
{{ range .CommitGroups -}}
|
|
||||||
### {{ .Title }}
|
|
||||||
|
|
||||||
{{ range .Commits -}}
|
|
||||||
- {{ if .Scope }}**{{ .Scope }}:** {{ end }}{{ (regexReplaceAll "(.*)/issues/(.*)" (regexReplaceAll "(Co-\\w*-by.*)" .Subject "") "${1}/pulls/${2}") | trim }}
|
|
||||||
{{ end }}
|
|
||||||
{{- end -}}
|
|
||||||
|
|
||||||
{{- if .NoteGroups -}}
|
|
||||||
{{ range .NoteGroups -}}
|
|
||||||
### {{ .Title }}
|
|
||||||
|
|
||||||
{{ range .Notes }}
|
|
||||||
{{ .Body }}
|
|
||||||
{{ end }}
|
|
||||||
{{ end -}}
|
|
||||||
{{ end -}}
|
|
||||||
{{ end -}}
|
|
@ -1,25 +0,0 @@
|
|||||||
style: github
|
|
||||||
template: CHANGELOG.tpl.md
|
|
||||||
info:
|
|
||||||
title: CHANGELOG
|
|
||||||
repository_url: https://gitea.rknet.org/docker/freshrss
|
|
||||||
options:
|
|
||||||
commit_groups:
|
|
||||||
title_maps:
|
|
||||||
feat: Features
|
|
||||||
fix: Bug Fixes
|
|
||||||
perf: Performance Improvements
|
|
||||||
refactor: Code Refactoring
|
|
||||||
chore: Others
|
|
||||||
test: Testing
|
|
||||||
ci: CI Pipeline
|
|
||||||
docs: Documentation
|
|
||||||
header:
|
|
||||||
pattern: "^(\\w*)(?:\\(([\\w\\$\\.\\-\\*\\s]*)\\))?\\:\\s(.*)$"
|
|
||||||
pattern_maps:
|
|
||||||
- Type
|
|
||||||
- Scope
|
|
||||||
- Subject
|
|
||||||
notes:
|
|
||||||
keywords:
|
|
||||||
- BREAKING CHANGE
|
|
8
.dockerignore
Normal file
8
.dockerignore
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
.git
|
||||||
|
.git*
|
||||||
|
.drone.*
|
||||||
|
*.md
|
||||||
|
.dockerignore
|
||||||
|
Dockerfile
|
||||||
|
Dockerfile.*
|
||||||
|
docker-compose.yml
|
148
.drone.jsonnet
Normal file
148
.drone.jsonnet
Normal file
@ -0,0 +1,148 @@
|
|||||||
|
local PipelineBuild(os='linux', arch='amd64') = {
|
||||||
|
local tag = os + '-' + arch,
|
||||||
|
local version_tag = os + '-' + arch,
|
||||||
|
local file_suffix = std.strReplace(version_tag, '-', '.'),
|
||||||
|
kind: "pipeline",
|
||||||
|
name: version_tag,
|
||||||
|
platform: {
|
||||||
|
os: os,
|
||||||
|
arch: arch,
|
||||||
|
},
|
||||||
|
steps: [
|
||||||
|
{
|
||||||
|
name: 'dryrun',
|
||||||
|
image: 'plugins/docker:' + tag,
|
||||||
|
pull: 'always',
|
||||||
|
settings: {
|
||||||
|
dry_run: true,
|
||||||
|
tags: version_tag,
|
||||||
|
dockerfile: './Dockerfile.' + file_suffix,
|
||||||
|
repo: 'xoxys/freshrss',
|
||||||
|
username: { from_secret: "docker_username" },
|
||||||
|
password: { from_secret: "docker_password" },
|
||||||
|
build_args: {
|
||||||
|
FRESHRSS_VERSION: "${DRONE_TAG%-*}",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'publish',
|
||||||
|
image: 'plugins/docker:' + tag,
|
||||||
|
pull: 'always',
|
||||||
|
settings: {
|
||||||
|
auto_tag: true,
|
||||||
|
auto_tag_suffix: version_tag,
|
||||||
|
dockerfile: './Dockerfile.' + file_suffix,
|
||||||
|
repo: 'xoxys/freshrss',
|
||||||
|
username: { from_secret: "docker_username" },
|
||||||
|
password: { from_secret: "docker_password" },
|
||||||
|
build_args: {
|
||||||
|
FRESHRSS_VERSION: "${DRONE_TAG%-*}",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
when: {
|
||||||
|
ref: [
|
||||||
|
'refs/heads/master',
|
||||||
|
'refs/tags/**',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "publish-gitea",
|
||||||
|
image: "plugins/gitea-release",
|
||||||
|
pull: "always",
|
||||||
|
settings: {
|
||||||
|
api_key: { "from_secret": "gitea_token" },
|
||||||
|
base_url: "https://gitea.rknet.org",
|
||||||
|
overwrite: true,
|
||||||
|
title: "${DRONE_TAG}",
|
||||||
|
note: "CHANGELOG.md",
|
||||||
|
},
|
||||||
|
when: {
|
||||||
|
ref: ['refs/tags/**'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
local PipelineNotifications(depends_on=[]) = {
|
||||||
|
kind: "pipeline",
|
||||||
|
name: "notifications",
|
||||||
|
platform: {
|
||||||
|
os: "linux",
|
||||||
|
arch: "amd64",
|
||||||
|
},
|
||||||
|
steps: [
|
||||||
|
{
|
||||||
|
image: "plugins/manifest",
|
||||||
|
name: "manifest",
|
||||||
|
pull: "always",
|
||||||
|
settings: {
|
||||||
|
ignore_missing: true,
|
||||||
|
tags: ["${DRONE_TAG}", "${DRONE_TAG%-*}", "${DRONE_TAG%.*}", "${DRONE_TAG%%.*}"],
|
||||||
|
username: { from_secret: "docker_username" },
|
||||||
|
password: { from_secret: "docker_password" },
|
||||||
|
spec: "./manifest.tmpl",
|
||||||
|
},
|
||||||
|
when: {
|
||||||
|
ref: [
|
||||||
|
'refs/heads/master',
|
||||||
|
'refs/tags/**',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "readme",
|
||||||
|
image: "sheogorath/readme-to-dockerhub",
|
||||||
|
pull: "always",
|
||||||
|
environment: {
|
||||||
|
DOCKERHUB_USERNAME: { from_secret: "docker_username" },
|
||||||
|
DOCKERHUB_PASSWORD: { from_secret: "docker_password" },
|
||||||
|
DOCKERHUB_REPO_PREFIX: "xoxys",
|
||||||
|
DOCKERHUB_REPO_NAME: "freshrss",
|
||||||
|
README_PATH: "README.md",
|
||||||
|
SHORT_DESCRIPTION: "Rootless FreshRSS - Self-hosted RSS feed aggregator"
|
||||||
|
},
|
||||||
|
when: {
|
||||||
|
ref: [
|
||||||
|
'refs/heads/master',
|
||||||
|
'refs/tags/**',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "microbadger",
|
||||||
|
image: "plugins/webhook",
|
||||||
|
pull: "always",
|
||||||
|
settings: {
|
||||||
|
urls: { from_secret: "microbadger_url" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
image: "plugins/matrix",
|
||||||
|
name: "matrix",
|
||||||
|
pull: 'always',
|
||||||
|
settings: {
|
||||||
|
homeserver: "https://matrix.rknet.org",
|
||||||
|
roomid: "MtidqQXWWAtQcByBhH:rknet.org",
|
||||||
|
template: "Status: **{{ build.status }}**<br/> Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}<br/> Message: {{ build.message }}",
|
||||||
|
username: { from_secret: "matrix_username" },
|
||||||
|
password: { from_secret: "matrix_password" },
|
||||||
|
},
|
||||||
|
when: {
|
||||||
|
status: [ "success", "failure" ],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
trigger: {
|
||||||
|
status: [ "success", "failure" ],
|
||||||
|
},
|
||||||
|
depends_on: depends_on,
|
||||||
|
};
|
||||||
|
|
||||||
|
[
|
||||||
|
PipelineBuild(os='linux', arch='amd64'),
|
||||||
|
PipelineNotifications(depends_on=[
|
||||||
|
"linux-amd64",
|
||||||
|
])
|
||||||
|
]
|
274
.drone.yml
274
.drone.yml
@ -1,132 +1,59 @@
|
|||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
name: test
|
name: linux-amd64
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: linux
|
os: linux
|
||||||
arch: amd64
|
arch: amd64
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: markdownlint
|
- name: dryrun
|
||||||
image: thegeeklab/markdownlint-cli
|
pull: always
|
||||||
commands:
|
image: plugins/docker:linux-amd64
|
||||||
- markdownlint 'README.md'
|
settings:
|
||||||
|
build_args:
|
||||||
|
FRESHRSS_VERSION: "${DRONE_TAG%-*}"
|
||||||
|
dockerfile: ./Dockerfile.linux.amd64
|
||||||
|
dry_run: true
|
||||||
|
password:
|
||||||
|
from_secret: docker_password
|
||||||
|
repo: xoxys/freshrss
|
||||||
|
tags: linux-amd64
|
||||||
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
|
||||||
trigger:
|
- name: publish
|
||||||
ref:
|
pull: always
|
||||||
- refs/heads/main
|
image: plugins/docker:linux-amd64
|
||||||
- refs/pull/**
|
settings:
|
||||||
- refs/tags/**
|
auto_tag: true
|
||||||
|
auto_tag_suffix: linux-amd64
|
||||||
|
build_args:
|
||||||
|
FRESHRSS_VERSION: "${DRONE_TAG%-*}"
|
||||||
|
dockerfile: ./Dockerfile.linux.amd64
|
||||||
|
password:
|
||||||
|
from_secret: docker_password
|
||||||
|
repo: xoxys/freshrss
|
||||||
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
- refs/heads/master
|
||||||
|
- "refs/tags/**"
|
||||||
|
|
||||||
---
|
- name: publish-gitea
|
||||||
kind: pipeline
|
pull: always
|
||||||
name: build-container
|
image: plugins/gitea-release
|
||||||
|
settings:
|
||||||
platform:
|
api_key:
|
||||||
os: linux
|
from_secret: gitea_token
|
||||||
arch: amd64
|
base_url: https://gitea.rknet.org
|
||||||
|
note: CHANGELOG.md
|
||||||
steps:
|
overwrite: true
|
||||||
- name: dryrun
|
title: "${DRONE_TAG}"
|
||||||
image: thegeeklab/drone-docker-buildx:23
|
when:
|
||||||
settings:
|
ref:
|
||||||
dockerfile: Dockerfile
|
- "refs/tags/**"
|
||||||
dry_run: true
|
|
||||||
provenance: false
|
|
||||||
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/pull/**
|
|
||||||
|
|
||||||
- name: tags
|
|
||||||
image: thegeeklab/docker-autotag
|
|
||||||
environment:
|
|
||||||
DOCKER_AUTOTAG_FORCE_LATEST: True
|
|
||||||
DOCKER_AUTOTAG_IGNORE_PRERELEASE: True
|
|
||||||
DOCKER_AUTOTAG_OUTPUT_FILE: .tags
|
|
||||||
DOCKER_AUTOTAG_VERSION: ${DRONE_TAG}
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- refs/tags/**
|
|
||||||
depends_on:
|
|
||||||
- dryrun
|
|
||||||
|
|
||||||
- name: changelog-generate
|
|
||||||
image: thegeeklab/git-chglog
|
|
||||||
commands:
|
|
||||||
- git fetch -tq
|
|
||||||
- git-chglog --no-color --no-emoji -o CHANGELOG.md ${DRONE_TAG:---next-tag unreleased unreleased}
|
|
||||||
depends_on:
|
|
||||||
- tags
|
|
||||||
|
|
||||||
- name: changelog-format
|
|
||||||
image: thegeeklab/alpine-tools
|
|
||||||
commands:
|
|
||||||
- prettier CHANGELOG.md
|
|
||||||
- prettier -w CHANGELOG.md
|
|
||||||
depends_on:
|
|
||||||
- changelog-generate
|
|
||||||
|
|
||||||
- name: publish-dockerhub
|
|
||||||
image: thegeeklab/drone-docker-buildx:23
|
|
||||||
settings:
|
|
||||||
dockerfile: Dockerfile
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
provenance: false
|
|
||||||
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- refs/tags/**
|
|
||||||
depends_on:
|
|
||||||
- changelog-format
|
|
||||||
|
|
||||||
- name: publish-quay
|
|
||||||
image: thegeeklab/drone-docker-buildx:23
|
|
||||||
settings:
|
|
||||||
dockerfile: Dockerfile
|
|
||||||
password:
|
|
||||||
from_secret: quay_password
|
|
||||||
provenance: false
|
|
||||||
registry: quay.io
|
|
||||||
repo: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
|
||||||
username:
|
|
||||||
from_secret: quay_username
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- refs/tags/**
|
|
||||||
depends_on:
|
|
||||||
- changelog-format
|
|
||||||
|
|
||||||
- name: publish-gitea
|
|
||||||
image: plugins/gitea-release
|
|
||||||
settings:
|
|
||||||
api_key:
|
|
||||||
from_secret: gitea_token
|
|
||||||
base_url: https://gitea.rknet.org
|
|
||||||
note: CHANGELOG.md
|
|
||||||
overwrite: true
|
|
||||||
title: ${DRONE_TAG}
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/tags/**
|
|
||||||
depends_on:
|
|
||||||
- publish-dockerhub
|
|
||||||
- publish-quay
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- refs/pull/**
|
|
||||||
- refs/tags/**
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- test
|
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
@ -137,63 +64,76 @@ platform:
|
|||||||
arch: amd64
|
arch: amd64
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: pushrm-dockerhub
|
- name: manifest
|
||||||
pull: always
|
pull: always
|
||||||
image: chko/docker-pushrm:1
|
image: plugins/manifest
|
||||||
environment:
|
settings:
|
||||||
DOCKER_PASS:
|
ignore_missing: true
|
||||||
from_secret: docker_password
|
password:
|
||||||
DOCKER_USER:
|
from_secret: docker_password
|
||||||
from_secret: docker_username
|
spec: ./manifest.tmpl
|
||||||
PUSHRM_FILE: README.md
|
tags:
|
||||||
PUSHRM_SHORT: Custom image for FreshRSS feed aggregator
|
- "${DRONE_TAG}"
|
||||||
PUSHRM_TARGET: thegeeklab/${DRONE_REPO_NAME}
|
- "${DRONE_TAG%-*}"
|
||||||
when:
|
- "${DRONE_TAG%.*}"
|
||||||
status:
|
- "${DRONE_TAG%%.*}"
|
||||||
- success
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
- refs/heads/master
|
||||||
|
- "refs/tags/**"
|
||||||
|
|
||||||
- name: pushrm-quay
|
- name: readme
|
||||||
pull: always
|
pull: always
|
||||||
image: chko/docker-pushrm:1
|
image: sheogorath/readme-to-dockerhub
|
||||||
environment:
|
environment:
|
||||||
APIKEY__QUAY_IO:
|
DOCKERHUB_PASSWORD:
|
||||||
from_secret: quay_token
|
from_secret: docker_password
|
||||||
PUSHRM_FILE: README.md
|
DOCKERHUB_REPO_NAME: freshrss
|
||||||
PUSHRM_TARGET: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
DOCKERHUB_REPO_PREFIX: xoxys
|
||||||
when:
|
DOCKERHUB_USERNAME:
|
||||||
status:
|
from_secret: docker_username
|
||||||
- success
|
README_PATH: README.md
|
||||||
|
SHORT_DESCRIPTION: Rootless FreshRSS - Self-hosted RSS feed aggregator
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
- refs/heads/master
|
||||||
|
- "refs/tags/**"
|
||||||
|
|
||||||
- name: matrix
|
- name: microbadger
|
||||||
image: thegeeklab/drone-matrix
|
pull: always
|
||||||
settings:
|
image: plugins/webhook
|
||||||
homeserver:
|
settings:
|
||||||
from_secret: matrix_homeserver
|
urls:
|
||||||
password:
|
from_secret: microbadger_url
|
||||||
from_secret: matrix_password
|
|
||||||
roomid:
|
|
||||||
from_secret: matrix_roomid
|
|
||||||
template: "Status: **{{ .Build.Status }}**<br/> Build: [{{ .Repo.Owner }}/{{ .Repo.Name }}]({{ .Build.Link }}){{ if .Build.Branch }} ({{ .Build.Branch }}){{ end }} by {{ .Commit.Author }}<br/> Message: {{ .Commit.Message.Title }}"
|
|
||||||
username:
|
|
||||||
from_secret: matrix_username
|
|
||||||
when:
|
|
||||||
status:
|
|
||||||
- success
|
|
||||||
- failure
|
|
||||||
|
|
||||||
trigger:
|
- name: matrix
|
||||||
ref:
|
pull: always
|
||||||
- refs/heads/main
|
image: plugins/matrix
|
||||||
- refs/tags/**
|
settings:
|
||||||
status:
|
homeserver: https://matrix.rknet.org
|
||||||
|
password:
|
||||||
|
from_secret: matrix_password
|
||||||
|
roomid: MtidqQXWWAtQcByBhH:rknet.org
|
||||||
|
template: "Status: **{{ build.status }}**<br/> Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}<br/> Message: {{ build.message }}"
|
||||||
|
username:
|
||||||
|
from_secret: matrix_username
|
||||||
|
when:
|
||||||
|
status:
|
||||||
- success
|
- success
|
||||||
- failure
|
- failure
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
status:
|
||||||
|
- success
|
||||||
|
- failure
|
||||||
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- build-container
|
- linux-amd64
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: signature
|
kind: signature
|
||||||
hmac: cba07850e21c648f8558e69aa7e5a561ef473fe2a3a7890bf308a57c73ea0343
|
hmac: bd995781ed16870c304a86ea3c0ab8e61f34f6539ab34e4c16750f0e677965a2
|
||||||
|
|
||||||
...
|
...
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,2 +1 @@
|
|||||||
test/
|
test/
|
||||||
CHANGELOG.md
|
|
||||||
|
@ -1,6 +0,0 @@
|
|||||||
---
|
|
||||||
default: True
|
|
||||||
MD013: False
|
|
||||||
MD041: False
|
|
||||||
MD004:
|
|
||||||
style: dash
|
|
@ -1,3 +0,0 @@
|
|||||||
.drone.yml
|
|
||||||
*.tpl.md
|
|
||||||
LICENSE
|
|
3
CHANGELOG.md
Normal file
3
CHANGELOG.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
* ENHANCEMENT
|
||||||
|
* better error handling in entrypoint script
|
||||||
|
* add env variable for custom DB port
|
55
Dockerfile
55
Dockerfile
@ -1,55 +0,0 @@
|
|||||||
FROM thegeeklab/nginx:latest@sha256:72ffd57b6b89013f6b4c6a8a97728120df1dfac0d66b2164e0aacba21ee87380
|
|
||||||
|
|
||||||
LABEL maintainer="Robert Kaussow <mail@thegeeklab.de>"
|
|
||||||
LABEL org.opencontainers.image.authors="Robert Kaussow <mail@thegeeklab.de>"
|
|
||||||
LABEL org.opencontainers.image.title="FreshRSS"
|
|
||||||
LABEL org.opencontainers.image.url="https://gitea.rknet.org/docker/freshrss"
|
|
||||||
LABEL org.opencontainers.image.source="https://gitea.rknet.org/docker/freshrss"
|
|
||||||
LABEL org.opencontainers.image.documentation="https://gitea.rknet.org/docker/freshrss"
|
|
||||||
|
|
||||||
ARG BUILD_VERSION
|
|
||||||
|
|
||||||
# renovate: datasource=github-releases depName=FreshRSS/FreshRSS
|
|
||||||
ENV FRESHRSS_VERSION="${BUILD_VERSION:-1.21.0}"
|
|
||||||
|
|
||||||
ADD overlay/ /
|
|
||||||
|
|
||||||
RUN apk --update add --virtual .build-deps tar curl && \
|
|
||||||
apk --update add php81 php81-curl php81-fpm php81-gmp php81-intl php81-mbstring php81-xml \
|
|
||||||
php81-zip php81-ctype php81-dom php81-fileinfo php81-iconv php81-json php81-opcache php81-phar \
|
|
||||||
php81-session php81-simplexml php81-xmlreader php81-xmlwriter php81-tokenizer php81-zlib \
|
|
||||||
php81-openssl php81-pdo_sqlite php81-pdo_mysql php81-pdo_pgsql && \
|
|
||||||
rm -rf /var/www/localhost && \
|
|
||||||
rm -f /etc/php81/php-fpm.d/www.conf && \
|
|
||||||
mkdir -p /var/www/app && \
|
|
||||||
mkdir /var/www/.postgresql && \
|
|
||||||
FRESHRSS_VERSION="${FRESHRSS_VERSION##v}" && \
|
|
||||||
echo "Installing FreshRSS version '${FRESHRSS_VERSION}' ..." && \
|
|
||||||
curl -SsfL "https://github.com/FreshRSS/FreshRSS/archive/${FRESHRSS_VERSION}.tar.gz" | \
|
|
||||||
tar xz -C /var/www/app/ -X /.tarignore --strip-components=1 && \
|
|
||||||
curl -SsfL -o /etc/php81/browscap.ini https://browscap.org/stream?q=Lite_PHP_BrowsCapINI && \
|
|
||||||
apk del .build-deps && \
|
|
||||||
rm -rf /var/cache/apk/* && \
|
|
||||||
rm -rf /tmp/* && \
|
|
||||||
mkdir -p /var/run/php && \
|
|
||||||
chown -R nginx /var/run/php && \
|
|
||||||
mkdir -p /var/lib/php/tmp_upload && \
|
|
||||||
mkdir -p /var/lib/php/soap_cache && \
|
|
||||||
mkdir -p /var/lib/php/session && \
|
|
||||||
chown -R nginx /var/lib/php && \
|
|
||||||
chown nginx /etc/php81/php.ini && \
|
|
||||||
chown -R nginx:nginx /var/www/.postgresql && \
|
|
||||||
chown -R nginx:nginx /var/www/app
|
|
||||||
|
|
||||||
VOLUME /var/www/app/extensions
|
|
||||||
VOLUME /var/www/app/data
|
|
||||||
|
|
||||||
EXPOSE 8080
|
|
||||||
|
|
||||||
USER nginx
|
|
||||||
|
|
||||||
STOPSIGNAL SIGTERM
|
|
||||||
|
|
||||||
ENTRYPOINT ["/usr/local/bin/entrypoint"]
|
|
||||||
WORKDIR /var/www/app
|
|
||||||
CMD []
|
|
51
Dockerfile.linux.amd64
Normal file
51
Dockerfile.linux.amd64
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
FROM xoxys/nginx:latest
|
||||||
|
|
||||||
|
LABEL maintainer="Robert Kaussow <mail@geeklabor.de>" \
|
||||||
|
org.label-schema.name="FreshRSS" \
|
||||||
|
org.label-schema.version="1.2" \
|
||||||
|
org.label-schema.vendor="Robert Kaussow" \
|
||||||
|
org.label-schema.schema-version="1.0"
|
||||||
|
|
||||||
|
ARG FRESHRSS_VERSION=master
|
||||||
|
ARG FRESHRSS_TARBALL=https://github.com/FreshRSS/FreshRSS/archive/${FRESHRSS_VERSION}.tar.gz
|
||||||
|
|
||||||
|
RUN apk --update add --virtual .build-deps tar curl && \
|
||||||
|
apk --update add php7 php7-curl php7-fpm php7-gmp php7-intl php7-mbstring php7-xml \
|
||||||
|
php7-zip php7-ctype php7-dom php7-fileinfo php7-iconv php7-json php7-session \
|
||||||
|
php7-simplexml php7-xmlreader php7-zlib php7-pdo_sqlite php7-pdo_mysql\
|
||||||
|
php7-pdo_pgsql && \
|
||||||
|
rm -rf /var/www/localhost && \
|
||||||
|
rm -f /etc/php7/php-fpm.d/www.conf && \
|
||||||
|
mkdir -p /var/www/app && \
|
||||||
|
mkdir /var/www/.postgresql && \
|
||||||
|
curl -SsL ${FRESHRSS_TARBALL} | tar xz -C /var/www/app/ --strip-components=1 && \
|
||||||
|
curl -SsL -o /etc/php7/browscap.ini https://browscap.org/stream?q=Lite_PHP_BrowsCapINI && \
|
||||||
|
apk del .build-deps && \
|
||||||
|
rm -rf /var/cache/apk/* && \
|
||||||
|
rm -rf /tmp/* && \
|
||||||
|
rm -rf /var/www/app/CHANGELOG.md /var/www/app/CONTRIBUTING.md /var/www/app/CREDITS.md /var/www/app/Docker /var/www/app/README.* && \
|
||||||
|
mkdir -p /var/run/php && \
|
||||||
|
chown -R nginx /var/run/php && \
|
||||||
|
mkdir -p /var/lib/php/tmp_upload && \
|
||||||
|
mkdir -p /var/lib/php/soap_cache && \
|
||||||
|
mkdir -p /var/lib/php/session && \
|
||||||
|
chown -R nginx /var/lib/php && \
|
||||||
|
chown nginx /etc/php7/php.ini && \
|
||||||
|
chown -R nginx:nginx /var/www/.postgresql && \
|
||||||
|
chown -R nginx:nginx /var/www/app
|
||||||
|
|
||||||
|
ADD overlay/ /
|
||||||
|
|
||||||
|
VOLUME /var/www/app/extensions
|
||||||
|
VOLUME /var/www/app/data
|
||||||
|
|
||||||
|
EXPOSE 8080
|
||||||
|
|
||||||
|
USER nginx
|
||||||
|
|
||||||
|
STOPSIGNAL SIGTERM
|
||||||
|
|
||||||
|
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
|
||||||
|
HEALTHCHECK --interval=30s --timeout=5s --retries=3 CMD /usr/local/bin/healthcheck.sh
|
||||||
|
WORKDIR /var/www/app
|
||||||
|
CMD []
|
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2022 Robert Kaussow <mail@thegeeklab.de>
|
Copyright (c) 2019 Robert Kaussow
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
57
README.md
57
README.md
@ -1,14 +1,9 @@
|
|||||||
# freshrss
|
# [freshrss](https://gitea.rknet.org/docker/freshrss)
|
||||||
|
|
||||||
Custom image for FreshRSS feed aggregator
|
[![Build Status](https://drone.rknet.org/api/badges/docker/freshrss/status.svg)](https://drone.rknet.org/docker/freshrss/)
|
||||||
|
[![Microbadger](https://images.microbadger.com/badges/image/xoxys/freshrss.svg)](https://microbadger.com/images/xoxys/freshrss "Get your own image badge on microbadger.com")
|
||||||
|
|
||||||
[![Build Status](https://img.shields.io/drone/build/docker/freshrss?logo=drone&server=https%3A%2F%2Fdrone.rknet.org)](https://drone.rknet.org/docker/freshrss)
|
FreshRSS is a self-hosted RSS feed aggregator. It is lightweight, easy to work with, powerful, and customizable.
|
||||||
[![Docker Hub](https://img.shields.io/badge/dockerhub-latest-blue.svg?logo=docker&logoColor=white)](https://hub.docker.com/r/thegeeklab/freshrss)
|
|
||||||
[![Quay.io](https://img.shields.io/badge/quay-latest-blue.svg?logo=docker&logoColor=white)](https://quay.io/repository/thegeeklab/freshrss)
|
|
||||||
[![Source: Gitea](https://img.shields.io/badge/source-gitea-blue.svg?logo=gitea&logoColor=white)](https://gitea.rknet.org/docker/freshrss)
|
|
||||||
[![License: MIT](https://img.shields.io/badge/license-MIT-blue.svg)](https://gitea.rknet.org/docker/freshrss/src/branch/main/LICENSE)
|
|
||||||
|
|
||||||
Custom rootless Docker image for FreshRSS, a self-hosted RSS feed aggregator. It is lightweight, easy to work with, powerful, and customizable.
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
@ -22,16 +17,42 @@ Here are some example snippets to help you get started creating a container. Thi
|
|||||||
docker create \
|
docker create \
|
||||||
--name=freshrss \
|
--name=freshrss \
|
||||||
-p 80:8080 \
|
-p 80:8080 \
|
||||||
thegeeklab/freshrss
|
xoxys/freshrss
|
||||||
```
|
```
|
||||||
|
|
||||||
### Docker Compose
|
### Docker Compose
|
||||||
|
|
||||||
Please take a look at the [example](https://gitea.rknet.org/docker/freshrss/src/branch/main/docker-compose.yml) compose file from the git repo.
|
Compatible with docker-compose v2 schemas.
|
||||||
|
|
||||||
|
```Yaml
|
||||||
|
---
|
||||||
|
version: '2.1'
|
||||||
|
|
||||||
|
services:
|
||||||
|
freshrss:
|
||||||
|
container_name: freshrss
|
||||||
|
image: xoxys/freshrss:latest
|
||||||
|
ports:
|
||||||
|
- "80:8080"
|
||||||
|
volumes:
|
||||||
|
- freshrss_data:/var/www/app/data
|
||||||
|
- freshrss_extensions:/var/www/app/extensions
|
||||||
|
environment:
|
||||||
|
FRESHRSS_DEFAULT_USER: admin
|
||||||
|
FRESHRSS_DEFAULT_PASSWORD: freshrss
|
||||||
|
FRESHRSS_API_ENABLED: "true"
|
||||||
|
FRESHRSS_SALT: "38fd29ac5878c270bbfc3599723cd479d48c6c58"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
freshrss_data:
|
||||||
|
driver: local
|
||||||
|
freshrss_extensions:
|
||||||
|
driver: local
|
||||||
|
```
|
||||||
|
|
||||||
## Environment variables
|
## Environment variables
|
||||||
|
|
||||||
### FreshRSS
|
### freshrss
|
||||||
|
|
||||||
> **WARNING**: Don't change any system settings through the web UI! These changes will be overwritten at EVERY container startup. Use the provided environment variables instead.
|
> **WARNING**: Don't change any system settings through the web UI! These changes will be overwritten at EVERY container startup. Use the provided environment variables instead.
|
||||||
|
|
||||||
@ -48,6 +69,7 @@ FRESHRSS_BASE_URL="http://localhost/"
|
|||||||
FRESHRSS_LANGUAGE="en"
|
FRESHRSS_LANGUAGE="en"
|
||||||
FRESHRSS_TITLE="FreshRSS"
|
FRESHRSS_TITLE="FreshRSS"
|
||||||
FRESHRSS_META_DESCRIPTION=
|
FRESHRSS_META_DESCRIPTION=
|
||||||
|
FRESHRSS_DEFAULT_USER="_"
|
||||||
FRESHRSS_ALLOW_ANONYMOUS="false"
|
FRESHRSS_ALLOW_ANONYMOUS="false"
|
||||||
FRESHRSS_ALLOW_ANONYMOUS_REFRESH="false"
|
FRESHRSS_ALLOW_ANONYMOUS_REFRESH="false"
|
||||||
FRESHRSS_AUTH_TYPE="form"
|
FRESHRSS_AUTH_TYPE="form"
|
||||||
@ -60,6 +82,7 @@ FRESHRSS_ALLOW_REFERRER="false"
|
|||||||
FRESHRSS_LIMITS_COOKIE_DURATION="2592000"
|
FRESHRSS_LIMITS_COOKIE_DURATION="2592000"
|
||||||
FRESHRSS_LIMITS_CACHE_DURATION="800"
|
FRESHRSS_LIMITS_CACHE_DURATION="800"
|
||||||
FRESHRSS_LIMITS_TIMEOUT="15"
|
FRESHRSS_LIMITS_TIMEOUT="15"
|
||||||
|
FRESHRSS_LIMITS_MAX_INACTIVITY="10800"
|
||||||
FRESHRSS_LIMITS_MAX_FEEDS="16384"
|
FRESHRSS_LIMITS_MAX_FEEDS="16384"
|
||||||
FRESHRSS_LIMITS_MAX_CATEGORIES="16384"
|
FRESHRSS_LIMITS_MAX_CATEGORIES="16384"
|
||||||
FRESHRSS_LIMITS_MAX_REGISTRATIONS="1"
|
FRESHRSS_LIMITS_MAX_REGISTRATIONS="1"
|
||||||
@ -79,8 +102,6 @@ FRESHRSS_DB_BASE=
|
|||||||
FRESHRSS_DB_PREFIX="freshrss_"
|
FRESHRSS_DB_PREFIX="freshrss_"
|
||||||
## comma-seperated string, extensions must be installed!
|
## comma-seperated string, extensions must be installed!
|
||||||
FRESHRSS_EXTENSIONS_ENABLED="Tumblr-GDPR"
|
FRESHRSS_EXTENSIONS_ENABLED="Tumblr-GDPR"
|
||||||
## comma-seperated string
|
|
||||||
FRESHRSS_TRUSTED_SOURCES=127.0.0.0/8,::1/128
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### PHP
|
### PHP
|
||||||
@ -110,6 +131,10 @@ PHP_DATE_TIMEZONE=Europe/Berlin
|
|||||||
PHP_SQL_SAFE_MODE=On
|
PHP_SQL_SAFE_MODE=On
|
||||||
```
|
```
|
||||||
|
|
||||||
## License
|
### License
|
||||||
|
|
||||||
This project is licensed under the MIT License - see the [LICENSE](https://gitea.rknet.org/docker/freshrss/src/branch/main/LICENSE) file for details.
|
This project is licensed under the MIT License - see the [LICENSE](https://gitea.rknet.org/docker/freshrss/src/branch/master/LICENSE) file for details.
|
||||||
|
|
||||||
|
### Maintainers and Contributors
|
||||||
|
|
||||||
|
[Robert Kaussow](https://gitea.rknet.org/xoxys)
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
---
|
---
|
||||||
version: "3"
|
version: '2.1'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
freshrss:
|
freshrss:
|
||||||
container_name: freshrss
|
container_name: freshrss
|
||||||
image: thegeeklab/freshrss
|
image: xoxys/freshrss:latest
|
||||||
ports:
|
ports:
|
||||||
- "80:8080"
|
- "80:8080"
|
||||||
volumes:
|
volumes:
|
||||||
|
15
manifest.tmpl
Normal file
15
manifest.tmpl
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
image: xoxys/freshrss:{{#if build.tag}}{{trimPrefix "v" build.tag}}{{else}}latest{{/if}}
|
||||||
|
{{#if build.tags}}
|
||||||
|
tags:
|
||||||
|
{{#each build.tags}}
|
||||||
|
{{#if this}}
|
||||||
|
- {{trimPrefix "v" this}}
|
||||||
|
- {{trimPrefix "v" this}}-linux-amd64
|
||||||
|
{{/if}}
|
||||||
|
{{/each}}
|
||||||
|
{{/if}}
|
||||||
|
manifests:
|
||||||
|
- image: xoxys/freshrss:{{#if build.tag}}{{trimPrefix "v" build.tag}}-{{/if}}linux-amd64
|
||||||
|
platform:
|
||||||
|
architecture: amd64
|
||||||
|
os: linux
|
@ -1,9 +0,0 @@
|
|||||||
CHANGELOG.md
|
|
||||||
CONTRIBUTING.md
|
|
||||||
CREDITS.md
|
|
||||||
Docker
|
|
||||||
docs
|
|
||||||
tests
|
|
||||||
README*
|
|
||||||
Make*
|
|
||||||
.[!.]*
|
|
@ -1,2 +1,2 @@
|
|||||||
SHELL=/bin/sh
|
SHELL=/bin/sh
|
||||||
*/15 * * * * /usr/bin/php -f /var/www/app/app/actualize_script.php >/tmp/freshrss_sync.log 2>&1
|
*/15 * * * * /usr/bin/php -f /var/www/app/app/actualize_script.php >/dev/null 2>&1
|
||||||
|
@ -7,47 +7,47 @@ return array(
|
|||||||
'language' => '{{ getenv "FRESHRSS_LANGUAGE" "en" }}',
|
'language' => '{{ getenv "FRESHRSS_LANGUAGE" "en" }}',
|
||||||
'title' => '{{ getenv "FRESHRSS_TITLE" "FreshRSS" }}',
|
'title' => '{{ getenv "FRESHRSS_TITLE" "FreshRSS" }}',
|
||||||
'meta_description' => '{{ getenv "FRESHRSS_META_DESCRIPTION" }}',
|
'meta_description' => '{{ getenv "FRESHRSS_META_DESCRIPTION" }}',
|
||||||
'default_user' => '{{ getenv "FRESHRSS_DEFAULT_USER" "admin" }}',
|
'default_user' => '{{ getenv "FRESHRSS_DEFAULT_USER" "_" }}',
|
||||||
'allow_anonymous' => {{ getenv "FRESHRSS_ALLOW_ANONYMOUS" "false" | conv.ToBool }},
|
'allow_anonymous' => {{ getenv "FRESHRSS_ALLOW_ANONYMOUS" "false" }},
|
||||||
'allow_anonymous_refresh' => {{ getenv "FRESHRSS_ALLOW_ANONYMOUS_REFRESH" "false" | conv.ToBool }},
|
'allow_anonymous_refresh' => {{ getenv "FRESHRSS_ALLOW_ANONYMOUS_REFRESH" "false" }},
|
||||||
'auth_type' => '{{ getenv "FRESHRSS_AUTH_TYPE" "form" }}',
|
'auth_type' => '{{ getenv "FRESHRSS_AUTH_TYPE" "form" }}',
|
||||||
'api_enabled' => {{ getenv "FRESHRSS_API_ENABLED" "false" | conv.ToBool }},
|
'api_enabled' => {{ getenv "FRESHRSS_API_ENABLED" "false" }},
|
||||||
'unsafe_autologin_enabled' => {{ getenv "FRESHRSS_UNSAFE_AUTOLOGIN_ENABLED" "false" | conv.ToBool }},
|
'unsafe_autologin_enabled' => {{ getenv "FRESHRSS_UNSAFE_AUTOLOGIN_ENABLED" "false" }},
|
||||||
'simplepie_syslog_enabled' => {{ getenv "FRESHRSS_SIMPLEPIE_SYSLOG_ENABLED" "true" | conv.ToBool }},
|
'simplepie_syslog_enabled' => {{ getenv "FRESHRSS_SIMPLEPIE_SYSLOG_ENABLED" "true" }},
|
||||||
'pubsubhubbub_enabled' => {{ getenv "FRESHRSS_PUBSUBHUBBUB_ENABLED" "false" | conv.ToBool }},
|
'pubsubhubbub_enabled' => {{ getenv "FRESHRSS_PUBSUBHUBBUB_ENABLED" "false" }},
|
||||||
'allow_robots' => {{ getenv "FRESHRSS_ALLOW_ROBOTS" "false" | conv.ToBool }},
|
'allow_robots' => {{ getenv "FRESHRSS_ALLOW_ROBOTS" "false" }},
|
||||||
'allow_referrer' => {{ getenv "FRESHRSS_ALLOW_REFERRER" "false" | conv.ToBool }},
|
'allow_referrer' => {{ getenv "FRESHRSS_ALLOW_REFERRER" "false" }},
|
||||||
|
|
||||||
'limits' => array(
|
'limits' => array(
|
||||||
'cookie_duration' => {{ getenv "FRESHRSS_LIMITS_COOKIE_DURATION" "2592000" }},
|
'cookie_duration' => {{ getenv "FRESHRSS_LIMITS_COOKIE_DURATION" "2592000" }},
|
||||||
'cache_duration' => {{ getenv "FRESHRSS_LIMITS_CACHE_DURATION" "800" }},
|
'cache_duration' => {{ getenv "FRESHRSS_LIMITS_CACHE_DURATION" "800" }},
|
||||||
'timeout' => {{ getenv "FRESHRSS_LIMITS_TIMEOUT" "15" }},
|
'timeout' => {{ getenv "FRESHRSS_LIMITS_TIMEOUT" "15" }},
|
||||||
'max_inactivity' => PHP_INT_MAX,
|
'max_inactivity' => {{ getenv "FRESHRSS_LIMITS_MAX_INACTIVITY" "10800" }},
|
||||||
'max_feeds' => {{ getenv "FRESHRSS_LIMITS_MAX_FEEDS" "16384" }},
|
'max_feeds' => {{ getenv "FRESHRSS_LIMITS_MAX_FEEDS" "16384" }},
|
||||||
'max_categories' => {{ getenv "FRESHRSS_LIMITS_MAX_CATEGORIES" "16384" }},
|
'max_categories' => {{ getenv "FRESHRSS_LIMITS_MAX_CATEGORIES" "16384" }},
|
||||||
'max_registrations' => {{ getenv "FRESHRSS_LIMITS_MAX_REGISTRATIONS" "1" }},
|
'max_registrations' => {{ getenv "FRESHRSS_LIMITS_MAX_REGISTRATIONS" "1" }},
|
||||||
),
|
),
|
||||||
|
|
||||||
'curl_options' => array(
|
'curl_options' => array(
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_SSL_VERIFYHOST" "true" | conv.ToBool) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_SSL_VERIFYHOST" "true")) }}
|
||||||
CURLOPT_SSL_VERIFYHOST => {{ getenv "FRESHRSS_CURLOPT_SSL_VERIFYHOST" }},
|
CURLOPT_SSL_VERIFYHOST => {{ getenv "FRESHRSS_CURLOPT_SSL_VERIFYHOST" }},
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_SSL_VERIFYPEER" "true" | conv.ToBool) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_SSL_VERIFYPEER" "true")) }}
|
||||||
CURLOPT_SSL_VERIFYPEER => {{ getenv "FRESHRSS_CURLOPT_SSL_VERIFYPEER" }},
|
CURLOPT_SSL_VERIFYPEER => {{ getenv "FRESHRSS_CURLOPT_SSL_VERIFYPEER" }},
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_PROXYTYPE" "true" | conv.ToBool) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_PROXYTYPE" "true")) }}
|
||||||
CURLOPT_PROXYTYPE => {{ getenv "FRESHRSS_CURLOPT_PROXYTYPE" }},
|
CURLOPT_PROXYTYPE => {{ getenv "FRESHRSS_CURLOPT_PROXYTYPE" }},
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_PROXY" "true" | conv.ToBool ) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_PROXY" "true" )) }}
|
||||||
CURLOPT_PROXY => '{{ getenv "FRESHRSS_CURLOPT_PROXY" }}',
|
CURLOPT_PROXY => '{{ getenv "FRESHRSS_CURLOPT_PROXY" }}',
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_PROXYPORT" "true" | conv.ToBool ) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_PROXYPORT" "true" )) }}
|
||||||
CURLOPT_PROXYPORT => {{ getenv "FRESHRSS_CURLOPT_PROXYPORT" }},
|
CURLOPT_PROXYPORT => {{ getenv "FRESHRSS_CURLOPT_PROXYPORT" }},
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_PROXYAUTH" "true" | conv.ToBool ) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_PROXYAUTH" "true" )) }}
|
||||||
CURLOPT_PROXYAUTH => {{ getenv "FRESHRSS_CURLOPT_PROXYAUTH" }},
|
CURLOPT_PROXYAUTH => {{ getenv "FRESHRSS_CURLOPT_PROXYAUTH" }},
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- if not (getenv "FRESHRSS_CURLOPT_PROXYUSERPWD" "true" | conv.ToBool ) }}
|
{{- if not (bool (getenv "FRESHRSS_CURLOPT_PROXYUSERPWD" "true" )) }}
|
||||||
CURLOPT_PROXYUSERPWD => '{{ getenv "FRESHRSS_CURLOPT_PROXYUSERPWD" }}',
|
CURLOPT_PROXYUSERPWD => '{{ getenv "FRESHRSS_CURLOPT_PROXYUSERPWD" }}',
|
||||||
{{- end }}
|
{{- end }}
|
||||||
),
|
),
|
||||||
@ -71,10 +71,4 @@ return array(
|
|||||||
),
|
),
|
||||||
|
|
||||||
'disable_update' => true,
|
'disable_update' => true,
|
||||||
|
|
||||||
'trusted_sources' => [
|
|
||||||
{{- range (getenv "FRESHRSS_TRUSTED_SOURCES" "127.0.0.0/8,::1/128" | strings.Split ",") }}
|
|
||||||
'{{ . | strings.TrimSpace }}',
|
|
||||||
{{- end }}
|
|
||||||
]
|
|
||||||
);
|
);
|
||||||
|
@ -1,15 +1,15 @@
|
|||||||
<?php
|
<?php
|
||||||
define('FRESHRSS_USERAGENT', 'FreshRSS/' . FRESHRSS_VERSION . ' (' . PHP_OS . '; ' . FRESHRSS_WEBSITE . ')');
|
safe_define('FRESHRSS_USERAGENT', 'FreshRSS/' . FRESHRSS_VERSION . ' (' . PHP_OS . '; ' . FRESHRSS_WEBSITE . ')');
|
||||||
define('PHP_COMPRESSION', false);
|
safe_define('PHP_COMPRESSION', false);
|
||||||
define('COPY_SYSLOG_TO_STDERR', true);
|
safe_define('COPY_SYSLOG_TO_STDERR', true);
|
||||||
define('MAX_LOG_SIZE', 1048576);
|
safe_define('MAX_LOG_SIZE', 1048576);
|
||||||
define('DATA_PATH', FRESHRSS_PATH . '/data');
|
safe_define('DATA_PATH', FRESHRSS_PATH . '/data');
|
||||||
|
|
||||||
define('UPDATE_FILENAME', DATA_PATH . '/update.php');
|
safe_define('UPDATE_FILENAME', DATA_PATH . '/update.php');
|
||||||
define('USERS_PATH', DATA_PATH . '/users');
|
safe_define('USERS_PATH', DATA_PATH . '/users');
|
||||||
define('ADMIN_LOG', USERS_PATH . '/_/log.txt');
|
safe_define('ADMIN_LOG', USERS_PATH . '/_/log.txt');
|
||||||
define('API_LOG', USERS_PATH . '/_/log_api.txt');
|
safe_define('API_LOG', USERS_PATH . '/_/log_api.txt');
|
||||||
define('CACHE_PATH', DATA_PATH . '/cache');
|
safe_define('CACHE_PATH', DATA_PATH . '/cache');
|
||||||
define('PSHB_LOG', USERS_PATH . '/_/log_pshb.txt');
|
safe_define('PSHB_LOG', USERS_PATH . '/_/log_pshb.txt');
|
||||||
define('PSHB_PATH', DATA_PATH . '/PubSubHubbub');
|
safe_define('PSHB_PATH', DATA_PATH . '/PubSubHubbub');
|
||||||
define('TMP_PATH', CACHE_PATH);
|
safe_define('TMP_PATH', CACHE_PATH);
|
||||||
|
@ -19,9 +19,9 @@ implicit_flush = Off
|
|||||||
unserialize_callback_func =
|
unserialize_callback_func =
|
||||||
serialize_precision = 17
|
serialize_precision = 17
|
||||||
|
|
||||||
open_basedir = "/var/www/app:/var/lib/php/tmp_upload:/var/lib/php/session:/var/lib/php/soap_cache:/tmp"
|
open_basedir = "/var/www/app:/var/lib/php/tmp_upload:/var/lib/php/session:/var/lib/php/soap_cache"
|
||||||
|
|
||||||
disable_functions = system, exec, shell_exec, phpinfo, show_source, highlight_file, popen, proc_open, fopen_with_path, dbmopen, dbase_open, move_uploaded_file, chmod, filepro, filepro_rowcount, filepro_retrieve, posix_mkfifo
|
disable_functions = system, exec, shell_exec, phpinfo, show_source, highlight_file, popen, proc_open, fopen_with_path, dbmopen, dbase_open, move_uploaded_file, chmod, rename, filepro, filepro_rowcount, filepro_retrieve, posix_mkfifo
|
||||||
disable_classes =
|
disable_classes =
|
||||||
|
|
||||||
;highlight.string = #DD0000
|
;highlight.string = #DD0000
|
||||||
@ -86,12 +86,12 @@ default_charset = "UTF-8"
|
|||||||
;input_encoding =
|
;input_encoding =
|
||||||
;output_encoding =
|
;output_encoding =
|
||||||
|
|
||||||
;include_path = ".:/php81/includes"
|
;include_path = ".:/php7/includes"
|
||||||
|
|
||||||
doc_root =
|
doc_root =
|
||||||
user_dir =
|
user_dir =
|
||||||
|
|
||||||
extension_dir = "/usr/lib/php81/modules"
|
extension_dir = "/usr/lib/php7/modules"
|
||||||
;sys_temp_dir = "/tmp"
|
;sys_temp_dir = "/tmp"
|
||||||
enable_dl = Off
|
enable_dl = Off
|
||||||
|
|
||||||
@ -250,7 +250,7 @@ pgsql.log_notice = 0
|
|||||||
bcmath.scale = 0
|
bcmath.scale = 0
|
||||||
|
|
||||||
[browscap]
|
[browscap]
|
||||||
browscap = /etc/php81/browscap.ini
|
browscap = /etc/php7/browscap.ini
|
||||||
|
|
||||||
[Session]
|
[Session]
|
||||||
session.save_handler = files
|
session.save_handler = files
|
||||||
@ -327,7 +327,7 @@ zend.assertions = -1
|
|||||||
;exif.decode_jis_intel = JIS
|
;exif.decode_jis_intel = JIS
|
||||||
|
|
||||||
[Tidy]
|
[Tidy]
|
||||||
;tidy.default_config = /usr/local/lib/php81/default.tcfg
|
;tidy.default_config = /usr/local/lib/php7/default.tcfg
|
||||||
tidy.clean_output = Off
|
tidy.clean_output = Off
|
||||||
|
|
||||||
[soap]
|
[soap]
|
||||||
|
@ -1,61 +0,0 @@
|
|||||||
#!/usr/bin/env sh
|
|
||||||
|
|
||||||
# shellcheck disable=SC1091
|
|
||||||
. /usr/local/lib/log.sh
|
|
||||||
|
|
||||||
/usr/local/bin/gomplate -o /etc/php81/php.ini -f /etc/templates/php.ini.tmpl
|
|
||||||
/usr/local/bin/gomplate -o /var/www/app/constants.local.php -f /etc/templates/constants.local.php.tmpl
|
|
||||||
|
|
||||||
if [ -n "${FRESHRSS_POSTGRES_SSL_ROOTCERT}" ] && [ ! -f "/var/www/.postgresql/root.crt" ]; then
|
|
||||||
ln -s "${FRESHRSS_POSTGRES_SSL_ROOTCERT}" /var/www/.postgresql/root.crt
|
|
||||||
fi
|
|
||||||
|
|
||||||
log_info "Prepare FreshRSS"
|
|
||||||
/usr/bin/php -f ./cli/prepare.php >/dev/null 2>&1
|
|
||||||
|
|
||||||
ERROR=$(/usr/bin/php -f ./cli/do-install.php -- --api_enabled \
|
|
||||||
--base_url "${FRESHRSS_BASE_URL:-http://localhost/}" \
|
|
||||||
--db-base "${FRESHRSS_DB_BASE}" \
|
|
||||||
--db-host "${FRESHRSS_DB_HOST:-localhost}" \
|
|
||||||
--db-password "${FRESHRSS_DB_PASSWORD}" \
|
|
||||||
--db-type "${FRESHRSS_DB_TYPE:-sqlite}" \
|
|
||||||
--db-user "${FRESHRSS_DB_USER}" \
|
|
||||||
--default_user "${FRESHRSS_DEFAULT_USER:-admin}" \
|
|
||||||
--language "${FRESHRSS_LANGUAGE:-en}" \
|
|
||||||
2>&1)
|
|
||||||
EXITCODE=$?
|
|
||||||
|
|
||||||
if [ $EXITCODE -eq 3 ]; then
|
|
||||||
log_info "FreshRSS already installed, skipped"
|
|
||||||
elif [ $EXITCODE -eq 0 ]; then
|
|
||||||
log_info "FreshRSS successfully installed"
|
|
||||||
else
|
|
||||||
log_error "FreshRSS error during installation: ${ERROR}"
|
|
||||||
exit $EXITCODE
|
|
||||||
fi
|
|
||||||
|
|
||||||
log_info "Ensure default user exists"
|
|
||||||
ERROR=$(/usr/bin/php ./cli/create-user.php \
|
|
||||||
--user "${FRESHRSS_DEFAULT_USER:-admin}" \
|
|
||||||
--password "${FRESHRSS_DEFAULT_PASSWORD:-freshrss}" \
|
|
||||||
--language "${FRESHRSS_LANGUAGE:-en}" \
|
|
||||||
2>&1)
|
|
||||||
EXITCODE=$?
|
|
||||||
|
|
||||||
if [ $EXITCODE -eq 3 ]; then
|
|
||||||
log_info "FreshRSS user already exists, skipped"
|
|
||||||
elif [ $EXITCODE -eq 0 ]; then
|
|
||||||
log_info "FreshRSS user successfully created"
|
|
||||||
./cli/list-users.php | xargs -n1 ./cli/actualize-user.php --user "${FRESHRSS_DEFAULT_USER:-admin}"
|
|
||||||
./cli/access-permissions.sh
|
|
||||||
else
|
|
||||||
log_error "FreshRSS error during the creation of a user: ${ERROR}"
|
|
||||||
exit $EXITCODE
|
|
||||||
fi
|
|
||||||
|
|
||||||
/usr/local/bin/gomplate -o /var/www/app/data/config.php -f /etc/templates/config.php.tmpl
|
|
||||||
|
|
||||||
log_info "Start FreshRSS Server\n"
|
|
||||||
supercronic /etc/crontabs/nginx &
|
|
||||||
php-fpm81 -F &
|
|
||||||
exec nginx -g "daemon off;"
|
|
39
overlay/usr/local/bin/entrypoint.sh
Executable file
39
overlay/usr/local/bin/entrypoint.sh
Executable file
@ -0,0 +1,39 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
/usr/local/bin/gomplate -V -o /etc/php7/php.ini -f /etc/templates/php.ini.tmpl
|
||||||
|
/usr/local/bin/gomplate -V -o /var/www/app/data/config.php -f /etc/templates/config.php.tmpl
|
||||||
|
/usr/local/bin/gomplate -V -o /var/www/app/constants.local.php -f /etc/templates/constants.local.php.tmpl
|
||||||
|
|
||||||
|
if [ "${FRESHRSS_POSTGRES_SSL_ROOTCERT}" ] && [ ! -f "/var/www/.postgresql/root.crt" ]; then
|
||||||
|
ln -s "${FRESHRSS_POSTGRES_SSL_ROOTCERT}" /var/www/.postgresql/root.crt
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf "\nPrepare FreshRSS...\n"
|
||||||
|
PREP=$(/usr/bin/php -f ./cli/prepare.php)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo $PREP
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${FRESHRSS_DEFAULT_USER}" ]; then
|
||||||
|
printf "\nEnsure default user exists...\n"
|
||||||
|
UCREATE=$(/usr/bin/php ./cli/create-user.php --user "$FRESHRSS_DEFAULT_USER" --password "$FRESHRSS_DEFAULT_PASSWORD" 2>&1)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
case "$UCREATE" in
|
||||||
|
*"username already taken"*) ;;
|
||||||
|
*)
|
||||||
|
echo $UCREATE
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
echo "Result: success"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "/var/www/app/data/do-install.txt" ]; then
|
||||||
|
rm -rf /var/www/app/data/do-install.txt
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec supercronic -split-logs /etc/crontabs/nginx 1> /dev/null &
|
||||||
|
exec php-fpm7 -F &
|
||||||
|
exec nginx -g "daemon off;"
|
@ -1,12 +0,0 @@
|
|||||||
#!/usr/bin/env sh
|
|
||||||
|
|
||||||
# shellcheck disable=SC3040
|
|
||||||
set -eo pipefail
|
|
||||||
|
|
||||||
if [ "$(gomplate -i '{{ getenv "FRESHRSS_API_ENABLED" "false" | conv.ToBool }}')" = "true" ]; then
|
|
||||||
(php -r "readfile('http://127.0.0.1:8080/api/fever.php');" | grep -q 'api_version') || exit 1
|
|
||||||
else
|
|
||||||
(php -r "readfile('http://127.0.0.1:8080/i/');" | grep -q 'jsonVars') || exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
exit 0
|
|
3
overlay/usr/local/bin/healthcheck.sh
Executable file
3
overlay/usr/local/bin/healthcheck.sh
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
(php -r "readfile('http://localhost:8080/i/');" | grep -q 'jsonVars') || exit 1
|
@ -1,4 +0,0 @@
|
|||||||
{
|
|
||||||
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
|
||||||
"extends": ["github>thegeeklab/renovate-presets:docker"]
|
|
||||||
}
|
|
Reference in New Issue
Block a user