Compare commits
5 Commits
2.6.2/mast
...
pkg/dev/eo
Author | SHA1 | Date | |
---|---|---|---|
a5e06df596 | |||
94fb92496f | |||
272f206d85 | |||
a68203c7e5 | |||
16332a190f |
1
debian/compat
vendored
Normal file
1
debian/compat
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
9
|
16
debian/control
vendored
Normal file
16
debian/control
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
Source: eole-gitea
|
||||||
|
Section: web
|
||||||
|
Priority: optional
|
||||||
|
Maintainer: Cadoles <eole@ac-dijon.fr>
|
||||||
|
Build-Depends: debhelper (>= 9)
|
||||||
|
Standards-Version: 3.9.3
|
||||||
|
Homepage: https://forge.cadoles.com/Cadoles/eole-gitea
|
||||||
|
Vcs-Git: https://forge.cadoles.com/Cadoles/eole-gitea.git
|
||||||
|
Vcs-Browser: https://forge.cadoles.com/Cadoles/eole-redis
|
||||||
|
|
||||||
|
Package: eole-gitea
|
||||||
|
Architecture: all
|
||||||
|
Depends: ${misc:Depends}, git-core, eole-db, eole-mysql
|
||||||
|
Description: Dictionnaires et templates pour la configuration d'un serveur Gitea, testée uniquement avec eolebase
|
||||||
|
.
|
||||||
|
Pour toute information complémentaire, veuillez vous rendre sur la forge Cadoles.
|
44
debian/copyright
vendored
Normal file
44
debian/copyright
vendored
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
||||||
|
Upstream-Name: {PROJECT}
|
||||||
|
Source: {URL}
|
||||||
|
|
||||||
|
Files: *
|
||||||
|
Copyright: YEAR {UPSTREAM} {AUTHOR} <{MAIL}>
|
||||||
|
License: {UPSTREAM LICENSE}
|
||||||
|
|
||||||
|
Files: debian/*
|
||||||
|
Copyright: 2012 Équipe EOLE <eole@ac-dijon.fr>
|
||||||
|
License: CeCILL-2
|
||||||
|
|
||||||
|
License: {UPSTREAM LICENSE}
|
||||||
|
{TEXT OF THE LICENSE}
|
||||||
|
|
||||||
|
License: CeCILL-2
|
||||||
|
This software is governed by the CeCILL-2 license under French law and
|
||||||
|
abiding by the rules of distribution of free software. You can use,
|
||||||
|
modify and or redistribute the software under the terms of the CeCILL-2
|
||||||
|
license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
"http://www.cecill.info";.
|
||||||
|
.
|
||||||
|
As a counterpart to the access to the source code and rights to copy,
|
||||||
|
modify and redistribute granted by the license, users are provided only
|
||||||
|
with a limited warranty and the software's author, the holder of the
|
||||||
|
economic rights, and the successive licensors have only limited
|
||||||
|
liability.
|
||||||
|
.
|
||||||
|
In this respect, the user's attention is drawn to the risks associated
|
||||||
|
with loading, using, modifying and/or developing or reproducing the
|
||||||
|
software by the user in light of its specific status of free software,
|
||||||
|
that may mean that it is complicated to manipulate, and that also
|
||||||
|
therefore means that it is reserved for developers and experienced
|
||||||
|
professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
encouraged to load and test the software's suitability as regards their
|
||||||
|
requirements in conditions enabling the security of their systems and/or
|
||||||
|
data to be ensured and, more generally, to use and operate it in the
|
||||||
|
same conditions as regards security.
|
||||||
|
.
|
||||||
|
The fact that you are presently reading this means that you have had
|
||||||
|
knowledge of the CeCILL-2 license and that you accept its terms.
|
||||||
|
.
|
||||||
|
On Eole systems, the complete text of the CeCILL-2 License can be found
|
||||||
|
in '/usr/share/common-licenses/CeCILL-2-en'.
|
1
debian/eole-gitea.forge.service
vendored
Symbolic link
1
debian/eole-gitea.forge.service
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../systemd/forge.service
|
3
debian/gbp.conf
vendored
Normal file
3
debian/gbp.conf
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# Set per distribution debian tag
|
||||||
|
[DEFAULT]
|
||||||
|
debian-tag = debian/eole/%(version)s
|
18
debian/rules
vendored
Executable file
18
debian/rules
vendored
Executable file
@ -0,0 +1,18 @@
|
|||||||
|
#!/usr/bin/make -f
|
||||||
|
# -*- makefile -*-
|
||||||
|
|
||||||
|
# Uncomment this to turn on verbose mode.
|
||||||
|
#export DH_VERBOSE=1
|
||||||
|
|
||||||
|
%:
|
||||||
|
dh $@
|
||||||
|
|
||||||
|
# Force init script name
|
||||||
|
override_dh_installinit:
|
||||||
|
dh_installinit --noscripts -peole-redis --name=redis2-server $@
|
||||||
|
|
||||||
|
override_dh_systemd_enable:
|
||||||
|
dh_systemd_enable -peole-redis --name=redis2-server
|
||||||
|
|
||||||
|
override_dh_systemd_start:
|
||||||
|
dh_systemd_start -peole-server --no-start --no-restart-on-upgrade redis2-server
|
1
debian/source/format
vendored
Normal file
1
debian/source/format
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
3.0 (native)
|
@ -1,6 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<creole>
|
<creole>
|
||||||
<files>
|
<files>
|
||||||
|
<!-- Je suis un commentaire -->
|
||||||
<file filelist='gitea-nginx' name='/etc/nginx/sites-available/gitea' source='gitea.nginx' mkdir='True' rm='True'/>
|
<file filelist='gitea-nginx' name='/etc/nginx/sites-available/gitea' source='gitea.nginx' mkdir='True' rm='True'/>
|
||||||
<file filelist='gitea' name='/usr/share/eole/bastion/data/51-gitea-nat_rules' mkdir='True' rm='True' mode='0755'/>
|
<file filelist='gitea' name='/usr/share/eole/bastion/data/51-gitea-nat_rules' mkdir='True' rm='True' mode='0755'/>
|
||||||
<file filelist='gitea' name='/etc/eole/eole-db.d/gitea-db.yml' rm='True' mkdir='True'/>
|
<file filelist='gitea' name='/etc/eole/eole-db.d/gitea-db.yml' rm='True' mkdir='True'/>
|
||||||
@ -13,13 +14,15 @@
|
|||||||
<container name='forge' id='101'>
|
<container name='forge' id='101'>
|
||||||
<package>apt-transport-https</package>
|
<package>apt-transport-https</package>
|
||||||
<package>git-core</package>
|
<package>git-core</package>
|
||||||
|
<!-- FIXME this have to be installed <package>gitea</package> -->
|
||||||
<file filelist='gitea' name='/etc/gitea/conf/app.ini' source='gitea.conf' mkdir='True' rm='True' mode='770' owner='root' group='gitservice'/>
|
<file filelist='gitea' name='/etc/gitea/conf/app.ini' source='gitea.conf' mkdir='True' rm='True' mode='770' owner='root' group='gitservice'/>
|
||||||
|
<!-- <service servicelist='xxxx'>nom-du-service-a-lancer-dans-le-conteneur</service> -->
|
||||||
<service servicelist='gitea'>forge</service>
|
<service servicelist='gitea'>forge</service>
|
||||||
<service_access service='gitea_without_nginx'>
|
<service_access service='gitea_without_nginx'>
|
||||||
<port service_accesslist="gitea_without_nginx" port_type="SymLinkOption">gitea_http_port</port>
|
<port service_accesslist="gitea_without_nginx" port_type="SymLinkOption">gitea_http_port</port>
|
||||||
</service_access>
|
</service_access>
|
||||||
<service_access service='gitea_ssh'>
|
<service_access service='gitea_ssh'>
|
||||||
<port service_accesslist="gitea_ssh'" port_type="SymLinkOption">gitea_ssh_port</port>
|
<tcpwrapper>sshd</tcpwrapper>
|
||||||
</service_access>
|
</service_access>
|
||||||
</container>
|
</container>
|
||||||
</containers>
|
</containers>
|
||||||
|
@ -16,120 +16,81 @@ HOMEDIR="${WKDIR}/${USER}"
|
|||||||
OS="linux"
|
OS="linux"
|
||||||
ARCH="amd64"
|
ARCH="amd64"
|
||||||
|
|
||||||
APPVERSION="1.10.0"
|
APPVERSION="1.8.2"
|
||||||
APPNAME="gitea"
|
APPNAME="gitea"
|
||||||
APPBINARY="gitea"
|
APPBINARY="gitea"
|
||||||
APPSIG="7C9E68152594688862D62AF62D9AE806EC1592E2"
|
APPSIG="7C9E68152594688862D62AF62D9AE806EC1592E2"
|
||||||
APPASC="${APPNAME}-${APPVERSION}-${OS}-${ARCH}.asc"
|
APPASC="${APPNAME}-${APPVERSION}-${OS}-${ARCH}.asc"
|
||||||
KEYSERV="hkp://p80.pool.sks-keyservers.net:80"
|
KEYSERV="pgp.mit.edu"
|
||||||
DLSERV="dl.gitea.io"
|
DLSERV="dl.gitea.io"
|
||||||
APPDIR="${WKDIR}/gitea"
|
APPDIR="${WKDIR}/gitea"
|
||||||
APPBINDIR="${APPDIR}/bin"
|
APPBINDIR="${APPDIR}/bin"
|
||||||
APPCONFDIR="/etc/${APPNAME}"
|
APPCONFDIR="/etc/${APPNAME}"
|
||||||
|
|
||||||
function configure_proxy {
|
if [[ -d ${APPCONFDIR} ]]
|
||||||
proxy=$(CreoleGet activer_proxy_client non)
|
then
|
||||||
if [[ ${proxy} == "oui" ]]
|
exit 0
|
||||||
then
|
fi
|
||||||
prAddr=$(CreoleGet proxy_client_adresse)
|
|
||||||
prPort=$(CreoleGet proxy_client_port)
|
|
||||||
export HTTP_PROXY=http://${prAddr}:${prPort}
|
|
||||||
export http_proxy=http://${prAddr}:${prPort}
|
|
||||||
export HTTPS_PROXY=http://${prAddr}:${prPort}
|
|
||||||
export https_proxy=http://${prAddr}:${prPort}
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function create_app_dir {
|
proxy=$(CreoleGet activer_proxy_client non)
|
||||||
|
|
||||||
mkdir -p "${APPDIR}"
|
|
||||||
chown ${USER}:${GROUP} "${APPDIR}" -R
|
|
||||||
|
|
||||||
# Create app structure
|
if [[ ${proxy} == "oui" ]]
|
||||||
mkdir -p ${APPDIR}/{custom,data,indexers,public,log}
|
then
|
||||||
chown ${USER}:${GROUP} ${APPDIR}/{data,indexers,log}
|
prAddr=$(CreoleGet proxy_client_adresse)
|
||||||
chmod 750 ${APPDIR}/{data,indexers,log}
|
prPort=$(CreoleGet proxy_client_port)
|
||||||
mkdir -p "${APPCONFDIR}"
|
export HTTP_PROXY=http://${prAddr}:${prPort}
|
||||||
chown root:${GROUP} ${APPCONFDIR}
|
export http_proxy=http://${prAddr}:${prPort}
|
||||||
chmod 770 "${APPCONFDIR}"
|
export HTTPS_PROXY=http://${prAddr}:${prPort}
|
||||||
|
export https_proxy=http://${prAddr}:${prPort}
|
||||||
|
fi
|
||||||
|
|
||||||
mkdir -p "${APPBINDIR}"
|
if [[ ! -d ${APPDIR} ]]
|
||||||
chown ${USER}:${GROUP} "${APPBINDIR}"
|
then
|
||||||
|
mkdir -p ${APPDIR}
|
||||||
|
chown ${USER}:${GROUP} ${APPDIR} -R
|
||||||
|
fi
|
||||||
|
|
||||||
}
|
# Create app user and group
|
||||||
|
groupadd ${GROUP}
|
||||||
|
adduser \
|
||||||
|
--shell ${USERSHELL} \
|
||||||
|
--gecos "${GECOS}" \
|
||||||
|
--ingroup ${GROUP} \
|
||||||
|
--disabled-password \
|
||||||
|
--home ${HOMEDIR} \
|
||||||
|
${USER}
|
||||||
|
|
||||||
function create_user_and_group {
|
# Create app structure
|
||||||
local existing_group=$(getent group ${GROUP})
|
mkdir -p ${APPDIR}/{custom,data,indexers,public,log}
|
||||||
if [ -z "${existing_group}" ]; then
|
chown ${USER}:${GROUP} ${APPDIR}/{data,indexers,log}
|
||||||
groupadd ${GROUP}
|
chmod 750 ${APPDIR}/{data,indexers,log}
|
||||||
fi
|
mkdir ${APPCONFDIR}
|
||||||
|
chown root:${GROUP} ${APPCONFDIR}
|
||||||
|
chmod 770 ${APPCONFDIR}
|
||||||
|
|
||||||
local existing_user=$(getent passwd ${USER})
|
if [[ ! -d ${APPBINDIR} ]]
|
||||||
if [ -z "${existing_user}" ]; then
|
then
|
||||||
adduser \
|
mkdir -p ${APPBINDIR}
|
||||||
--shell ${USERSHELL} \
|
chown ${USER}:${GROUP} ${APPBINDIR}
|
||||||
--gecos "${GECOS}" \
|
fi
|
||||||
--ingroup ${GROUP} \
|
|
||||||
--disabled-password \
|
|
||||||
--home ${HOMEDIR} \
|
|
||||||
${USER}
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function download_binary {
|
cd $APPBINDIR
|
||||||
local temp_bin=$(mktemp)
|
if [[ ! -f ${APPBINARY} ]]
|
||||||
|
then
|
||||||
|
wget -O ${APPBINARY} https://${DLSERV}/${APPNAME}/${APPVERSION}/${APPNAME}-${APPVERSION}-${OS}-${ARCH}
|
||||||
|
if [[ $? -eq 0 ]]
|
||||||
|
then
|
||||||
|
chmod +x ${APPBINARY}
|
||||||
|
else
|
||||||
|
echo "Error downloading binary for ${APPNAME}"
|
||||||
|
return 123
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
wget -O "${temp_bin}" https://${DLSERV}/${APPNAME}/${APPVERSION}/${APPNAME}-${APPVERSION}-${OS}-${ARCH}
|
if [[ ! -f ${APPASC} ]]
|
||||||
if [[ $? -ne 0 ]]
|
then
|
||||||
then
|
wget -O ${APPASC} https://${DLSERV}/${APPNAME}/${APPVERSION}/${APPASC}
|
||||||
echo "Error downloading binary for ${APPNAME}"
|
|
||||||
return 123
|
|
||||||
fi
|
|
||||||
|
|
||||||
wget -O "${temp_bin}.asc" https://${DLSERV}/${APPNAME}/${APPVERSION}/${APPASC}
|
|
||||||
gpg --keyserver ${KEYSERV} --recv ${APPSIG}
|
gpg --keyserver ${KEYSERV} --recv ${APPSIG}
|
||||||
gpg --verify "${temp_bin}.asc" "${temp_bin}"
|
gpg --verify ${APPNAME}-${APPVERSION}-${OS}-${ARCH}.asc ${APPBINARY}
|
||||||
|
fi
|
||||||
if [[ $? -ne 0 ]]
|
cd -
|
||||||
then
|
|
||||||
echo "Error downloading binary for ${APPNAME}"
|
|
||||||
return 123
|
|
||||||
fi
|
|
||||||
|
|
||||||
cd $APPBINDIR
|
|
||||||
chmod +x "${temp_bin}"
|
|
||||||
mv -f "${temp_bin}" ${APPBINARY}
|
|
||||||
cd -
|
|
||||||
}
|
|
||||||
|
|
||||||
function current_gitea_version {
|
|
||||||
if [[ ! -f "${APPBINDIR}/${APPBINARY}" ]]
|
|
||||||
then
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
"${APPBINDIR}/${APPBINARY}" --version | cut -d' ' -f 3
|
|
||||||
}
|
|
||||||
|
|
||||||
function main {
|
|
||||||
|
|
||||||
# Check that installed version if ok
|
|
||||||
local current_version=$(current_gitea_version)
|
|
||||||
if [ "$current_version" == "$APPVERSION" ]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$current_version" ]
|
|
||||||
then
|
|
||||||
echo "Installing Gitea ${APPVERSION}..."
|
|
||||||
else
|
|
||||||
echo "Upgrade Gitea from ${current_version} to ${APPVERSION}..."
|
|
||||||
fi
|
|
||||||
|
|
||||||
configure_proxy
|
|
||||||
create_user_and_group
|
|
||||||
create_app_dir
|
|
||||||
download_binary
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
main
|
|
||||||
|
@ -34,7 +34,8 @@ createscript: "/usr/share/eole/db/gitea/gen/00-create-gitea-db.sql"
|
|||||||
%set cnt_prefix = %%getVar('container_path_reseau', '')
|
%set cnt_prefix = %%getVar('container_path_reseau', '')
|
||||||
pwd_files:
|
pwd_files:
|
||||||
- {file: '%%cnt_prefix/etc/gitea/conf/app.ini',
|
- {file: '%%cnt_prefix/etc/gitea/conf/app.ini',
|
||||||
pattern: 'PASSWD = `',
|
pattern: 'PASSWD = ',
|
||||||
end_pattern: '`',
|
end_pattern: '',
|
||||||
owner: 'root:gitservice',
|
owner: 'root:gitservice',
|
||||||
mod: '660' }
|
mod: '660' }
|
||||||
|
|
||||||
|
@ -30,7 +30,6 @@ HTTP_ADDR =
|
|||||||
HTTP_PORT = %%gitea_http_port
|
HTTP_PORT = %%gitea_http_port
|
||||||
; Disable SSH feature when not available
|
; Disable SSH feature when not available
|
||||||
DISABLE_SSH = false
|
DISABLE_SSH = false
|
||||||
START_SSH_SERVER = true
|
|
||||||
SSH_PORT = %%gitea_ssh_port
|
SSH_PORT = %%gitea_ssh_port
|
||||||
; Disable CDN even in "prod" mode
|
; Disable CDN even in "prod" mode
|
||||||
OFFLINE_MODE = false
|
OFFLINE_MODE = false
|
||||||
@ -71,7 +70,7 @@ HOST = %%{gitea_dbserver}:%%{gitea_dbport}
|
|||||||
%end if
|
%end if
|
||||||
NAME = gitea
|
NAME = gitea
|
||||||
USER = gitea
|
USER = gitea
|
||||||
PASSWD = `gitea1234`
|
PASSWD = gitea1234
|
||||||
; For "postgres" only, either "disable", "require" or "verify-full"
|
; For "postgres" only, either "disable", "require" or "verify-full"
|
||||||
SSL_MODE = disable
|
SSL_MODE = disable
|
||||||
; For "sqlite3" only
|
; For "sqlite3" only
|
||||||
|
Reference in New Issue
Block a user