Project

General

Profile

Download (18.6 KB) Statistics
| Branch: | Tag: | Revision:
1
#!/bin/sh
2
#
3
# builder_defaults.sh
4
#
5
# part of pfSense (https://www.pfsense.org)
6
# Copyright (c) 2004-2016 Rubicon Communications, LLC (Netgate)
7
# All rights reserved.
8
#
9
# Redistribution and use in source and binary forms, with or without
10
# modification, are permitted provided that the following conditions are met:
11
#
12
# 1. Redistributions of source code must retain the above copyright notice,
13
#    this list of conditions and the following disclaimer.
14
#
15
# 2. Redistributions in binary form must reproduce the above copyright
16
#    notice, this list of conditions and the following disclaimer in
17
#    the documentation and/or other materials provided with the
18
#    distribution.
19
#
20
# 3. All advertising materials mentioning features or use of this software
21
#    must display the following acknowledgment:
22
#    "This product includes software developed by the pfSense Project
23
#    for use in the pfSense® software distribution. (http://www.pfsense.org/).
24
#
25
# 4. The names "pfSense" and "pfSense Project" must not be used to
26
#    endorse or promote products derived from this software without
27
#    prior written permission. For written permission, please contact
28
#    coreteam@pfsense.org.
29
#
30
# 5. Products derived from this software may not be called "pfSense"
31
#    nor may "pfSense" appear in their names without prior written
32
#    permission of the Electric Sheep Fencing, LLC.
33
#
34
# 6. Redistributions of any form whatsoever must retain the following
35
#    acknowledgment:
36
#
37
# "This product includes software developed by the pfSense Project
38
# for use in the pfSense software distribution (http://www.pfsense.org/).
39
#
40
# THIS SOFTWARE IS PROVIDED BY THE pfSense PROJECT ``AS IS'' AND ANY
41
# EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
43
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE pfSense PROJECT OR
44
# ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
45
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
46
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
47
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
48
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
49
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
50
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
51
# OF THE POSSIBILITY OF SUCH DAMAGE.
52

    
53
###########################################
54
# Product builder configuration file      #
55
# Please don't modify this file, you      #
56
# can put your settings and options       #
57
# in build.conf, which is sourced at the  #
58
# beginning of this file                  #
59
###########################################
60

    
61
if [ -z "${BUILDER_ROOT}" ]; then
62
	echo ">>> ERROR: BUILDER_ROOT must be defined by script that includes builder_defaults.sh"
63
	exit 1
64
fi
65

    
66
if [ ! -d "${BUILDER_ROOT}" ]; then
67
	echo ">>> ERROR: BUILDER_ROOT is invalid"
68
	exit 1
69
fi
70

    
71
export BUILDER_TOOLS=${BUILDER_TOOLS:-"${BUILDER_ROOT}/tools"}
72

    
73
if [ ! -d "${BUILDER_TOOLS}" ]; then
74
	echo ">>> ERROR: BUILDER_TOOLS is invalid"
75
	exit 1
76
fi
77

    
78
BUILD_CONF="${BUILDER_ROOT}/build.conf"
79

    
80
# Ensure file exists
81
if [ -f ${BUILD_CONF} ]; then
82
	. ${BUILD_CONF}
83
fi
84

    
85
# Make sure pkg will not be interactive
86
export ASSUME_ALWAYS_YES=true
87

    
88
# Architecture, supported ARCH values are:
89
#  Tier 1: i386, AMD64, and PC98
90
#  Tier 2: ARM, PowerPC, ia64, Sparc64 and sun4v
91
#  Tier 3: MIPS and S/390
92
#  Tier 4: None at the moment
93
#  Source: http://www.freebsd.org/doc/en/articles/committers-guide/archs.html
94
export TARGET=${TARGET:-"`uname -m`"}
95
export TARGET_ARCH=${TARGET_ARCH:-${TARGET}}
96
# Set TARGET_ARCH_CONF_DIR
97
if [ "$TARGET_ARCH" = "" ]; then
98
        export TARGET_ARCH=`uname -p`
99
fi
100

    
101
# Directory to be used for writing temporary information
102
export SCRATCHDIR=${SCRATCHDIR:-"${BUILDER_ROOT}/tmp"}
103
if [ ! -d ${SCRATCHDIR} ]; then
104
	mkdir -p ${SCRATCHDIR}
105
fi
106

    
107
# Product details
108
export PRODUCT_NAME=${PRODUCT_NAME:-"nonSense"}
109
export PRODUCT_NAME_SUFFIX=${PRODUCT_NAME_SUFFIX:-"-CE"}
110
export PRODUCT_URL=${PRODUCT_URL:-""}
111
export PRODUCT_SRC=${PRODUCT_SRC:-"${BUILDER_ROOT}/src"}
112
export PRODUCT_EMAIL=${PRODUCT_EMAIL:-"coreteam@pfsense.org"}
113
export XML_ROOTOBJ=${XML_ROOTOBJ:-$(echo "${PRODUCT_NAME}" | tr '[[:upper:]]' '[[:lower:]]')}
114

    
115
if [ "${PRODUCT_NAME}" = "pfSense" -a "${BUILD_AUTHORIZED_BY_NETGATE}" != "yes" ]; then
116
	echo ">>>ERROR: According the following license, only Netgate can build genuine pfSense® software"
117
	echo ""
118
	cat ${BUILDER_ROOT}/license.txt
119
	exit 1
120
fi
121

    
122
if [ -z "${PRODUCT_VERSION}" ]; then
123
	if [ ! -f ${PRODUCT_SRC}/etc/version ]; then
124
		echo ">>> ERROR: PRODUCT_VERSION is not defined and ${PRODUCT_SRC}/etc/version was not found"
125
		print_error_pfS
126
	fi
127

    
128
	export PRODUCT_VERSION=$(head -n 1 ${PRODUCT_SRC}/etc/version)
129
fi
130
export PRODUCT_REVISION=${PRODUCT_REVISION:-""}
131

    
132
# Product repository tag to build
133
_cur_git_repo_branch_or_tag=$(git -C ${BUILDER_ROOT} rev-parse --abbrev-ref HEAD)
134
if [ "${_cur_git_repo_branch_or_tag}" = "HEAD" ]; then
135
	# We are on a tag, lets find out its name
136
	export GIT_REPO_BRANCH_OR_TAG=$(git -C ${BUILDER_ROOT} describe --tags)
137
else
138
	export GIT_REPO_BRANCH_OR_TAG="${_cur_git_repo_branch_or_tag}"
139
fi
140
# Use vX_Y instead of RELENG_X_Y for poudriere to make it shorter
141
# Replace . by _ to make tag names look correct
142
POUDRIERE_BRANCH=$(echo "${GIT_REPO_BRANCH_OR_TAG}" | sed 's,RELENG_,v,; s,\.,_,g')
143

    
144
GIT_REPO_BASE=$(git -C ${BUILDER_ROOT} config --get remote.origin.url | sed -e 's,/[^/]*$,,')
145

    
146
# This is used for using svn for retrieving src
147
export FREEBSD_REPO_BASE=${FREEBSD_REPO_BASE:-"${GIT_REPO_BASE}/freebsd-src.git"}
148
export FREEBSD_BRANCH=${FREEBSD_BRANCH:-"RELENG_2_3"}
149
export FREEBSD_PARENT_BRANCH=${FREEBSD_PARENT_BRANCH:-"releng/10.3"}
150
export FREEBSD_SRC_DIR=${FREEBSD_SRC_DIR:-"${SCRATCHDIR}/FreeBSD-src"}
151

    
152
if [ "${TARGET}" = "i386" ]; then
153
	export BUILD_KERNELS=${BUILD_KERNELS:-"${PRODUCT_NAME} ${PRODUCT_NAME}_wrap ${PRODUCT_NAME}_wrap_vga"}
154
else
155
	export BUILD_KERNELS=${BUILD_KERNELS:-"${PRODUCT_NAME}"}
156
fi
157

    
158
# Leave this alone.
159
export SRC_CONF=${SRC_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_src.conf"}
160
export MAKE_CONF=${MAKE_CONF:-"${FREEBSD_SRC_DIR}/release/conf/${PRODUCT_NAME}_make.conf"}
161

    
162
# Extra tools to be added to ITOOLS
163
export EXTRA_TOOLS=${EXTRA_TOOLS:-"uuencode uudecode ex"}
164

    
165
# Path to kernel files being built
166
export KERNEL_BUILD_PATH=${KERNEL_BUILD_PATH:-"${SCRATCHDIR}/kernels"}
167

    
168
# Do not touch builder /usr/obj
169
export MAKEOBJDIRPREFIX=${MAKEOBJDIRPREFIX:-"${SCRATCHDIR}/obj"}
170

    
171
# Controls how many concurrent make processes are run for each stage
172
_CPUS=""
173
if [ -z "${NO_MAKEJ}" ]; then
174
	_CPUS=$(expr $(sysctl -n kern.smp.cpus) '*' 2)
175
	if [ -n "${_CPUS}" ]; then
176
		_CPUS="-j${_CPUS}"
177
	fi
178
fi
179

    
180
export MAKEJ_WORLD=${MAKEJ_WORLD:-"${_CPUS}"}
181
export MAKEJ_KERNEL=${MAKEJ_KERNEL:-"${_CPUS}"}
182

    
183
if [ "${TARGET}" = "i386" ]; then
184
	export MODULES_OVERRIDE=${MODULES_OVERRIDE:-"i2c ipmi ndis ipfw ipdivert dummynet fdescfs opensolaris zfs glxsb if_stf coretemp amdtemp hwpmc"}
185
else
186
	export MODULES_OVERRIDE=${MODULES_OVERRIDE:-"i2c ipmi ndis ipfw ipdivert dummynet fdescfs opensolaris zfs glxsb if_stf coretemp amdtemp aesni sfxge hwpmc vmm nmdm ixgbe"}
187
fi
188

    
189
# gnid
190
export GNID_REPO_BASE=${GNID_REPO_BASE:-"${GIT_REPO_BASE}/gnid.git"}
191
export GNID_SRC_DIR=${GNID_SRC_DIR:-"${SCRATCHDIR}/gnid"}
192
export GNID_BRANCH=${GNID_BRANCH:-"master"}
193
export GNID_INCLUDE_DIR=${GNID_INCLUDE_DIR:-"${MAKEOBJDIRPREFIX}/${FREEBSD_SRC_DIR}/tmp/usr/include"}
194
export GNID_LIBCRYPTO_DIR=${GNID_LIBCRYPTO_DIR:-"${MAKEOBJDIRPREFIX}/${FREEBSD_SRC_DIR}/secure/lib/libcrypto"}
195

    
196
# Area that the final image will appear in
197
export IMAGES_FINAL_DIR=${IMAGES_FINAL_DIR:-"${SCRATCHDIR}/${PRODUCT_NAME}/"}
198

    
199
export BUILDER_LOGS=${BUILDER_LOGS:-"${BUILDER_ROOT}/logs"}
200
if [ ! -d ${BUILDER_LOGS} ]; then
201
	mkdir -p ${BUILDER_LOGS}
202
fi
203

    
204
# This is where files will be staged
205
export STAGE_CHROOT_DIR=${STAGE_CHROOT_DIR:-"${SCRATCHDIR}/stage-dir"}
206

    
207
# Directory that will clone to in order to create
208
# iso staging area.
209
export FINAL_CHROOT_DIR=${FINAL_CHROOT_DIR:-"${SCRATCHDIR}/final-dir"}
210

    
211
# OVF/vmdk parms
212
# Name of ovf file included inside OVA archive
213
export OVFTEMPLATE=${OVFTEMPLATE:-"${BUILDER_TOOLS}/templates/ovf/${PRODUCT_NAME}.ovf"}
214
# / partition to be used by mkimg
215
export OVFUFS=${OVFUFS:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.ufs"}
216
# Raw disk to be converted to vmdk
217
export OVFRAW=${OVFRAW:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.raw"}
218
# On disk name of VMDK file included in OVA
219
export OVFVMDK=${OVFVMDK:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-disk1.vmdk"}
220
# 8 gigabyte on disk VMDK size
221
export VMDK_DISK_CAPACITY_IN_GB=${VMDK_DISK_CAPACITY_IN_GB:-"8"}
222
# swap partition size (freebsd-swap)
223
export OVA_SWAP_PART_SIZE_IN_GB=${OVA_SWAP_PART_SIZE_IN_GB:-"0"}
224
# Temporary place to save files
225
export OVA_TMP=${OVA_TMP:-"${SCRATCHDIR}/ova_tmp"}
226
# end of OVF
227

    
228
# Number of code images on media (1 or 2)
229
export NANO_IMAGES=2
230
# 0 -> Leave second image all zeroes so it compresses better.
231
# 1 -> Initialize second image with a copy of the first
232
export NANO_INIT_IMG2=1
233
export NANO_NEWFS="-b 4096 -f 512 -i 8192 -O1"
234
export FLASH_SIZE=${FLASH_SIZE:-"2g"}
235
# Size of code file system in 512 bytes sectors
236
# If zero, size will be as large as possible.
237
export NANO_CODESIZE=0
238
# Size of data file system in 512 bytes sectors
239
# If zero: no partition configured.
240
# If negative: max size possible
241
export NANO_DATASIZE=0
242
# Size of Product /conf partition  # 102400 = 50 megabytes.
243
export NANO_CONFSIZE=102400
244
# packet is OK for 90% of embedded
245
export NANO_BOOT0CFG="-o packet -s 1 -m 3"
246

    
247
# NOTE: Date string is used for creating file names of images
248
#       The file is used for sharing the same value with build_snapshots.sh
249
export DATESTRINGFILE=${DATESTRINGFILE:-"$SCRATCHDIR/version.snapshots"}
250
if [ -z "${DATESTRING}" ]; then
251
	if [ -f "${DATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
252
		export DATESTRING=$(cat $DATESTRINGFILE)
253
	else
254
		export DATESTRING=$(date "+%Y%m%d-%H%M")
255
	fi
256
fi
257
echo "$DATESTRING" > $DATESTRINGFILE
258

    
259
# NOTE: Date string is placed on the final image etc folder to help detect new updates
260
#       The file is used for sharing the same value with build_snapshots.sh
261
export BUILTDATESTRINGFILE=${BUILTDATESTRINGFILE:-"$SCRATCHDIR/version.buildtime"}
262
if [ -z "${BUILTDATESTRING}" ]; then
263
	if [ -f "${BUILTDATESTRINGFILE}" -a -n "${_USE_OLD_DATESTRING}" ]; then
264
		export BUILTDATESTRING=$(cat $BUILTDATESTRINGFILE)
265
	else
266
		export BUILTDATESTRING=$(date "+%a %b %d %T %Z %Y")
267
	fi
268
fi
269
echo "$BUILTDATESTRING" > $BUILTDATESTRINGFILE
270

    
271
STAGING_HOSTNAME=${STAGING_HOSTNAME:-"release-staging.netgate.com"}
272

    
273
# Poudriere
274
export ZFS_TANK=${ZFS_TANK:-"zroot"}
275
export ZFS_ROOT=${ZFS_ROOT:-"/poudriere"}
276
export POUDRIERE_PORTS_NAME=${POUDRIERE_PORTS_NAME:-"${PRODUCT_NAME}_${POUDRIERE_BRANCH}"}
277

    
278
export POUDRIERE_BULK=${POUDRIERE_BULK:-"${BUILDER_TOOLS}/conf/pfPorts/poudriere_bulk"}
279
export POUDRIERE_PORTS_GIT_URL=${POUDRIERE_PORTS_GIT_URL:-"${GIT_REPO_BASE}/freebsd-ports.git"}
280
export POUDRIERE_PORTS_GIT_BRANCH=${POUDRIERE_PORTS_GIT_BRANCH:-"RELENG_2_3_5"}
281

    
282
unset _IS_RELEASE
283
unset _IS_RC
284
unset CORE_PKG_DATESTRING
285
export TIMESTAMP_SUFFIX="-${DATESTRING}"
286
# pkg doesn't like - as version separator, use . instead
287
export PKG_DATESTRING=$(echo "${DATESTRING}" | sed 's,-,.,g')
288
case "${PRODUCT_VERSION##*-}" in
289
	RELEASE)
290
		export _IS_RELEASE=yes
291
		unset TIMESTAMP_SUFFIX
292
		;;
293
	ALPHA|DEVELOPMENT)
294
		export CORE_PKG_DATESTRING=".a.${PKG_DATESTRING}"
295
		;;
296
	BETA*)
297
		export CORE_PKG_DATESTRING=".b.${PKG_DATESTRING}"
298
		;;
299
	RC*)
300
		export _IS_RC=yes
301
		export CORE_PKG_DATESTRING=".r.${PKG_DATESTRING}"
302
		;;
303
	*)
304
		echo ">>> ERROR: Invalid PRODUCT_VERSION format ${PRODUCT_VERSION}"
305
		exit 1
306
esac
307

    
308
# Host to rsync pkg repos from poudriere
309
export PKG_RSYNC_HOSTNAME=${PKG_RSYNC_HOSTNAME:-${STAGING_HOSTNAME}}
310
export PKG_RSYNC_USERNAME=${PKG_RSYNC_USERNAME:-"wwwsync"}
311
export PKG_RSYNC_SSH_PORT=${PKG_RSYNC_SSH_PORT:-"22"}
312
export PKG_RSYNC_DESTDIR=${PKG_RSYNC_DESTDIR:-"/staging/ce/packages"}
313
export PKG_RSYNC_LOGS=${PKG_RSYNC_LOGS:-"/staging/ce/packages/logs/${POUDRIERE_BRANCH}/${TARGET}"}
314

    
315
# Final packages server
316
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
317
	export PKG_FINAL_RSYNC_HOSTNAME=${PKG_FINAL_RSYNC_HOSTNAME:-"nfs1.nyi.netgate.com"}
318
	export PKG_FINAL_RSYNC_DESTDIR=${PKG_FINAL_RSYNC_DESTDIR:-"/storage/files/pkg"}
319
else
320
	export PKG_FINAL_RSYNC_HOSTNAME=${PKG_FINAL_RSYNC_HOSTNAME:-"nfs1.nyi.netgate.com"}
321
	export PKG_FINAL_RSYNC_DESTDIR=${PKG_FINAL_RSYNC_DESTDIR:-"/storage/files/beta/packages"}
322
fi
323
export PKG_FINAL_RSYNC_USERNAME=${PKG_FINAL_RSYNC_USERNAME:-"wwwsync"}
324
export PKG_FINAL_RSYNC_SSH_PORT=${PKG_FINAL_RSYNC_SSH_PORT:-"22"}
325
export SKIP_FINAL_RSYNC=${SKIP_FINAL_RSYNC:-}
326

    
327
# pkg repo variables
328
export USE_PKG_REPO_STAGING="1"
329
export PKG_REPO_SERVER_DEVEL=${PKG_REPO_SERVER_DEVEL:-"pkg+https://beta.pfsense.org/packages"}
330
export PKG_REPO_SERVER_RELEASE=${PKG_REPO_SERVER_RELEASE:-"pkg+https://pkg.pfsense.org"}
331
export PKG_REPO_SERVER_STAGING=${PKG_REPO_SERVER_STAGING:-"pkg+http://${STAGING_HOSTNAME}/ce/packages"}
332

    
333
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
334
	export PKG_REPO_BRANCH_RELEASE=${PKG_REPO_BRANCH_RELEASE:-${POUDRIERE_BRANCH}}
335
	export PKG_REPO_BRANCH_DEVEL=${PKG_REPO_BRANCH_DEVEL:-"v2_3"}
336
	export PKG_REPO_BRANCH_STAGING=${PKG_REPO_BRANCH_STAGING:-${PKG_REPO_BRANCH_RELEASE}}
337
else
338
	export PKG_REPO_BRANCH_RELEASE=${PKG_REPO_BRANCH_RELEASE:-"v2_3_5"}
339
	export PKG_REPO_BRANCH_DEVEL=${PKG_REPO_BRANCH_DEVEL:-${POUDRIERE_BRANCH}}
340
	export PKG_REPO_BRANCH_STAGING=${PKG_REPO_BRANCH_STAGING:-${PKG_REPO_BRANCH_DEVEL}}
341
fi
342

    
343
if [ -n "${_IS_RELEASE}" -o -n "${_IS_RC}" ]; then
344
	export PKG_REPO_SIGN_KEY=${PKG_REPO_SIGN_KEY:-"release${PRODUCT_NAME_SUFFIX}"}
345
else
346
	export PKG_REPO_SIGN_KEY=${PKG_REPO_SIGN_KEY:-"beta${PRODUCT_NAME_SUFFIX}"}
347
fi
348
# Command used to sign pkg repo
349
export PKG_REPO_SIGNING_COMMAND=${PKG_REPO_SIGNING_COMMAND:-"ssh sign@codesigner.netgate.com sudo ./sign.sh ${PKG_REPO_SIGN_KEY}"}
350
export DO_NOT_SIGN_PKG_REPO=${DO_NOT_SIGN_PKG_REPO:-}
351

    
352
# Define base package version, based on date for snaps
353
export CORE_PKG_VERSION="${PRODUCT_VERSION%%-*}${CORE_PKG_DATESTRING}${PRODUCT_REVISION:+_}${PRODUCT_REVISION}"
354
export CORE_PKG_PATH=${CORE_PKG_PATH:-"${SCRATCHDIR}/${PRODUCT_NAME}_${POUDRIERE_BRANCH}_${TARGET_ARCH}-core"}
355
export CORE_PKG_REAL_PATH="${CORE_PKG_PATH}/.real_${DATESTRING}"
356
export CORE_PKG_ALL_PATH="${CORE_PKG_PATH}/All"
357
export CORE_PKG_TMP=${CORE_PKG_TMP:-"${SCRATCHDIR}/core_pkg_tmp"}
358

    
359
export PKG_REPO_BASE=${PKG_REPO_BASE:-"${BUILDER_TOOLS}/templates/pkg_repos"}
360
export PFSENSE_DEFAULT_REPO_amd64="${PRODUCT_NAME}-repo-23"
361
export PKG_REPO_DEFAULT_amd64=${PKG_REPO_DEFAULT_amd64:-"${PKG_REPO_BASE}/${PFSENSE_DEFAULT_REPO_amd64}.conf"}
362
export PFSENSE_DEFAULT_REPO_i386="${PRODUCT_NAME}-repo"
363
export PKG_REPO_DEFAULT_i386=${PKG_REPO_DEFAULT_i386:-"${PKG_REPO_BASE}_i386/${PFSENSE_DEFAULT_REPO_i386}.conf"}
364
export PKG_REPO_PATH=${PKG_REPO_PATH:-"/usr/local/etc/pkg/repos/${PRODUCT_NAME}.conf"}
365

    
366
export PRODUCT_SHARE_DIR=${PRODUCT_SHARE_DIR:-"/usr/local/share/${PRODUCT_NAME}"}
367

    
368
# Package overlay. This gives people a chance to build product
369
# installable image that already contains certain extra packages.
370
#
371
# Needs to contain comma separated package names. Of course
372
# package names must be valid. Using non existent
373
# package name would yield an error.
374
#
375
#export custom_package_list=""
376

    
377
# General builder output filenames
378
export UPDATESDIR=${UPDATESDIR:-"${IMAGES_FINAL_DIR}/updates"}
379
export ISOPATH=${ISOPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.iso"}
380
export MEMSTICKPATH=${MEMSTICKPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
381
export MEMSTICKSERIALPATH=${MEMSTICKSERIALPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-serial-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
382
export MEMSTICKADIPATH=${MEMSTICKADIPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-memstick-ADI-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.img"}
383
export OVAPATH=${OVAPATH:-"${IMAGES_FINAL_DIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.ova"}
384
export MEMSTICK_VARIANTS=${MEMSTICK_VARIANTS:-}
385
export VARIANTIMAGES=""
386
export VARIANTUPDATES=""
387

    
388
# set full-update update filename
389
export UPDATES_TARBALL_FILENAME=${UPDATES_TARBALL_FILENAME:-"${UPDATESDIR}/${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-Full-Update-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-${TARGET}${TIMESTAMP_SUFFIX}.tgz"}
390

    
391
# nanobsd templates
392
export NANOBSD_IMG_TEMPLATE=${NANOBSD_IMG_TEMPLATE:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-%%SIZE%%-${TARGET}-%%TYPE%%${TIMESTAMP_SUFFIX}.img"}
393
export NANOBSD_UPGRADE_TEMPLATE=${NANOBSD_UPGRADE_TEMPLATE:-"${PRODUCT_NAME}${PRODUCT_NAME_SUFFIX}-${PRODUCT_VERSION}${PRODUCT_REVISION:+-p}${PRODUCT_REVISION}-%%SIZE%%-${TARGET}-%%TYPE%%-upgrade${TIMESTAMP_SUFFIX}.img"}
394

    
395
# Rsync data to send snapshots
396
if [ -n "${_IS_RELEASE}" ]; then
397
	export RSYNCIP=${RSYNCIP:-"release-staging.netgate.com"}
398
	export RSYNCUSER=${RSYNCUSER:-"wwwsync"}
399
	export RSYNCPATH=${RSYNCPATH:-"/staging/ce/images"}
400
else
401
	export RSYNCIP=${RSYNCIP:-"nfs1.nyi.netgate.com"}
402
	export RSYNCUSER=${RSYNCUSER:-"wwwsync"}
403
	export RSYNCPATH=${RSYNCPATH:-"/storage/files/snapshots/${TARGET}/${PRODUCT_NAME}_${GIT_REPO_BRANCH_OR_TAG}"}
404
fi
405

    
406
# staging area used on snapshots build
407
STAGINGAREA=${STAGINGAREA:-"${SCRATCHDIR}/staging"}
408
mkdir -p ${STAGINGAREA}
409

    
410
export SNAPSHOTSLOGFILE=${SNAPSHOTSLOGFILE:-"${SCRATCHDIR}/snapshots-build.log"}
411
export SNAPSHOTSLASTUPDATE=${SNAPSHOTSLASTUPDATE:-"${SCRATCHDIR}/snapshots-lastupdate.log"}
412

    
413
if [ -n "${POUDRIERE_SNAPSHOTS}" ]; then
414
	export SNAPSHOTS_RSYNCIP=${PKG_RSYNC_HOSTNAME}
415
	export SNAPSHOTS_RSYNCUSER=${PKG_RSYNC_USERNAME}
416
else
417
	export SNAPSHOTS_RSYNCIP=${RSYNCIP}
418
	export SNAPSHOTS_RSYNCUSER=${RSYNCUSER}
419
fi
420

    
421
if [ "${PRODUCT_NAME}" = "pfSense" ]; then
422
	export VENDOR_NAME=${VENDOR_NAME:-"Rubicon Communications, LLC (Netgate)"}
423
	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."}
424
else
425
	export VENDOR_NAME=${VENDOR_NAME:-"nonSense"}
426
	export OVF_INFO=${OVF_INFO:-"none"}
427
fi
(3-3/3)