1
|
#!/bin/sh
|
2
|
#
|
3
|
# builder_defaults.sh
|
4
|
#
|
5
|
# part of pfSense (https://www.pfsense.org)
|
6
|
# Copyright (c) 2004-2013 BSD Perimeter
|
7
|
# Copyright (c) 2013-2016 Electric Sheep Fencing
|
8
|
# Copyright (c) 2014-2020 Rubicon Communications, LLC (Netgate)
|
9
|
# All rights reserved.
|
10
|
#
|
11
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
12
|
# you may not use this file except in compliance with the License.
|
13
|
# You may obtain a copy of the License at
|
14
|
#
|
15
|
# http://www.apache.org/licenses/LICENSE-2.0
|
16
|
#
|
17
|
# Unless required by applicable law or agreed to in writing, software
|
18
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
19
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
20
|
# See the License for the specific language governing permissions and
|
21
|
# limitations under the License.
|
22
|
|
23
|
###########################################
|
24
|
# Product builder configuration file #
|
25
|
# Please don't modify this file, you #
|
26
|
# can put your settings and options #
|
27
|
# in build.conf, which is sourced at the #
|
28
|
# beginning of this file #
|
29
|
###########################################
|
30
|
|
31
|
if [ -z "${BUILDER_ROOT}" ]; then
|
32
|
echo ">>> ERROR: BUILDER_ROOT must be defined by script that includes builder_defaults.sh"
|
33
|
exit 1
|
34
|
fi
|
35
|
|
36
|
if [ ! -d "${BUILDER_ROOT}" ]; then
|
37
|
echo ">>> ERROR: BUILDER_ROOT is invalid"
|
38
|
exit 1
|
39
|
fi
|
40
|
|
41
|
export BUILDER_TOOLS=${BUILDER_TOOLS:-"${BUILDER_ROOT}/tools"}
|
42
|
export BUILDER_SCRIPTS=${BUILDER_SCRIPTS:-"${BUILDER_ROOT}/build/scripts"}
|
43
|
|
44
|
if [ ! -d "${BUILDER_TOOLS}" ]; then
|
45
|
echo ">>> ERROR: BUILDER_TOOLS is invalid"
|
46
|
exit 1
|
47
|
fi
|
48
|
|
49
|
BUILD_CONF=${BUILD_CONF:-"${BUILDER_ROOT}/build.conf"}
|
50
|
|
51
|
# Ensure file exists
|
52
|
if [ -f ${BUILD_CONF} ]; then
|
53
|
. ${BUILD_CONF}
|
54
|
fi
|
55
|
|
56
|
# Make sure pkg will not be interactive
|
57
|
export ASSUME_ALWAYS_YES=true
|
58
|
|
59
|
# Architecture
|
60
|
export TARGET=${TARGET:-"$(uname -m)"}
|
61
|
export TARGET_ARCH=${TARGET_ARCH:-"$(uname -p)"}
|
62
|
|
63
|
# Directory to be used for writing temporary information
|
64
|
export SCRATCHDIR=${SCRATCHDIR:-"${BUILDER_ROOT}/tmp"}
|
65
|
if [ ! -d ${SCRATCHDIR} ]; then
|
66
|
mkdir -p ${SCRATCHDIR}
|
67
|
fi
|
68
|
|
69
|
# Product details
|
70
|
export PRODUCT_NAME=${PRODUCT_NAME:-"nonSense"}
|
71
|
export PRODUCT_NAME_SUFFIX=${PRODUCT_NAME_SUFFIX:-"-CE"}
|
72
|
export REPO_BRANCH_PREFIX=${REPO_BRANCH_PREFIX:-""}
|
73
|
export PRODUCT_URL=${PRODUCT_URL:-""}
|
74
|
export PRODUCT_SRC=${PRODUCT_SRC:-"${BUILDER_ROOT}/src"}
|
75
|
export PRODUCT_EMAIL=${PRODUCT_EMAIL:-"coreteam@pfsense.org"}
|
76
|
export XML_ROOTOBJ=${XML_ROOTOBJ:-$(echo "${PRODUCT_NAME}" | tr '[[:upper:]]' '[[:lower:]]')}
|
77
|
|
78
|
if [ "${PRODUCT_NAME}" = "pfSense" -a "${BUILD_AUTHORIZED_BY_NETGATE}" != "yes" ]; then
|
79
|
echo ">>>ERROR: According the following license, only Netgate can build genuine pfSense® software"
|
80
|
echo ""
|
81
|
cat ${BUILDER_ROOT}/LICENSE
|
82
|
exit 1
|
83
|
fi
|
84
|
|
85
|
if [ -z "${PRODUCT_VERSION}" ]; then
|
86
|
if [ ! -f ${PRODUCT_SRC}/etc/version ]; then
|
87
|
echo ">>> ERROR: PRODUCT_VERSION is not defined and ${PRODUCT_SRC}/etc/version was not found"
|
88
|
print_error_pfS
|
89
|
fi
|
90
|
|
91
|
export PRODUCT_VERSION=$(head -n 1 ${PRODUCT_SRC}/etc/version)
|
92
|
fi
|
93
|
export PRODUCT_REVISION=${PRODUCT_REVISION:-""}
|
94
|
|
95
|
# Product repository tag to build
|
96
|
_cur_git_repo_branch_or_tag=$(git -C ${BUILDER_ROOT} rev-parse --abbrev-ref HEAD)
|
97
|
if [ "${_cur_git_repo_branch_or_tag}" = "HEAD" ]; then
|
98
|
# We are on a tag, lets find out its name
|
99
|
export GIT_REPO_BRANCH_OR_TAG=$(git -C ${BUILDER_ROOT} describe --tags)
|
100
|
else
|
101
|
export GIT_REPO_BRANCH_OR_TAG="${_cur_git_repo_branch_or_tag}"
|
102
|
fi
|
103
|
# Use vX_Y instead of RELENG_X_Y for poudriere to make it shorter
|
104
|
# Replace . by _ to make tag names look correct
|
105
|
POUDRIERE_BRANCH=$(echo "${GIT_REPO_BRANCH_OR_TAG}" | sed 's,RELENG_,v,; s,\.,_,g')
|
106
|
|
107
|
GIT_REPO_BASE=$(git -C ${BUILDER_ROOT} config --get remote.origin.url | sed -e 's,/[^/]*$,,')
|
108
|
|
109
|
# This is used for using svn for retrieving src
|
110
|
export FREEBSD_REPO_BASE=${FREEBSD_REPO_BASE:-"${GIT_REPO_BASE}/freebsd-src.git"}
|
111
|
export FREEBSD_BRANCH=${FREEBSD_BRANCH:-"RELENG_2_5"}
|
112
|
export FREEBSD_SRC_DIR=${FREEBSD_SRC_DIR:-"${SCRATCHDIR}/FreeBSD-src"}
|
113
|
|
114
|
export BUILD_KERNELS=${BUILD_KERNELS:-"${PRODUCT_NAME}"}
|
115
|
|
116
|
# XXX: Poudriere doesn't like ssh short form
|
117
|
case "${FREEBSD_REPO_BASE}" in
|
118
|
git@*)
|
119
|
export FREEBSD_REPO_BASE_POUDRIERE="ssh://$(echo ${FREEBSD_REPO_BASE} | sed 's,:,/,')"
|
120
|
;;
|
121
|
*)
|
122
|
export FREEBSD_REPO_BASE_POUDRIERE="${FREEBSD_REPO_BASE}"
|
123
|
;;
|
124
|
esac
|
125
|
|
126
|
# Leave this alone.
|
127
|
export SRCCONF=${SRCCONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_src.conf"}
|
128
|
export SRC_ENV_CONF=${SRC_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_src-env.conf"}
|
129
|
export __MAKE_CONF=${__MAKE_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_make.conf"}
|
130
|
|
131
|
# Extra tools to be added to ITOOLS
|
132
|
export LOCAL_ITOOLS=${LOCAL_ITOOLS:-"uuencode uudecode ex"}
|
133
|
|
134
|
# Path to kernel files being built
|
135
|
export KERNEL_BUILD_PATH=${KERNEL_BUILD_PATH:-"${SCRATCHDIR}/kernels"}
|
136
|
|
137
|
# Do not touch builder /usr/obj
|
138
|
export MAKEOBJDIRPREFIX=${MAKEOBJDIRPREFIX:-"${SCRATCHDIR}/obj"}
|
139
|
|
140
|
export MODULES_OVERRIDE=${MODULES_OVERRIDE:-"aesni amdtemp amdsmn coretemp cryptodev cpuctl drm2 fdescfs dummynet hwpmc i2c if_stf ipdivert ipfw ipmi ix ixv ndis nmdm opensolaris sfxge vmm zfs"}
|
141
|
|
142
|
# gnid
|
143
|
export GNID_REPO_BASE=${GNID_REPO_BASE:-"${GIT_REPO_BASE}/gnid.git"}
|
144
|
export GNID_SRC_DIR=${GNID_SRC_DIR:-"${SCRATCHDIR}/gnid"}
|
145
|
export GNID_BRANCH=${GNID_BRANCH:-"master"}
|
146
|
export GNID_INCLUDE_DIR=${GNID_INCLUDE_DIR:-"${MAKEOBJDIRPREFIX}${FREEBSD_SRC_DIR}/${TARGET}.${TARGET_ARCH}/tmp/usr/include"}
|
147
|
export GNID_LIBCRYPTO_DIR=${GNID_LIBCRYPTO_DIR:-"${MAKEOBJDIRPREFIX}${FREEBSD_SRC_DIR}/${TARGET}.${TARGET_ARCH}/secure/lib/libcrypto"}
|
148
|
|
149
|
# Area that the final image will appear in
|
150
|
export IMAGES_FINAL_DIR=${IMAGES_FINAL_DIR:-"${SCRATCHDIR}/${PRODUCT_NAME}/"}
|
151
|
|
152
|
export BUILDER_LOGS=${BUILDER_LOGS:-"${BUILDER_ROOT}/logs"}
|
153
|
if [ ! -d ${BUILDER_LOGS} ]; then
|
154
|
mkdir -p ${BUILDER_LOGS}
|
155
|
fi
|
156
|
|
157
|
# This is where files will be staged
|
158
|
export INSTALLER_CHROOT_DIR=${INSTALLER_CHROOT_DIR:-"${SCRATCHDIR}/installer-dir"}
|
159
|
|
160
|
# This is where files will be staged
|
161
|
export STAGE_CHROOT_DIR=${STAGE_CHROOT_DIR:-"${SCRATCHDIR}/stage-dir"}
|
162
|
|
163
|
# Directory that will clone to in order to create
|
164
|
# iso staging area.
|
165
|
export FINAL_CHROOT_DIR=${FINAL_CHROOT_DIR:-"${SCRATCHDIR}/final-dir"}
|
166
|
|
167
|
# OVF/vmdk parms
|
168
|
# Name of ovf file included inside OVA archive
|
169
|
export OVFTEMPLATE=${OVFTEMPLATE:-"${BUILDER_TOOLS}/templates/ovf/${PRODUCT_NAME}.ovf"}
|
170
|
# / partition to be used by mkimg
|
171
|
export OVFUFS=${OVFUFS:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.ufs"}
|
172
|
# Raw disk to be converted to vmdk
|
173
|
export OVFRAW=${OVFRAW:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.raw"}
|
174
|
# On disk name of VMDK file included in OVA
|
175
|
export OVFVMDK=${OVFVMDK:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.vmdk"}
|
176
|
# 8 gigabyte on disk VMDK size
|
177
|
export VMDK_DISK_CAPACITY_IN_GB=${VMDK_DISK_CAPACITY_IN_GB:-"8"}
|
178
|
# swap partition size (freebsd-swap)
|
179
|
export OVA_SWAP_PART_SIZE_IN_GB=${OVA_SWAP_PART_SIZE_IN_GB:-"0"}
|
180
|
# Temporary place to save files
|
181
|
export OVA_TMP=${OVA_TMP:-"${SCRATCHDIR}/ova_tmp"}
|
182
|
# end of OVF
|
183
|
|
184
|
# NOTE: Date string is used for creating file names of images
|
185
|
# The file is used for sharing the same value with build_snapshots.sh
|
186
|
export DATESTRINGFILE=${DATESTRINGFILE:-"$SCRATCHDIR/version.snapshots"}
|
187
|
if [ -z "${DATESTRING}" ]; then
|
188
|
if [ -f "${DATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
|
189
|
export DATESTRING=$(cat $DATESTRINGFILE)
|
190
|
else
|
191
|
export DATESTRING=$(date "+%Y%m%d-%H%M")
|
192
|
fi
|
193
|
fi
|
194
|
echo "$DATESTRING" > $DATESTRINGFILE
|
195
|
|
196
|
# NOTE: Date string is placed on the final image etc folder to help detect new updates
|
197
|
# The file is used for sharing the same value with build_snapshots.sh
|
198
|
export BUILTDATESTRINGFILE=${BUILTDATESTRINGFILE:-"$SCRATCHDIR/version.buildtime"}
|
199
|
if [ -z "${BUILTDATESTRING}" ]; then
|
200
|
if [ -f "${BUILTDATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
|
201
|
export BUILTDATESTRING=$(cat $BUILTDATESTRINGFILE)
|
202
|
else
|
203
|
export BUILTDATESTRING=$(date "+%a %b %d %T %Z %Y")
|
204
|
fi
|
205
|
fi
|
206
|
echo "$BUILTDATESTRING" > $BUILTDATESTRINGFILE
|
207
|
|
208
|
# Poudriere
|
209
|
export ZFS_TANK=${ZFS_TANK:-"zroot"}
|
210
|
export ZFS_ROOT=${ZFS_ROOT:-"/poudriere"}
|
211
|
|
212
|
export POUDRIERE_BULK=${POUDRIERE_BULK:-"${BUILDER_TOOLS}/conf/pfPorts/poudriere_bulk"}
|
213
|
if [ -z "${REPO_BRANCH_PREFIX}" ]; then
|
214
|
export POUDRIERE_PORTS_GIT_URL=${POUDRIERE_PORTS_GIT_URL:-"${GIT_REPO_BASE}/freebsd-ports.git"}
|
215
|
else
|
216
|
export POUDRIERE_PORTS_GIT_URL=${POUDRIERE_PORTS_GIT_URL:-"${GIT_REPO_BASE}/${REPO_BRANCH_PREFIX}ports.git"}
|
217
|
fi
|
218
|
export POUDRIERE_PORTS_GIT_BRANCH=${POUDRIERE_PORTS_GIT_BRANCH:-"${REPO_BRANCH_PREFIX}devel"}
|
219
|
|
220
|
# Use vX_Y instead of RELENG_X_Y for poudriere to make it shorter
|
221
|
POUDRIERE_PORTS_BRANCH=$(echo "${POUDRIERE_PORTS_GIT_BRANCH}" | sed 's,RELENG_,v,')
|
222
|
|
223
|
export POUDRIERE_PORTS_NAME=${POUDRIERE_PORTS_NAME:-"${PRODUCT_NAME}_${POUDRIERE_PORTS_BRANCH}"}
|
224
|
|
225
|
# XXX: Poudriere doesn't like ssh short form
|
226
|
case "${POUDRIERE_PORTS_GIT_URL}" in
|
227
|
git@*)
|
228
|
POUDRIERE_PORTS_GIT_URL="ssh://$(echo ${POUDRIERE_PORTS_GIT_URL} | sed 's,:,/,')"
|
229
|
;;
|
230
|
esac
|
231
|
|
232
|
unset _IS_RELEASE
|
233
|
unset _IS_RC
|
234
|
unset CORE_PKG_DATESTRING
|
235
|
export TIMESTAMP_SUFFIX="-${DATESTRING}"
|
236
|
# pkg doesn't like - as version separator, use . instead
|
237
|
export PKG_DATESTRING=$(echo "${DATESTRING}" | sed 's,-,.,g')
|
238
|
case "${PRODUCT_VERSION##*-}" in
|
239
|
RELEASE)
|
240
|
export _IS_RELEASE=yes
|
241
|
unset TIMESTAMP_SUFFIX
|
242
|
;;
|
243
|
ALPHA|DEVELOPMENT)
|
244
|
export CORE_PKG_DATESTRING=".a.${PKG_DATESTRING}"
|
245
|
;;
|
246
|
BETA*)
|
247
|
export CORE_PKG_DATESTRING=".b.${PKG_DATESTRING}"
|
248
|
;;
|
249
|
RC*)
|
250
|
export _IS_RC=yes
|
251
|
export CORE_PKG_DATESTRING=".r.${PKG_DATESTRING}"
|
252
|
;;
|
253
|
*)
|
254
|
echo ">>> ERROR: Invalid PRODUCT_VERSION format ${PRODUCT_VERSION}"
|
255
|
exit 1
|
256
|
esac
|
257
|
|
258
|
export BUILDER_PKG_DEPENDENCIES="devel/git ftp/curl net/rsync sysutils/screen \
|
259
|
sysutils/vmdktool security/sudo www/nginx emulators/qemu-user-static \
|
260
|
archivers/gtar textproc/xmlstarlet"
|
261
|
|
262
|
STAGING_HOSTNAME=${STAGING_HOSTNAME:-"release-staging.nyi.netgate.com"}
|
263
|
|
264
|
# Host to rsync pkg repos from poudriere
|
265
|
export PKG_RSYNC_HOSTNAME=${PKG_RSYNC_HOSTNAME:-"nfs1.nyi.netgate.com"}
|
266
|
export PKG_RSYNC_USERNAME=${PKG_RSYNC_USERNAME:-"wwwsync"}
|
267
|
export PKG_RSYNC_SSH_PORT=${PKG_RSYNC_SSH_PORT:-"22"}
|
268
|
export PKG_RSYNC_DESTDIR=${PKG_RSYNC_DESTDIR:-"/storage/files/release-staging/ce/packages"}
|
269
|
|
270
|
# Final packages server
|
271
|
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
|
272
|
export PKG_FINAL_RSYNC_HOSTNAME=${PKG_FINAL_RSYNC_HOSTNAME:-"nfs1.nyi.netgate.com"}
|
273
|
export PKG_FINAL_RSYNC_DESTDIR=${PKG_FINAL_RSYNC_DESTDIR:-"/storage/files/pkg"}
|
274
|
else
|
275
|
export PKG_FINAL_RSYNC_HOSTNAME=${PKG_FINAL_RSYNC_HOSTNAME:-"nfs1.nyi.netgate.com"}
|
276
|
export PKG_FINAL_RSYNC_DESTDIR=${PKG_FINAL_RSYNC_DESTDIR:-"/storage/files/beta/packages"}
|
277
|
fi
|
278
|
export PKG_FINAL_RSYNC_USERNAME=${PKG_FINAL_RSYNC_USERNAME:-"wwwsync"}
|
279
|
export PKG_FINAL_RSYNC_SSH_PORT=${PKG_FINAL_RSYNC_SSH_PORT:-"22"}
|
280
|
export SKIP_FINAL_RSYNC=${SKIP_FINAL_RSYNC:-}
|
281
|
|
282
|
# pkg repo variables
|
283
|
export USE_PKG_REPO_STAGING="1"
|
284
|
export PKG_REPO_SERVER_DEVEL=${PKG_REPO_SERVER_DEVEL:-"pkg+https://beta.pfsense.org/packages"}
|
285
|
export PKG_REPO_SERVER_RELEASE=${PKG_REPO_SERVER_RELEASE:-"pkg+https://pkg.pfsense.org"}
|
286
|
export PKG_REPO_SERVER_STAGING=${PKG_REPO_SERVER_STAGING:-"pkg+http://${STAGING_HOSTNAME}/ce/packages"}
|
287
|
|
288
|
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
|
289
|
export PKG_REPO_BRANCH_RELEASE=${PKG_REPO_BRANCH_RELEASE:-"${REPO_BRANCH_PREFIX}v2_4_4"}
|
290
|
export PKG_REPO_BRANCH_DEVEL=${PKG_REPO_BRANCH_DEVEL:-${POUDRIERE_BRANCH}}
|
291
|
export PKG_REPO_BRANCH_STAGING=${PKG_REPO_BRANCH_STAGING:-${PKG_REPO_BRANCH_RELEASE}}
|
292
|
else
|
293
|
export PKG_REPO_BRANCH_RELEASE=${PKG_REPO_BRANCH_RELEASE:-"${REPO_BRANCH_PREFIX}v2_4_4"}
|
294
|
export PKG_REPO_BRANCH_DEVEL=${PKG_REPO_BRANCH_DEVEL:-${POUDRIERE_BRANCH}}
|
295
|
export PKG_REPO_BRANCH_STAGING=${PKG_REPO_BRANCH_STAGING:-${PKG_REPO_BRANCH_DEVEL}}
|
296
|
fi
|
297
|
|
298
|
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
|
299
|
export PKG_REPO_SIGN_KEY=${PKG_REPO_SIGN_KEY:-"release${PRODUCT_NAME_SUFFIX}"}
|
300
|
else
|
301
|
export PKG_REPO_SIGN_KEY=${PKG_REPO_SIGN_KEY:-"beta${PRODUCT_NAME_SUFFIX}"}
|
302
|
fi
|
303
|
# Command used to sign pkg repo
|
304
|
: ${PKG_REPO_SIGNING_COMMAND="ssh sign@codesigner.netgate.com sudo ./sign.sh ${PKG_REPO_SIGN_KEY}"}
|
305
|
export PKG_REPO_SIGNING_COMMAND
|
306
|
export DO_NOT_SIGN_PKG_REPO=${DO_NOT_SIGN_PKG_REPO:-}
|
307
|
|
308
|
# Define base package version, based on date for snaps
|
309
|
export CORE_PKG_VERSION="${PRODUCT_VERSION%%-*}${CORE_PKG_DATESTRING}${PRODUCT_REVISION:+_}${PRODUCT_REVISION}"
|
310
|
export CORE_PKG_PATH=${CORE_PKG_PATH:-"${SCRATCHDIR}/${PRODUCT_NAME}_${POUDRIERE_BRANCH}_${TARGET_ARCH}-core"}
|
311
|
export CORE_PKG_REAL_PATH="${CORE_PKG_PATH}/.real_${DATESTRING}"
|
312
|
export CORE_PKG_ALL_PATH="${CORE_PKG_PATH}/All"
|
313
|
|
314
|
export PKG_REPO_BASE=${PKG_REPO_BASE:-"${BUILDER_TOOLS}/templates/pkg_repos"}
|
315
|
export PFSENSE_DEFAULT_REPO="${PRODUCT_NAME}-repo-devel"
|
316
|
export PKG_REPO_DEFAULT=${PKG_REPO_DEFAULT:-"${PKG_REPO_BASE}/${PFSENSE_DEFAULT_REPO}.conf"}
|
317
|
export PFSENSE_BUILD_REPO="${PFSENSE_DEFAULT_REPO}"
|
318
|
export PKG_REPO_BUILD=${PKG_REPO_BUILD:-"${PKG_REPO_BASE}/${PFSENSE_BUILD_REPO}.conf"}
|
319
|
export PKG_REPO_PATH=${PKG_REPO_PATH:-"/usr/local/etc/pkg/repos/${PRODUCT_NAME}.conf"}
|
320
|
|
321
|
export PRODUCT_SHARE_DIR=${PRODUCT_SHARE_DIR:-"/usr/local/share/${PRODUCT_NAME}"}
|
322
|
|
323
|
# Package overlay. This gives people a chance to build product
|
324
|
# installable image that already contains certain extra packages.
|
325
|
#
|
326
|
# Needs to contain comma separated package names. Of course
|
327
|
# package names must be valid. Using non existent
|
328
|
# package name would yield an error.
|
329
|
#
|
330
|
#export custom_package_list=""
|
331
|
|
332
|
# General builder output filenames
|
333
|
export ISOPATH=${ISOPATH:-"${IMAGES_FINAL_DIR}/installer/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.iso"}
|
334
|
export MEMSTICKPATH=${MEMSTICKPATH:-"${IMAGES_FINAL_DIR}/installer/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
|
335
|
export MEMSTICKSERIALPATH=${MEMSTICKSERIALPATH:-"${IMAGES_FINAL_DIR}/installer/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-serial-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
|
336
|
export MEMSTICKADIPATH=${MEMSTICKADIPATH:-"${IMAGES_FINAL_DIR}/installer/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-ADI-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
|
337
|
export OVAPATH=${OVAPATH:-"${IMAGES_FINAL_DIR}/virtualization/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.ova"}
|
338
|
export MEMSTICK_VARIANTS=${MEMSTICK_VARIANTS:-}
|
339
|
export VARIANTIMAGES=""
|
340
|
export VARIANTUPDATES=""
|
341
|
|
342
|
# Rsync data to send snapshots
|
343
|
if [ -n "${_IS_RELEASE}" -o -n "${SKIP_FINAL_RSYNC}" ]; then
|
344
|
export RSYNCIP=${RSYNCIP:-"nfs1.nyi.netgate.com"}
|
345
|
export RSYNCUSER=${RSYNCUSER:-"wwwsync"}
|
346
|
export RSYNCPATH=${RSYNCPATH:-"/storage/files/release-staging/ce/images"}
|
347
|
else
|
348
|
export RSYNCIP=${RSYNCIP:-"nfs1.nyi.netgate.com"}
|
349
|
export RSYNCUSER=${RSYNCUSER:-"wwwsync"}
|
350
|
export RSYNCPATH=${RSYNCPATH:-"/storage/files/snapshots/${TARGET}/${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}"}
|
351
|
fi
|
352
|
|
353
|
export SNAPSHOTSLOGFILE=${SNAPSHOTSLOGFILE:-"${SCRATCHDIR}/snapshots-build.log"}
|
354
|
export SNAPSHOTSLASTUPDATE=${SNAPSHOTSLASTUPDATE:-"${SCRATCHDIR}/snapshots-lastupdate.log"}
|
355
|
|
356
|
if [ -n "${POUDRIERE_SNAPSHOTS}" ]; then
|
357
|
export SNAPSHOTS_RSYNCIP=${PKG_RSYNC_HOSTNAME}
|
358
|
export SNAPSHOTS_RSYNCUSER=${PKG_RSYNC_USERNAME}
|
359
|
else
|
360
|
export SNAPSHOTS_RSYNCIP=${RSYNCIP}
|
361
|
export SNAPSHOTS_RSYNCUSER=${RSYNCUSER}
|
362
|
fi
|
363
|
|
364
|
if [ "${PRODUCT_NAME}" = "pfSense" ]; then
|
365
|
export VENDOR_NAME=${VENDOR_NAME:-"Rubicon Communications, LLC (Netgate)"}
|
366
|
export OVF_INFO=${OVF_INFO:-"pfSense is a free, open source customized distribution of FreeBSD tailored for use as a firewall and router. In addition to being a powerful, flexible firewalling and routing platform, it includes a long list of related features and a package system allowing further expandability without adding bloat and potential security vulnerabilities to the base distribution. pfSense is a popular project with more than 1 million downloads since its inception, and proven in countless installations ranging from small home networks protecting a PC and an Xbox to large corporations, universities and other organizations protecting thousands of network devices."}
|
367
|
else
|
368
|
export VENDOR_NAME=${VENDOR_NAME:-"nonSense"}
|
369
|
export OVF_INFO=${OVF_INFO:-"none"}
|
370
|
fi
|