Compare commits

...

35 Commits

Author SHA1 Message Date
f58e8b6c15 util-iso-yaml: add optional libpwquality check in user module 2018-10-03 11:11:02 +02:00
d432ffee3f util-iso-yaml: remoive netinstall commented code
util-iso: check for $log_dir
2018-10-03 10:22:31 +02:00
961bc2cd59 Explicitly create log_dir and iso_root (#2) 2018-10-03 04:18:54 +02:00
92aeff61d8 util-iso-grub: enable ucode
util-iso-yaml: rm netinstall
util-pkg-subrepo: simplify
2018-10-02 22:31:57 +02:00
64725482f8 update readme 2018-09-07 22:27:08 +02:00
11cd590529 util-iso-yaml: fix services in settings.conf 2018-09-07 22:19:26 +02:00
bb22741aa1 util-iso-grub: set pxe in base profile only 2018-09-07 17:34:52 +02:00
28e4b73964 util-iso-yaml: add dir options in services-openrc; fix runit svc typos 2018-09-06 19:29:57 +02:00
7ea0d6f475 util-iso-yaml: adopt upstream cal new services naming 2018-09-06 18:06:20 +02:00
bdcc22fd46 Makefile: remove uninstall & dist 2018-09-06 18:05:29 +02:00
3c2e97f915 buildtree: fix config arg on pull 2018-08-12 02:58:32 +02:00
ba77c20d77 buildtree: ch in proper dir in config 2018-08-12 02:48:47 +02:00
c376041a07 buildtree: fix it 2018-08-12 02:38:24 +02:00
bd29d360b4 buildtree: fix path 2018-08-12 02:34:47 +02:00
7e1b1ee238 nuildtree: configure repo after clone as well, its too later after pull only 2018-08-12 02:21:24 +02:00
221218ba2a util-pkg: don't set localersion in kernel config 2018-08-09 01:54:48 +02:00
697d18da82 util-pkg-gitea: create compliant git repo 2018-08-07 21:47:34 +02:00
27d0230ed7 buildtree: fix import 2018-08-07 02:38:25 +02:00
41fdcb68fb commitpkg: run git prune 2018-08-06 22:17:01 +02:00
37b02c08bc util-pkg-gitea: add licence header 2018-07-30 02:43:29 +02:00
31200d7765 util-pkg-gitea: get compliant repo name 2018-07-30 02:21:53 +02:00
60844ee0ea Merge branch 'subrepo' of artix/artools into master 2018-07-29 20:47:25 +00:00
2c2e6b41a1 commitpkg: move subrepo push in push switch 2018-07-29 18:45:40 +02:00
52c81a0e61 bump version 2018-07-29 18:38:10 +02:00
6667147b77 buildtree: fix import 2018-07-29 17:25:48 +02:00
26635e3a10 use ssh for git 2018-07-29 00:28:43 +02:00
1d5a565ed8 commitpkg: spilt out subrepo functions 2018-07-28 22:29:15 +02:00
4e54b48903 commitpkg: fix, add sleep 1 2018-07-28 22:23:10 +02:00
2f16cd73c9 buildtree, commitpkg: prepare first test 2018-07-28 21:54:26 +02:00
9fd6ac3531 buildtree: revert to old pkg repos 2018-07-27 20:39:26 +02:00
2f5acc6e3c buildtree, commitpkg: adapt import path 2018-07-27 19:51:27 +02:00
d73b6d9178 rename gitea lib 2018-07-27 19:47:30 +02:00
d5404ac2fa builtree: write jenkinsfile for new pkgs 2018-07-27 18:28:34 +02:00
d250b967ba buildtree, commitpkg: use subrepo 2018-07-27 14:52:30 +02:00
5715eecf0c buildtree, commitpkg: initial gitea/subrepo support 2018-07-27 13:35:31 +02:00
13 changed files with 215 additions and 130 deletions

View File

@@ -1,4 +1,4 @@
VERSION=0.8 VERSION=0.9
CHROOT_VERSION=0.8 CHROOT_VERSION=0.8
@@ -22,17 +22,6 @@ M4 = m4 -P
CHMODAW = chmod a-w CHMODAW = chmod a-w
CHMODX = chmod +x CHMODX = chmod +x
ifdef WITH-PKG
WITH-PKG = no
else
WITH-PKG = yes
endif
ifdef WITH-ISO
WITH-ISO = no
else
WITH-ISO = yes
endif
CPIODIR = $(SYSCONFDIR)/initcpio CPIODIR = $(SYSCONFDIR)/initcpio
SYSCONF = \ SYSCONF = \
@@ -103,19 +92,7 @@ LIBS_ISO = \
SHARED_ISO = \ SHARED_ISO = \
data/mkinitcpio.conf data/mkinitcpio.conf
ifeq ($(WITH-PKG),yes) all: $(BIN_BASE) $(BIN_PKG) $(BIN_ISO)
all: $(BIN_PKG)
endif
ifeq ($(WITH-ISO),yes)
all: $(BIN_ISO)
endif
all: $(BIN_BASE)
EDIT = sed -e "s|@datadir[@]|$(DATADIR)/$(TOOLS)|g" \ EDIT = sed -e "s|@datadir[@]|$(DATADIR)/$(TOOLS)|g" \
-e "s|@sysconfdir[@]|$(SYSCONFDIR)/$(TOOLS)|g" \ -e "s|@sysconfdir[@]|$(SYSCONFDIR)/$(TOOLS)|g" \
@@ -177,54 +154,6 @@ install_iso: install_cpio
install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)
install $(FILEMODE) $(SHARED_ISO) $(DESTDIR)$(DATADIR)/$(TOOLS) install $(FILEMODE) $(SHARED_ISO) $(DESTDIR)$(DATADIR)/$(TOOLS)
uninstall_base: install: install_base install_pkg install_iso
for f in $(notdir $(SYSCONF)); do $(RM) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)/$$f; done
for f in $(notdir $(BIN_BASE)); do $(RM) $(DESTDIR)$(BINDIR)/$$f; done
for f in $(notdir $(LIBS_BASE)); do $(RM) $(DESTDIR)$(LIBDIR)/$(TOOLS)/$$f; done
for f in $(notdir $(SHARED_BASE)); do $(RM) $(DESTDIR)$(DATADIR)/$(TOOLS)/$$f; done
$(RMD) $(DESTDIR)$(SYSCONFDIR)/$(TOOLS)
$(RMD) $(DESTDIR)$(LIBDIR)/$(TOOLS)
$(RMD) $(DESTDIR)$(DATADIR)/$(TOOLS)
uninstall_pkg: .PHONY: all clean install
for f in $(notdir $(BIN_PKG)); do $(RM) $(DESTDIR)$(BINDIR)/$$f; done
$(RM) $(DESTDIR)$(BINDIR)/find-libprovides
for l in $(COMMITPKG_SYMS); do $(RM) $(DESTDIR)$(BINDIR)/$$l; done
for f in $(notdir $(LIBS_PKG)); do $(RM) $(DESTDIR)$(LIBDIR)/$(TOOLS)/$$f; done
for f in $(notdir $(PATCHES)); do $(RM) $(DESTDIR)$(DATADIR)/$(TOOLS)/patches/$$f; done
for f in $(notdir $(SHARED_PKG)); do $(RM) $(DESTDIR)$(DATADIR)/$(TOOLS)/$$f; done
uninstall_cpio:
+make CPIODIR=$(CPIODIR) DESTDIR=$(DESTDIR) -C initcpio uninstall
uninstall_iso: uninstall_cpio
for f in $(notdir $(BIN_ISO)); do $(RM) $(DESTDIR)$(BINDIR)/$$f; done
for l in $(notdir $(BIN_ISO_SYMS)); do $(RM) $(DESTDIR)$(BINDIR)/$$l; done
for f in $(notdir $(LIBS_ISO)); do $(RM) $(DESTDIR)$(LIBDIR)/$(TOOLS)/$$f; done
for f in $(notdir $(SHARED_ISO)); do $(RM) $(DESTDIR)$(DATADIR)/$(TOOLS)/$$f; done
ifeq ($(WITH-PKG),yes)
install: install_pkg
uninstall: uninstall_pkg
endif
ifeq ($(WITH-ISO),yes)
install: install_iso
uninstall: uninstall_iso
endif
install: install_base
uninstall: uninstall_base
dist:
git archive --format=tar --prefix=$(TOOLS)-$(VERSION)/ $(VERSION) | gzip -9 > $(TOOLS)-$(VERSION).tar.gz
gpg --detach-sign --use-agent $(TOOLS)-$(VERSION).tar.gz
.PHONY: all clean install uninstall dist

View File

@@ -6,9 +6,6 @@ artools
* PREFIX=/usr/local (default if defined) * PREFIX=/usr/local (default if defined)
* SYSCONFDIR=/etc * SYSCONFDIR=/etc
* WITH-PKG=yes
* WITH-ISO=yes
#### Dependencies #### Dependencies
@@ -21,7 +18,6 @@ artools
##### Runtime: ##### Runtime:
- base: - base:
* openssh * openssh
* rsync * rsync
* haveged * haveged
@@ -30,9 +26,8 @@ artools
* pacman * pacman
- pkg: - pkg:
* namcap * namcap
* git * git-subrepo
- iso: - iso:
* dosfstools * dosfstools

View File

@@ -44,6 +44,7 @@ prepare_build(){
mnt_dir=${chroots_iso}/${profile}/mnt mnt_dir=${chroots_iso}/${profile}/mnt
prepare_dir "${mnt_dir}" prepare_dir "${mnt_dir}"
prepare_dir "${iso_dir}" prepare_dir "${iso_dir}"
prepare_dir "${iso_root}"
} }
show_profile(){ show_profile(){

View File

@@ -18,14 +18,16 @@ DATADIR='@datadir@'
[[ -r ${LIBDIR}/util-msg.sh ]] && source ${LIBDIR}/util-msg.sh [[ -r ${LIBDIR}/util-msg.sh ]] && source ${LIBDIR}/util-msg.sh
import ${LIBDIR}/util.sh import ${LIBDIR}/util.sh
import ${LIBDIR}/util-pkg.sh import ${LIBDIR}/util-pkg.sh
import ${LIBDIR}/util-pkg-gitea.sh
import ${LIBDIR}/util-pkg-subrepo.sh
pull_tree_arch(){ pull_tree_arch(){
cd ${tree_dir_arch} cd ${tree_dir_arch}
for tree in packages community;do for tree in packages community;do
if [[ -d ${tree} ]];then if [[ -d ${tree} ]];then
cd ${tree} cd ${tree}
msg "Checking (%s)" "${tree}" msg "Checking (%s)" "${tree}"
pull_tree pull_tree
cd .. cd ..
else else
msg "Cloning (%s) ..." "$tree" msg "Cloning (%s) ..." "$tree"
@@ -34,24 +36,32 @@ pull_tree_arch(){
done done
} }
config_tree(){
local tree="$1"
cd $tree
git config --bool pull.rebase true
git config commit.gpgsign true
if [[ -n "${GPGKEY}" ]];then
git config user.signingkey "${GPGKEY}"
else
warning "No GPGKEY configured in makepkg.conf!"
fi
cd ..
}
pull_tree_artix(){ pull_tree_artix(){
cd ${tree_dir_artix} cd ${tree_dir_artix}
for tree in packages packages-galaxy;do for tree in packages packages-galaxy;do
if [[ -d ${tree} ]];then if [[ -d ${tree} ]];then
config_tree "${tree}"
cd ${tree} cd ${tree}
git config --bool pull.rebase true msg "Checking (%s)" "${tree}"
git config commit.gpgsign true pull_tree
if [[ -n "${GPGKEY}" ]];then
git config user.signingkey "${GPGKEY}"
else
warning "No GPGKEY configured in makepkg.conf!"
fi
msg "Checking (%s)" "${tree}"
pull_tree
cd .. cd ..
else else
msg "Cloning (%s) ..." "$tree" msg "Cloning (%s) ..." "$tree"
clone_tree "${host_tree_artix}/${tree}" clone_tree "${host_tree_artix}/${tree}"
config_tree "${tree}"
fi fi
done done
} }
@@ -161,7 +171,10 @@ from_arch(){
cd ${tree_dir_artix}/$git_tree_artix cd ${tree_dir_artix}/$git_tree_artix
dest=${tree_dir_artix}/$git_tree_artix/$pkg/trunk dest=${tree_dir_artix}/$git_tree_artix/$pkg/trunk
mkdir $pkg
create_repo "$pkg"
add_repo_to_team "$pkg" "$pkg_path"
subrepo_clone "$pkg"
info "Import from archlinux (%s)" "$git_tree_arch" info "Import from archlinux (%s)" "$git_tree_arch"
rsync "${rsync_args[@]}" $src/ $dest/ rsync "${rsync_args[@]}" $src/ $dest/

View File

@@ -18,6 +18,7 @@ DATADIR='@datadir@'
[[ -r ${LIBDIR}/util-msg.sh ]] && source ${LIBDIR}/util-msg.sh [[ -r ${LIBDIR}/util-msg.sh ]] && source ${LIBDIR}/util-msg.sh
import ${LIBDIR}/util.sh import ${LIBDIR}/util.sh
import ${LIBDIR}/util-pkg.sh import ${LIBDIR}/util-pkg.sh
import ${LIBDIR}/util-pkg-subrepo.sh
commit_pkg(){ commit_pkg(){
local git_tree=$(find_tree "${tree_dir_artix}" "${package}") local git_tree=$(find_tree "${tree_dir_artix}" "${package}")
@@ -27,6 +28,7 @@ commit_pkg(){
source trunk/PKGBUILD source trunk/PKGBUILD
[[ $arch == 'any' ]] && CARCH=any [[ $arch == 'any' ]] && CARCH=any
local ver=$(get_full_version "${package}") local ver=$(get_full_version "${package}")
local commit_msg=""
if ${remove};then if ${remove};then
local action='remove' local action='remove'
@@ -37,20 +39,27 @@ commit_pkg(){
local pkg="${package}-$ver" local pkg="${package}-$ver"
git rm -r repos/"${source_repo}-$CARCH" git rm -r repos/"${source_repo}-$CARCH"
fi fi
msg "Action: [%s] '%s' %s" "${source_repo}" "$pkg" "${action}" commit_msg="[${source_repo}] '$pkg' ${action}"
git commit -m "[${source_repo}] '$pkg' ${action}" msg "Action: %s" "$commit_msg"
else else
local action='modify' local action='modify'
msg "Action: [%s] '%s' %s" "${source_repo}" "${package}-$ver" "${action}" commit_msg="[${source_repo}] '${package}-$ver' ${action}"
msg "Action: %s" "$commit_msg"
git add . git add .
git commit -m "[${source_repo}] '${package}-$ver' ${action}"
fi fi
git commit -m "$commit_msg"
cd ${tree_dir_artix}/${git_tree}
if ${push};then if ${push};then
msg "Checking (%s)" "${git_tree}" msg "Checking (%s)" "${git_tree}"
git pull origin master git pull origin master
subrepo_push "${package}"
sleep 1
git push origin master git push origin master
fi fi
git prune
else else
error "Package '%s' does not exist!" "${package}" error "Package '%s' does not exist!" "${package}"
fi fi
@@ -85,16 +94,22 @@ symlink_commit_pkg(){
cp repos/$src/* repos/$dest/ cp repos/$src/* repos/$dest/
git rm -r repos/$src git rm -r repos/$src
fi fi
local commit_msg="[${source_repo}] -> [${target_repo}] '${package}-$ver' ${action}"
msg "Action: %s" "$commit_msg"
msg "Action: [%s] -> [%s] '%s' %s" "${source_repo}" "${target_repo}" "${package}-$ver" "${action}"
git add . git add .
git commit -m "[${source_repo}] -> [${target_repo}] '${package}-$ver' ${action}" git commit -m "$commit_msg"
cd ${tree_dir_artix}/${git_tree}
if ${push};then if ${push};then
msg "Checking (%s)" "${git_tree}" msg "Checking (%s)" "${git_tree}"
git pull origin master git pull origin master
subrepo_push "${package}"
sleep 1
git push origin master git push origin master
fi fi
git prune
else else
error "Package '%s' does not exist!" "${package}" error "Package '%s' does not exist!" "${package}"
fi fi

View File

@@ -12,7 +12,10 @@
################ artools-pkg ################ ################ artools-pkg ################
############################################# #############################################
# host_tree_artix='https://github.com/artix-linux' # git user access token
# git_token=''
# host_tree_artix='gitea@gitea.artixlinux.org:artix'
# host_tree_arch=git://projects.archlinux.org/svntogit # host_tree_arch=git://projects.archlinux.org/svntogit

View File

@@ -20,6 +20,11 @@ prepare_initcpio(){
prepare_initramfs(){ prepare_initramfs(){
local mnt="$1" local mnt="$1"
cp ${DATADIR}/mkinitcpio.conf $mnt/etc/mkinitcpio-artix.conf cp ${DATADIR}/mkinitcpio.conf $mnt/etc/mkinitcpio-artix.conf
if [[ "${profile}" != 'base' ]];then
sed -e 's/artix_pxe_common artix_pxe_http artix_pxe_nbd artix_pxe_nfs //' -i $mnt/etc/mkinitcpio-artix.conf
fi
if [[ -n ${gpgkey} ]]; then if [[ -n ${gpgkey} ]]; then
user_run "gpg --export ${gpgkey} >${AT_USERCONFDIR}/gpgkey" user_run "gpg --export ${gpgkey} >${AT_USERCONFDIR}/gpgkey"
exec 17<>${AT_USERCONFDIR}/gpgkey exec 17<>${AT_USERCONFDIR}/gpgkey
@@ -40,8 +45,12 @@ prepare_initramfs(){
prepare_boot_extras(){ prepare_boot_extras(){
local src="$1" dest="$2" local src="$1" dest="$2"
# cp $src/boot/intel-ucode.img $dest/intel_ucode.img
# cp $src/usr/share/licenses/intel-ucode/LICENSE $dest/intel_ucode.LICENSE for u in intel amd;do
cp $src/boot/$u-ucode.img $dest/$u-ucode.img
cp $src/usr/share/licenses/$u-ucode/LICENSE $dest/$u-ucode.LICENSE
done
cp $src/boot/memtest86+/memtest.bin $dest/memtest cp $src/boot/memtest86+/memtest.bin $dest/memtest
cp $src/usr/share/licenses/common/GPL2/license.txt $dest/memtest.COPYING cp $src/usr/share/licenses/common/GPL2/license.txt $dest/memtest.COPYING
} }
@@ -83,8 +92,13 @@ prepare_grub(){
cp -r ${theme}/themes/artix ${grub}/themes/ cp -r ${theme}/themes/artix ${grub}/themes/
cp -r ${theme}/{locales,tz} ${grub} cp -r ${theme}/{locales,tz} ${grub}
msg2 "Creating %s ..." "unicode.pf2" if [[ -f /usr/share/grub/unicode.pf2 ]];then
grub-mkfont -o ${grub}/unicode.pf2 /usr/share/fonts/misc/unifont.bdf msg2 "Copying %s ..." "unicode.pf2"
cp /usr/share/grub/unicode.pf2 ${grub}/unicode.pf2
else
msg2 "Creating %s ..." "unicode.pf2"
grub-mkfont -o ${grub}/unicode.pf2 /usr/share/fonts/misc/unifont.bdf
fi
local size=4M mnt="${mnt_dir}/efiboot" efi_img="$3/efi.img" local size=4M mnt="${mnt_dir}/efiboot" efi_img="$3/efi.img"
msg2 "Creating fat image of %s ..." "${size}" msg2 "Creating fat image of %s ..." "${size}"

View File

@@ -25,27 +25,45 @@ write_users_conf(){
echo "setRootPassword: true" >> "$conf" echo "setRootPassword: true" >> "$conf"
# echo "doReusePassword: false" >> "$conf" # only used in old 'users' module # echo "doReusePassword: false" >> "$conf" # only used in old 'users' module
echo "availableShells: /bin/bash, /bin/zsh" >> "$conf" # only used in new 'users' module echo "availableShells: /bin/bash, /bin/zsh" >> "$conf" # only used in new 'users' module
echo "avatarFilePath: ~/.face" >> "$conf" # echo "avatarFilePath: ~/.face" >> "$conf"
# echo "passwordRequirements:" >> "$conf"
# echo " minLength: -1" >> "$conf"
# echo " maxLength: -1" >> "$conf"
# echo " libpwquality:" >> "$conf"
# echo " - minlen=8" >> "$conf"
# echo " - minclass=80" >> "$conf"
} }
write_servicescfg_conf(){ write_servicescfg_conf(){
local init="$2" local init="$2"
local conf="$1"/"$init"cfg.conf state='add' local conf="$1"/services-"$init".conf
msg2 "Writing %s ..." "${conf##*/}" msg2 "Writing %s ..." "${conf##*/}"
echo '---' > "$conf" echo '---' > "$conf"
if [[ "$init" == 'runit' ]];then case "$init" in
state='enabled' 'runit')
echo 'svdir: /etc/runit/sv' >> "$conf" echo 'svDir: /etc/runit/sv' >> "$conf"
echo '' >> "$conf" echo '' >> "$conf"
echo 'runsvdir: /etc/runit/runsvdir' >> "$conf" echo 'runsvDir: /etc/runit/runsvdir' >> "$conf"
fi echo '' >> "$conf"
echo '' >> "$conf" echo 'services:' >> "$conf"
echo 'services:' >> "$conf" echo " enabled:" >> "$conf"
echo " $state:" >> "$conf" for svc in ${services[@]};do
for svc in ${services[@]};do echo " - name: $svc" >> "$conf"
echo " - name: $svc" >> "$conf" echo ' runlevel: default' >> "$conf"
echo ' runlevel: default' >> "$conf" done
done ;;
'openrc')
echo 'initdDir: /etc/init.d' >> "$conf"
echo '' >> "$conf"
echo 'runlevelsDir: /etc/runlevels' >> "$conf"
echo '' >> "$conf"
echo 'services:' >> "$conf"
for svc in ${services[@]};do
echo " - name: $svc" >> "$conf"
echo ' runlevel: default' >> "$conf"
done
;;
esac
} }
write_postcfg_conf(){ write_postcfg_conf(){
@@ -53,21 +71,15 @@ write_postcfg_conf(){
sed -e "s|openrc|$init|" -i "$conf" sed -e "s|openrc|$init|" -i "$conf"
} }
write_netinstall_conf(){
local conf="$1/netinstall.conf" init="$2"
sed -e "s|netgroups-openrc.yaml|netgroups-$init.yaml|" -i "$conf"
}
configure_calamares(){ configure_calamares(){
local mods="$1/etc/calamares/modules" init="$2" local mods="$1/etc/calamares/modules" init="$2"
if [[ -d "$mods" ]];then if [[ -d "$mods" ]];then
info "Configuring [Calamares]" info "Configuring [Calamares]"
write_netinstall_conf "$mods" "$init"
write_users_conf "$mods" write_users_conf "$mods"
write_servicescfg_conf "$mods" "$init" write_servicescfg_conf "$mods" "$init"
write_postcfg_conf "$mods" "$init" write_postcfg_conf "$mods" "$init"
local name="$init"cfg local name=services-"$init"
sed -e "s|openrccfg|$name|" -i "$1"/etc/calamares/settings.conf sed -e "s|services-openrc|$name|" -i "$1"/etc/calamares/settings.conf
info "Done configuring [Calamares]" info "Done configuring [Calamares]"
fi fi
} }

View File

@@ -87,6 +87,7 @@ error_function() {
# $1: function # $1: function
run_log(){ run_log(){
local func="$1" log_dir='/var/log/artools' local func="$1" log_dir='/var/log/artools'
[[ ! -d $log_dir ]] && mkdir -p $log_dir
local logfile=${log_dir}/$(gen_iso_fn).$func.log local logfile=${log_dir}/$(gen_iso_fn).$func.log
logpipe=$(mktemp -u "/tmp/$func.pipe.XXXXXXXX") logpipe=$(mktemp -u "/tmp/$func.pipe.XXXXXXXX")
mkfifo "$logpipe" mkfifo "$logpipe"

59
lib/util-pkg-gitea.sh Normal file
View File

@@ -0,0 +1,59 @@
#!/bin/bash
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
get_compliant_name(){
local gitname="$1"
case $gitname in
*+) gitname=${gitname//+/plus}
esac
echo $gitname
}
create_repo(){
local pkg="$1"
local gitname=$(get_compliant_name "$pkg")
curl -X POST "${git_url}/api/v1/org/packages/repos?access_token=${git_token}" -H "accept: application/json" -H "content-type: application/json" -d "{ \"auto_init\": true, \"name\":\"$gitname\", \"readme\": \"Default\" }"
}
delete_repo(){
local pkg="$1"
local gitname=$(get_compliant_name "$pkg")
curl -X DELETE "${git_url}/api/v1/repos/packages/$gitname?access_token=${git_token}" -H "accept: application/json"
}
find_team(){
local pkg="$1" team_id=
if [[ -f $pkg/repos/core-x86_64/PKGBUILD ]];then
team_id=18
elif [[ -f $pkg/repos/core-any/PKGBUILD ]];then
team_id=18
elif [[ -f $pkg/repos/extra-x86_64/PKGBUILD ]];then
team_id=19
elif [[ -f $pkg/repos/extra-any/PKGBUILD ]];then
team_id=19
elif [[ -f $pkg/repos/community-x86_64/PKGBUILD ]];then
team_id=20
elif [[ -f $pkg/repos/community-any/PKGBUILD ]];then
team_id=20
elif [[ -f $pkg/repos/multilib-x86_64/PKGBUILD ]];then
team_id=21
fi
echo $team_id
}
add_repo_to_team(){
local pkg="$1" path="$2"
local id=$(find_team "$path")
curl -X PUT "${git_url}/api/v1/teams/$id/repos/packages/$pkg?access_token=${git_token}" -H "accept: application/json"
}

30
lib/util-pkg-subrepo.sh Normal file
View File

@@ -0,0 +1,30 @@
#!/bin/bash
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
subrepo_init(){
local pkg="$1" branch=master org=packages
git subrepo init "$pkg" -r gitea@"${git_domain}":"$org"/"$pkg".git -b "$branch"
}
subrepo_push(){
local pkg="$1" branch=master
git subrepo push "$pkg" -u -b "$branch"
}
subrepo_pull(){
local pkg="$1" name="${2:-$1}" branch=master org=packages
git subrepo pull "$pkg" -r gitea@"${git_domain}":"$org"/"$name".git -u -b "$branch"
}
subrepo_clone(){
local pkg="$1" name="${2:-$1}" branch=master org=packages
git subrepo clone gitea@"${git_domain}":"$org"/"$name".git "$pkg" -b "$branch"
}

View File

@@ -45,8 +45,7 @@ patch_pkg(){
;; ;;
'linux') 'linux')
sed -e 's|-ARCH|-ARTIX|g' -i $pkg/trunk/PKGBUILD sed -e 's|-ARCH|-ARTIX|g' -i $pkg/trunk/PKGBUILD
sed -e 's|CONFIG_LOCALVERSION=.*|CONFIG_LOCALVERSION="-ARTIX"|' \ sed -e 's|CONFIG_DEFAULT_HOSTNAME=.*|CONFIG_DEFAULT_HOSTNAME="artixlinux"|' \
-e 's|CONFIG_DEFAULT_HOSTNAME=.*|CONFIG_DEFAULT_HOSTNAME="artixlinux"|' \
-e 's|CONFIG_CRYPTO_SPECK=.*|CONFIG_CRYPTO_SPECK=n|' \ -e 's|CONFIG_CRYPTO_SPECK=.*|CONFIG_CRYPTO_SPECK=n|' \
-i $pkg/trunk/config -i $pkg/trunk/config
cd $pkg/trunk cd $pkg/trunk
@@ -77,6 +76,14 @@ patch_pkg(){
esac esac
} }
write_jenkinsfile(){
local pkg="$1" jenkins=Jenkinsfile
echo '@Library(["PackagePipeline", "BuildPkg", "DeployPkg", "Notify", "PostBuild", "RepoPackage"]) import org.artixlinux.RepoPackage' > $pkg/$jenkins
echo '' >> $pkg/$jenkins
echo 'PackagePipeline(new RepoPackage(this))' >> $pkg/$jenkins
echo '' >> $pkg/$jenkins
}
find_tree(){ find_tree(){
local tree="$1" pkg="$2" local tree="$1" pkg="$2"
local result=$(find $tree -mindepth 2 -maxdepth 2 -type d -name "$pkg") local result=$(find $tree -mindepth 2 -maxdepth 2 -type d -name "$pkg")

View File

@@ -60,9 +60,15 @@ init_artools_base(){
init_artools_pkg(){ init_artools_pkg(){
git_domain='gitea.artixlinux.org'
git_url="https://${git_domain}"
[[ -z ${git_token} ]] && git_token=''
[[ -z ${tree_dir_artix} ]] && tree_dir_artix=${workspace_dir}/artix [[ -z ${tree_dir_artix} ]] && tree_dir_artix=${workspace_dir}/artix
[[ -z ${host_tree_artix} ]] && host_tree_artix='https://github.com/artix-linux' [[ -z ${host_tree_artix} ]] && host_tree_artix="gitea@gitea.artixlinux.org:artix"
[[ -z ${tree_dir_arch} ]] && tree_dir_arch=${workspace_dir}/archlinux [[ -z ${tree_dir_arch} ]] && tree_dir_arch=${workspace_dir}/archlinux