Skip to content

Commit

Permalink
Merge pull request #1 from shawndwells/master
Browse files Browse the repository at this point in the history
Initial Commit
  • Loading branch information
shawndwells authored Jul 31, 2020
2 parents 16c5995 + f4562ae commit 2d69ed3
Show file tree
Hide file tree
Showing 4 changed files with 191 additions and 2 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
# Don't accidentally commit the sensor RPM into the repo ;)
*.rpm
60 changes: 60 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
#
# RHEL Universal Base Image (RHEL UBI) is a stripped down, OCI-compliant,
# base operating system image purpose built for containers. For more information
# see https://developers.redhat.com/products/rhel/ubi
#
FROM registry.access.redhat.com/ubi8/ubi
USER root

#
# Friendly reminder that generated container images are from an open source
# project, and not a formal CrowdStrike product.
#
LABEL maintainer="https://github.com/CrowdStrike/openshift-falcon-daemonset"

#
# Apply updates to base image.
#
RUN yum -y update --disablerepo=* --enablerepo=ubi-8-appstream --enablerepo=ubi-8-baseos && yum -y clean all && rm -rf /var/cache/yum

#
# Copy Falcon Agent RPM into container & install it, then remove the RPM
#
# TO DO: For now this script copies the full RPM and renames to /tmp/falcon-agent.rpm. This should be
# changed to a parameter at some point.
#
COPY ./falcon-sensor-5.33.0-9808.el8.x86_64.rpm /tmp/falcon-agent.rpm
RUN yum -y install --disablerepo=* --enablerepo=ubi-8-appstream --enablerepo=ubi-8-baseos /tmp/falcon-agent.rpm && yum -y clean all && rm -rf /var/cache/yum && rm /tmp/falcon-agent.rpm

#
# Copy the entrypoint script into the container and make sure
# that its executable. Add the symlink for backwards compatability
#
COPY entrypoint.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/entrypoint.sh
RUN ln -s /usr/local/bin/entrypoint.sh /


ARG container_version
ARG BUILD_DATE # BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')
ARG VCS_REF # VCS_REF=$(git rev-parse --short HEAD)

LABEL org.label-schema.build-date=$BUILD_DATE
LABEL org.label-schema.schema-version "1.0"
LABEL org.label-schema.description "CrowdStrike Falcon Linux Sensor"
LABEL org.label-schema.vendor "https://github.com/CrowdStrike/openshift-falcon-daemonset"
LABEL org.label-schema.url="https://github.com/CrowdStrike/openshift-falcon-daemonset"
LABEL org.label-schema.vcs-url="https://github.com/CrowdStrike/openshift-falcon-daemonset"
LABEL org.label-schema.vcs-ref=$VCS_REF
LABEL org.label-schema.docker.cmd \
"docker run -d --privileged -v /var/log:/var/log \
--mount type=bind,source=/var/run/docker.sock,destination=/var/run/docker.sock \
--net=host --pid=host --uts=host --ipc=host \
falcon-sensor"
LABEL org.label-schema.container_version $container_version

ENV PATH ".:/bin:/usr/bin:/sbin:/usr/sbin"
WORKDIR /opt/CrowdStrike

VOLUME /var/log
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
80 changes: 78 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,78 @@
# dockerfiles
Automation to help create container images pre-loaded with the CrowdStrike Falcon sensor.
# Package CrowdStrike Falcon Linux sensor as a container

## Pre-reqs

* Build user mode, kernel modules and KMA bits for the respective build type.
They'll be picked up by container packaging.
* Install `docker` and `ldd` if not already present on the build host.

## Build

* Build the container using the included ``Dockerfile``:
* ``$ docker build --no-cache=true --build-arg \
BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ') \
VCS_REF=$(git rev-parse --short HEAD) \
-t falcon-sensor:latest .``

## Run

`falcon-sensor` is the default command of the container. It can be invoked
as follows:

```
docker run --rm -ti --privileged --net=host -v /var/log:/var/log falcon-sensor
```

This is like running falcon-sensor directly on the console. Standard terminal
output appears. Pressing Control-C would cause `docker` client to pass
`SIGINT` along to the sensor, which would then exit.

`--net=host` is required for the containerized sensor to talk to the kernel
module over netlink and to Cloudsim over localhost. Host `pid`, `uts` and
`ipc` namespaces are passed through to sensor container for easy access to
host resources. Following additional host files and directories need to be
provided to the sensor by mounting them within the container:

```
/var/run/docker.sock # for the sensor to query Docker engine
/var/log # for logs
/etc/os-release # or its equivalent based on the distro
```

Sensor container picks up `falconctl` configuration from its environment.
Following variables are supported. They map to the similarly named
`SET_OPTIONS` of `falconctl`. Typically, the environment variables
are set through a Kubernetes `configmap`. They can also be set with
`-e` option to `docker run` on the command line.

```
FALCONCTL_OPT_CID
FALCONCTL_OPT_AID
FALCONCTL_OPT_APD
FALCONCTL_OPT_APH
FALCONCTL_OPT_APP
FALCONCTL_OPT_TRACE
FALCONCTL_OPT_FEATURE
FALCONCTL_OPT_MESSAGE_LOG
FALCONCTL_OPT_BILLING
FALCONCTL_OPT_ASSERT
FALCONCTL_OPT_MEMFAIL_GRACE_PERIOD
FALCONCTL_OPT_MEMFAIL_EVERY_N
```

The sensor can be run as a background service as follows:

```
CONTAINER_ID=$(docker run -d -e FALCONCTL_OPT_CID=<<your CID>> -e FALCONCTL_OPT_TRACE=debug --privileged --net=host -v /var/log:/var/log falcon-sensor:0.1)
```

### Running `falconctl`

`falconctl` can be invoked inside a running sensor container with `docker exec`:

```
docker exec -it $CONTAINER_ID falconctl -g --trace
```

## Post-reqs
Push the image to a registry (like ECR) if the container needs to be accessed outside of the build host.
51 changes: 51 additions & 0 deletions entrypoint.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
#!/bin/sh
set -e

CSROOT=/opt/CrowdStrike
FALCONCTL=$CSROOT/falconctl
FALCON_SENSOR=$CSROOT/falcon-sensor
CLOUDSIM_CID="YOURCID"

#
# Initialize ``opts`` as one-dimensional array
#
declare -A opts

#
# Pull options from the environment (passed to us through a Kubernetes
# config map). If $CLOUDSIM_CID is defined assume a local build.
#
# Reference output of ``falconctl --help`` for option descriptions.
#
opts['--cid']="${FALCONCTL_OPT_CID:-$CLOUDSIM_CID}"
opts['--aid']="$FALCONCTL_OPT_AID"
opts['--apd']="$FALCONCTL_OPT_APD"
opts['--aph']="$FALCONCTL_OPT_APH"
opts['--app']="$FALCONCTL_OPT_APP"
opts['--trace']="$FALCONCTL_OPT_TRACE"
opts['--feature']="$FALCONCTL_OPT_FEATURE"
opts['--message-log']="$FALCONCTL_OPT_MESSAGE_LOG"
opts['--billing']="$FALCONCTL_OPT_BILLING"
opts['--assert']="$FALCONCTL_OPT_ASSERT"
opts['--memfail-grace-period']="$FALCONCTL_OPT_MEMFAIL_GRACE_PERIOD"
opts['--memfail-every-n']="$FALCONCTL_OPT_MEMFAIL_EVERY_N"

#
# Iterate through the ``opts`` array and pull out defined options. Build a unified
# ``falconctl -s -f [OPTS]`` style command.
#
cmd="$FALCONCTL -s -f"
for opt in "${!opts[@]}"
do
[ -z ${opts[$opt]} ] || cmd+=" $opt=${opts[$opt]}"
done

#
# Set the sensor config by running $cmd, and then
# exec the sensor ($FALCON_SENSOR)
#
# Note this is why the ``set -e`` line earlier is so important. If $cmd fails
# we do not want the sensor daemon to initiate, as that would mean the sensor
# was not properly initiated.
echo $cmd
$cmd && exec $FALCON_SENSOR

0 comments on commit 2d69ed3

Please sign in to comment.