blob: 9def8aa4e72aa213f0379fff9c0795cecca371b3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
#!/bin/sh
# contains functions used to access mysql db
# shellcheck disable=SC2039
mysql_command='mysql buildmaster -e'
# add_package_source $pkgbase $pkgver $pkgrel $git_revision $mod_git_revision $upstream_package_repository
# shellcheck disable=SC2016,SC2086
add_package_source() {
local names='pkgbase pkgver pkgrel git_revision mod_git_revision upstream_package_repository'
local values;
for _ in ${names}; do
values="${values}$(
printf '%s' "$1" | \
base64 -w0
) "
shift
done
values="${values% }"
${mysql_command} "$(
printf 'INSERT IGNORE INTO package_sources'
{
printf ' ('
printf '`%s`, ' ${names}
printf ') SELECT'
printf ' from_base64("%s"), ' ${values% *}
printf ' `upstream_repositories`.`id`'
printf ' FROM `upstream_repositories`'
printf ' WHERE `upstream_repositories`.`name` = from_base64("%s");' \
"${values##* }"
} | \
sed 's|, )|)|g'
)"
}
#add_binary_package $pkgbase $git_revision $mod_git_revision $upstream_package_repository $pkgname $sub_pkgrel $architecture $repository
# shellcheck disable=SC2016,SC2086,SC2154
add_binary_package() {
local names='pkgbase git_revision mod_git_revision upstream_package_repository pkgname sub_pkgrel architecture repository'
local name
for name in ${names}; do
eval 'local '"${name}"
eval "${name}"'=$(
printf "%s" "$1" |
base64 -w0
)'
shift
done
${mysql_command} "$(
printf 'INSERT IGNORE INTO binary_packages'
{
printf ' ('
printf '`%s`, ' 'sub_pkgrel' 'pkgname' 'package_source' 'repository' 'architecture'
printf ') SELECT'
printf ' from_base64("%s"), ' "${sub_pkgrel}" "${pkgname}"
printf ' `%s`.`id`,' 'package_sources' 'repositories' 'architectures'
printf ' FROM'
printf ' `%s` JOIN' 'package_sources' 'repositories' 'architectures'
printf ' `upstream_repositories` ON `package_sources`.`upstream_package_repository` = `upstream_repositories`.`id`'
printf ' WHERE'
printf ' `%s`.`name` = from_base64("%s") AND' \
'repositories' "${repository}" \
'architectures' "${architecture}"
printf ' `package_sources`.`%s` = from_base64("%s") AND' \
'pkgbase' "${pkgbase}" \
'git_revision' "${git_revision}" \
'mod_git_revision' "${mod_git_revision}"
printf ' `upstream_repositories`.`name` = from_base64("%s")' \
"${upstream_package_repository}"
} | \
sed '
s|, )|)|g
s|, FROM| FROM|g
'
)"
}
|