2015-01-08 23:53:51 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2016-02-11 19:48:58 +00:00
|
|
|
# Copyright (c) 2014-present, Facebook, Inc.
|
2015-01-08 23:53:51 +00:00
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# This source code is licensed under the BSD-style license found in the
|
2015-01-30 03:37:24 +00:00
|
|
|
# LICENSE file in the root directory of this source tree. An additional grant
|
2015-01-08 23:53:51 +00:00
|
|
|
# of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
|
|
SOURCE_DIR="$SCRIPT_DIR/../.."
|
|
|
|
BUILD_DIR="$SOURCE_DIR/build/linux"
|
|
|
|
|
2016-04-22 18:15:26 +00:00
|
|
|
export PATH="$PATH:/usr/local/bin"
|
|
|
|
source "$SOURCE_DIR/tools/lib.sh"
|
2015-01-08 23:53:51 +00:00
|
|
|
|
2015-04-19 02:51:00 +00:00
|
|
|
PACKAGE_VERSION=`git describe --tags HEAD || echo 'unknown-version'`
|
2015-03-28 02:19:55 +00:00
|
|
|
PACKAGE_ARCH=`uname -m`
|
|
|
|
PACKAGE_ITERATION=""
|
|
|
|
PACKAGE_TYPE=""
|
2015-01-08 23:53:51 +00:00
|
|
|
DESCRIPTION="osquery is an operating system instrumentation toolchain."
|
2015-06-29 18:18:49 +00:00
|
|
|
PACKAGE_NAME="osquery"
|
2015-01-30 03:37:24 +00:00
|
|
|
if [[ $PACKAGE_VERSION == *"-"* ]]; then
|
2015-04-08 21:13:01 +00:00
|
|
|
DESCRIPTION="$DESCRIPTION (unstable/latest version)"
|
2015-01-30 03:37:24 +00:00
|
|
|
fi
|
2016-07-21 00:02:40 +00:00
|
|
|
|
|
|
|
OUTPUT_PKG_PATH="$BUILD_DIR/${PACKAGE_NAME}-${PACKAGE_VERSION}."
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
# Config files
|
|
|
|
INITD_SRC="$SCRIPT_DIR/osqueryd.initd"
|
|
|
|
INITD_DST="/etc/init.d/osqueryd"
|
2016-01-13 17:27:54 +00:00
|
|
|
SYSTEMD_SERVICE_SRC="$SCRIPT_DIR/osqueryd.service"
|
|
|
|
SYSTEMD_SERVICE_DST="/usr/lib/systemd/system/osqueryd.service"
|
|
|
|
SYSTEMD_SYSCONFIG_SRC="$SCRIPT_DIR/osqueryd.sysconfig"
|
|
|
|
SYSTEMD_SYSCONFIG_DST="/etc/sysconfig/osqueryd"
|
2016-06-15 20:21:33 +00:00
|
|
|
SYSTEMD_SYSCONFIG_DST_DEBIAN="/etc/default/osqueryd"
|
2015-01-22 18:57:22 +00:00
|
|
|
CTL_SRC="$SCRIPT_DIR/osqueryctl"
|
2015-07-17 23:03:15 +00:00
|
|
|
PACKS_SRC="$SOURCE_DIR/packs"
|
|
|
|
PACKS_DST="/usr/share/osquery/packs/"
|
2016-06-07 22:09:08 +00:00
|
|
|
OSQUERY_POSTINSTALL=${OSQUERY_POSTINSTALL:-""}
|
|
|
|
OSQUERY_CONFIG_SRC=${OSQUERY_CONFIG_SRC:-""}
|
2015-01-08 23:53:51 +00:00
|
|
|
OSQUERY_EXAMPLE_CONFIG_SRC="$SCRIPT_DIR/osquery.example.conf"
|
2015-01-21 23:41:24 +00:00
|
|
|
OSQUERY_EXAMPLE_CONFIG_DST="/usr/share/osquery/osquery.example.conf"
|
2015-01-08 23:53:51 +00:00
|
|
|
OSQUERY_LOG_DIR="/var/log/osquery/"
|
2015-01-22 18:57:22 +00:00
|
|
|
OSQUERY_VAR_DIR="/var/osquery"
|
|
|
|
OSQUERY_ETC_DIR="/etc/osquery"
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
WORKING_DIR=/tmp/osquery_packaging
|
|
|
|
INSTALL_PREFIX=$WORKING_DIR/prefix
|
2016-03-15 02:51:03 +00:00
|
|
|
DEBUG_PREFIX=$WORKING_DIR/debug
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
function usage() {
|
2015-03-28 02:19:55 +00:00
|
|
|
fatal "Usage: $0 -t deb|rpm -i REVISION -d DEPENDENCY_LIST
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
This will generate an Linux package with:
|
|
|
|
(1) An example config /var/osquery/osquery.example.config
|
|
|
|
(2) An init.d script /etc/init.d/osqueryd
|
2015-04-08 21:13:01 +00:00
|
|
|
(3) The osquery toolset /usr/bin/osquery*"
|
2015-01-08 23:53:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function parse_args() {
|
|
|
|
while [ "$1" != "" ]; do
|
|
|
|
case $1 in
|
|
|
|
-t | --type ) shift
|
|
|
|
PACKAGE_TYPE=$1
|
|
|
|
;;
|
2016-06-07 22:09:08 +00:00
|
|
|
-c | --config ) shift
|
|
|
|
OSQUERY_CONFIG_SRC=$1
|
|
|
|
;;
|
|
|
|
-p | --postinst ) shift
|
|
|
|
OSQUERY_POSTINSTALL=$1
|
|
|
|
;;
|
2015-03-28 02:19:55 +00:00
|
|
|
-i | --iteration ) shift
|
|
|
|
PACKAGE_ITERATION=$1
|
|
|
|
;;
|
2015-01-08 23:53:51 +00:00
|
|
|
-d | --dependencies ) shift
|
|
|
|
PACKAGE_DEPENDENCIES="${@}"
|
|
|
|
;;
|
|
|
|
-h | --help ) usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
function check_parsed_args() {
|
2015-03-28 02:19:55 +00:00
|
|
|
if [[ $PACKAGE_TYPE = "" ]] || [[ $PACKAGE_ITERATION = "" ]]; then
|
2015-01-08 23:53:51 +00:00
|
|
|
usage
|
|
|
|
fi
|
|
|
|
|
|
|
|
OUTPUT_PKG_PATH=$OUTPUT_PKG_PATH$PACKAGE_TYPE
|
|
|
|
}
|
|
|
|
|
|
|
|
function main() {
|
|
|
|
parse_args $@
|
|
|
|
check_parsed_args
|
|
|
|
|
|
|
|
platform OS
|
2016-01-13 17:27:54 +00:00
|
|
|
distro $OS DISTRO
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
rm -rf $WORKING_DIR
|
|
|
|
rm -f $OUTPUT_PKG_PATH
|
|
|
|
mkdir -p $INSTALL_PREFIX
|
|
|
|
|
|
|
|
log "copying osquery binaries"
|
|
|
|
BINARY_INSTALL_DIR="$INSTALL_PREFIX/usr/bin/"
|
|
|
|
mkdir -p $BINARY_INSTALL_DIR
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryi" $BINARY_INSTALL_DIR
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryd" $BINARY_INSTALL_DIR
|
|
|
|
strip $BINARY_INSTALL_DIR/*
|
2015-01-22 18:57:22 +00:00
|
|
|
cp "$CTL_SRC" $BINARY_INSTALL_DIR
|
2015-01-08 23:53:51 +00:00
|
|
|
|
|
|
|
# Create the prefix log dir and copy source configs
|
|
|
|
log "copying osquery configurations"
|
2015-01-22 18:57:22 +00:00
|
|
|
mkdir -p $INSTALL_PREFIX/$OSQUERY_VAR_DIR
|
2015-01-08 23:53:51 +00:00
|
|
|
mkdir -p $INSTALL_PREFIX/$OSQUERY_LOG_DIR
|
2015-01-22 18:57:22 +00:00
|
|
|
mkdir -p $INSTALL_PREFIX/$OSQUERY_ETC_DIR
|
2015-07-17 23:03:15 +00:00
|
|
|
mkdir -p $INSTALL_PREFIX/$PACKS_DST
|
2015-01-08 23:53:51 +00:00
|
|
|
mkdir -p `dirname $INSTALL_PREFIX$OSQUERY_EXAMPLE_CONFIG_DST`
|
|
|
|
cp $OSQUERY_EXAMPLE_CONFIG_SRC $INSTALL_PREFIX$OSQUERY_EXAMPLE_CONFIG_DST
|
2015-07-17 23:03:15 +00:00
|
|
|
cp $PACKS_SRC/* $INSTALL_PREFIX/$PACKS_DST
|
2015-01-08 23:53:51 +00:00
|
|
|
|
2016-06-10 23:37:56 +00:00
|
|
|
if [[ $OSQUERY_CONFIG_SRC != "" ]] && [[ -f $OSQUERY_CONFIG_SRC ]]; then
|
2016-06-07 22:09:08 +00:00
|
|
|
log "config setup"
|
|
|
|
cp $OSQUERY_CONFIG_SRC $INSTALL_PREFIX/$OSQUERY_ETC_DIR/osquery.conf
|
|
|
|
fi
|
|
|
|
|
2016-06-15 20:21:33 +00:00
|
|
|
if [[ $DISTRO = "xenial" ]]; then
|
|
|
|
#Change config path to Ubuntu/Xenial default
|
|
|
|
SYSTEMD_SYSCONFIG_DST=$SYSTEMD_SYSCONFIG_DST_DEBIAN
|
|
|
|
fi
|
|
|
|
|
2016-06-03 16:09:09 +00:00
|
|
|
if [[ $DISTRO = "centos7" || $DISTRO = "rhel7" || $DISTRO = "xenial" ]]; then
|
2016-01-13 17:27:54 +00:00
|
|
|
# Install the systemd service and sysconfig
|
|
|
|
mkdir -p `dirname $INSTALL_PREFIX$SYSTEMD_SERVICE_DST`
|
|
|
|
mkdir -p `dirname $INSTALL_PREFIX$SYSTEMD_SYSCONFIG_DST`
|
|
|
|
cp $SYSTEMD_SERVICE_SRC $INSTALL_PREFIX$SYSTEMD_SERVICE_DST
|
|
|
|
cp $SYSTEMD_SYSCONFIG_SRC $INSTALL_PREFIX$SYSTEMD_SYSCONFIG_DST
|
|
|
|
else
|
|
|
|
mkdir -p `dirname $INSTALL_PREFIX$INITD_DST`
|
|
|
|
cp $INITD_SRC $INSTALL_PREFIX$INITD_DST
|
|
|
|
fi
|
2015-01-08 23:53:51 +00:00
|
|
|
|
2016-06-15 20:21:33 +00:00
|
|
|
if [[ $DISTRO = "xenial" ]]; then
|
|
|
|
#Change config path in service unit
|
|
|
|
sed -i 's/sysconfig/default/g' $INSTALL_PREFIX$SYSTEMD_SERVICE_DST
|
|
|
|
fi
|
|
|
|
|
2015-01-08 23:53:51 +00:00
|
|
|
log "creating package"
|
|
|
|
IFS=',' read -a deps <<< "$PACKAGE_DEPENDENCIES"
|
|
|
|
PACKAGE_DEPENDENCIES=
|
|
|
|
for element in "${deps[@]}"
|
|
|
|
do
|
|
|
|
element=`echo $element | sed 's/ *$//'`
|
|
|
|
PACKAGE_DEPENDENCIES="$PACKAGE_DEPENDENCIES -d \"$element\""
|
|
|
|
done
|
|
|
|
|
2015-08-15 22:11:29 +00:00
|
|
|
platform OS
|
|
|
|
distro $OS DISTRO
|
|
|
|
FPM="fpm"
|
|
|
|
if [[ $DISTRO == "lucid" ]]; then
|
|
|
|
FPM="/var/lib/gems/1.8/bin/fpm"
|
|
|
|
fi
|
|
|
|
|
2016-07-21 00:02:40 +00:00
|
|
|
# some tune to stay compliant with Debian package naming convention
|
|
|
|
if [[ $PACKAGE_TYPE == "deb" ]]; then
|
|
|
|
DEB_PACKAGE_ARCH=`dpkg --print-architecture`
|
|
|
|
OUTPUT_PKG_PATH="$BUILD_DIR/${PACKAGE_NAME}_${PACKAGE_VERSION}_${DEB_PACKAGE_ARCH}.deb"
|
|
|
|
fi
|
|
|
|
|
2016-06-07 22:09:08 +00:00
|
|
|
POSTINST_CMD=""
|
2016-06-10 23:37:56 +00:00
|
|
|
if [[ $OSQUERY_POSTINSTALL != "" ]] && [[ -f $OSQUERY_POSTINSTALL ]]; then
|
2016-06-07 22:09:08 +00:00
|
|
|
POSTINST_CMD="--after-install $OSQUERY_POSTINSTALL"
|
|
|
|
fi
|
|
|
|
|
2016-03-15 02:51:03 +00:00
|
|
|
EPILOG="--url https://osquery.io \
|
|
|
|
-m osquery@osquery.io \
|
|
|
|
--vendor Facebook \
|
|
|
|
--license BSD \
|
|
|
|
--description \"$DESCRIPTION\""
|
|
|
|
|
2015-08-15 22:11:29 +00:00
|
|
|
CMD="$FPM -s dir -t $PACKAGE_TYPE \
|
2015-01-30 03:37:24 +00:00
|
|
|
-n $PACKAGE_NAME -v $PACKAGE_VERSION \
|
2015-03-28 02:19:55 +00:00
|
|
|
--iteration $PACKAGE_ITERATION \
|
|
|
|
-a $PACKAGE_ARCH \
|
2016-06-07 22:09:08 +00:00
|
|
|
$POSTINST_CMD \
|
2015-01-08 23:53:51 +00:00
|
|
|
$PACKAGE_DEPENDENCIES \
|
|
|
|
-p $OUTPUT_PKG_PATH \
|
2016-03-15 02:51:03 +00:00
|
|
|
$EPILOG \"$INSTALL_PREFIX/=/\""
|
2015-01-08 23:53:51 +00:00
|
|
|
eval "$CMD"
|
|
|
|
log "package created at $OUTPUT_PKG_PATH"
|
2016-03-15 02:51:03 +00:00
|
|
|
|
|
|
|
# Generate debug packages for Linux or CentOS
|
|
|
|
BUILD_DEBUG_PKG=false
|
|
|
|
if [[ $OS = "ubuntu" || $OS = "debian" ]]; then
|
|
|
|
BUILD_DEBUG_PKG=true
|
|
|
|
PACKAGE_DEBUG_NAME="$PACKAGE_NAME-dbg"
|
2016-03-15 16:30:40 +00:00
|
|
|
PACKAGE_DEBUG_DEPENDENCIES="osquery (= $PACKAGE_VERSION-$PACKAGE_ITERATION)"
|
2016-03-15 02:51:03 +00:00
|
|
|
|
|
|
|
# Debian only needs the non-stripped binaries.
|
2016-03-15 16:30:40 +00:00
|
|
|
BINARY_DEBUG_DIR=$DEBUG_PREFIX/usr/lib/debug/usr/bin
|
2016-03-15 02:51:03 +00:00
|
|
|
mkdir -p $BINARY_DEBUG_DIR
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryi" $BINARY_DEBUG_DIR
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryd" $BINARY_DEBUG_DIR
|
|
|
|
elif [[ $OS = "rhel" || $OS = "centos" || $OS = "fedora" ]]; then
|
|
|
|
BUILD_DEBUG_PKG=true
|
|
|
|
PACKAGE_DEBUG_NAME="$PACKAGE_NAME-debuginfo"
|
|
|
|
PACKAGE_DEBUG_DEPENDENCIES="osquery = $PACKAGE_VERSION"
|
|
|
|
|
|
|
|
# Create Build-ID links for executables and Dwarfs.
|
2016-03-18 02:11:18 +00:00
|
|
|
BUILD_ID_SHELL=`eu-readelf -n "$BUILD_DIR/osquery/osqueryi" | grep "Build ID" | awk '{print $3}'`
|
|
|
|
BUILD_ID_DAEMON=`eu-readelf -n "$BUILD_DIR/osquery/osqueryd" | grep "Build ID" | awk '{print $3}'`
|
2016-03-15 02:51:03 +00:00
|
|
|
BUILDLINK_DEBUG_DIR=$DEBUG_PREFIX/usr/lib/debug/.build-id/64
|
2016-03-18 02:11:18 +00:00
|
|
|
if [[ ! "$BUILD_ID_SHELL" = "" ]]; then
|
|
|
|
mkdir -p $BUILDLINK_DEBUG_DIR
|
|
|
|
ln -s ../../../../bin/osqueryi $BUILDLINK_DEBUG_DIR/$BUILD_ID_SHELL
|
|
|
|
ln -s ../../bin/osqueryi.debug $BUILDLINK_DEBUG_DIR/$BUILD_ID_SHELL.debug
|
|
|
|
ln -s ../../../../bin/osqueryd $BUILDLINK_DEBUG_DIR/$BUILD_ID_DAEMON
|
|
|
|
ln -s ../../bin/osqueryd.debug $BUILDLINK_DEBUG_DIR/$BUILD_ID_DAEMON.debug
|
|
|
|
fi
|
2016-03-15 02:51:03 +00:00
|
|
|
|
|
|
|
# Install the non-stripped binaries.
|
|
|
|
BINARY_DEBUG_DIR=$DEBUG_PREFIX/usr/lib/debug/usr/bin/
|
|
|
|
mkdir -p $BINARY_DEBUG_DIR
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryi" "$BINARY_DEBUG_DIR/osqueryi.debug"
|
|
|
|
cp "$BUILD_DIR/osquery/osqueryd" "$BINARY_DEBUG_DIR/osqueryd.debug"
|
|
|
|
|
|
|
|
# Finally install the source.
|
|
|
|
SOURCE_DEBUG_DIR=$DEBUG_PREFIX/usr/src/debug/osquery-$PACKAGE_VERSION
|
2016-03-18 02:11:18 +00:00
|
|
|
BUILD_DIR=`readlink --canonicalize "$BUILD_DIR"`
|
|
|
|
SOURCE_DIR=`readlink --canonicalize "$SOURCE_DIR"`
|
2016-03-15 02:51:03 +00:00
|
|
|
for file in `"$SCRIPT_DIR/getfiles.py" --build "$BUILD_DIR/" --base "$SOURCE_DIR/"`
|
|
|
|
do
|
|
|
|
mkdir -p `dirname "$SOURCE_DEBUG_DIR/$file"`
|
|
|
|
cp "$SOURCE_DIR/$file" "$SOURCE_DEBUG_DIR/$file"
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
PACKAGE_DEBUG_DEPENDENCIES=`echo "$PACKAGE_DEBUG_DEPENDENCIES"|tr '-' '_'`
|
|
|
|
OUTPUT_DEBUG_PKG_PATH="$BUILD_DIR/$PACKAGE_DEBUG_NAME-$PACKAGE_VERSION.$PACKAGE_TYPE"
|
|
|
|
if [[ $BUILD_DEBUG_PKG ]]; then
|
2016-03-15 16:30:40 +00:00
|
|
|
rm -f $OUTPUT_DEBUG_PKG_PATH
|
2016-03-15 02:51:03 +00:00
|
|
|
CMD="$FPM -s dir -t $PACKAGE_TYPE \
|
|
|
|
-n $PACKAGE_DEBUG_NAME -v $PACKAGE_VERSION \
|
|
|
|
--iteration $PACKAGE_ITERATION \
|
|
|
|
-a $PACKAGE_ARCH \
|
|
|
|
-d \"$PACKAGE_DEBUG_DEPENDENCIES\" \
|
|
|
|
-p $OUTPUT_DEBUG_PKG_PATH \
|
|
|
|
$EPILOG \"$DEBUG_PREFIX/=/\""
|
|
|
|
eval "$CMD"
|
|
|
|
log "debug created at $OUTPUT_DEBUG_PKG_PATH"
|
|
|
|
fi
|
2015-01-08 23:53:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
main $@
|