mirror of
https://github.com/telekom-security/tpotce.git
synced 2025-07-02 01:27:27 -04:00
include docker repos
... skip emobility since it is a dev repo
This commit is contained in:
52
docker/elk/kibana/Dockerfile
Normal file
52
docker/elk/kibana/Dockerfile
Normal file
@ -0,0 +1,52 @@
|
||||
FROM alpine
|
||||
MAINTAINER MO
|
||||
|
||||
# Include dist
|
||||
ADD dist/ /root/dist/
|
||||
|
||||
# Setup env and apt
|
||||
RUN apk -U upgrade && \
|
||||
apk add bash curl nodejs procps wget && \
|
||||
|
||||
# Get and install packages
|
||||
cd /root/dist/ && \
|
||||
mkdir -p /usr/share/kibana/ && \
|
||||
wget https://artifacts.elastic.co/downloads/kibana/kibana-5.6.1-linux-x86_64.tar.gz && \
|
||||
tar xvfz kibana-5.6.1-linux-x86_64.tar.gz --strip-components=1 -C /usr/share/kibana/ && \
|
||||
|
||||
# Kibana's bundled node does not work in alpine
|
||||
rm /usr/share/kibana/node/bin/node && \
|
||||
rm /usr/share/kibana/node/bin/npm && \
|
||||
ln -s /usr/bin/node /usr/share/kibana/node/bin/node && \
|
||||
ln -s /usr/bin/npm /usr/share/kibana/node/bin/npm && \
|
||||
|
||||
# Add and move files
|
||||
cd /root/dist/ && \
|
||||
cp kibana.svg /usr/share/kibana/src/ui/public/images/kibana.svg && \
|
||||
cp kibana.svg /usr/share/kibana/src/ui/public/icons/kibana.svg && \
|
||||
cp elk.ico /usr/share/kibana/src/ui/public/assets/favicons/favicon.ico && \
|
||||
cp elk.ico /usr/share/kibana/src/ui/public/assets/favicons/favicon-16x16.png && \
|
||||
cp elk.ico /usr/share/kibana/src/ui/public/assets/favicons/favicon-32x32.png && \
|
||||
cp create_kibana_index.js /usr/share/kibana/src/core_plugins/elasticsearch/lib/ && \
|
||||
cd / && \
|
||||
|
||||
# Setup user, groups and configs
|
||||
sed -i 's/#server.basePath: ""/server.basePath: "\/kibana"/' /usr/share/kibana/config/kibana.yml && \
|
||||
sed -i 's/#kibana.defaultAppId: "discover"/kibana.defaultAppId: "dashboards"/' /usr/share/kibana/config/kibana.yml && \
|
||||
sed -i 's/#server.host: "localhost"/server.host: "0.0.0.0"/' /usr/share/kibana/config/kibana.yml && \
|
||||
sed -i 's/#elasticsearch.url: "http:\/\/localhost:9200"/elasticsearch.url: "http:\/\/elasticsearch:9200"/' /usr/share/kibana/config/kibana.yml && \
|
||||
/usr/share/kibana/bin/kibana 2>&1 | grep -m 1 "Optimization of bundles" && \
|
||||
addgroup -g 2000 kibana && \
|
||||
adduser -S -H -s /bin/bash -u 2000 -D -g 2000 kibana && \
|
||||
chown -R kibana:kibana /usr/share/kibana/ && \
|
||||
|
||||
# Clean up
|
||||
apk del wget && \
|
||||
rm -rf /root/*
|
||||
|
||||
# Healthcheck
|
||||
HEALTHCHECK --retries=10 CMD curl -s -XGET 'http://127.0.0.1:5601'
|
||||
|
||||
# Start kibana
|
||||
USER kibana
|
||||
CMD ["/usr/share/kibana/bin/kibana"]
|
176
docker/elk/kibana/dashboard/es_kibana.json
Normal file
176
docker/elk/kibana/dashboard/es_kibana.json
Normal file
File diff suppressed because one or more lines are too long
1
docker/elk/kibana/dashboard/kibana-patterns.json
Normal file
1
docker/elk/kibana/dashboard/kibana-patterns.json
Normal file
File diff suppressed because one or more lines are too long
38
docker/elk/kibana/dist/create_kibana_index.js
vendored
Normal file
38
docker/elk/kibana/dist/create_kibana_index.js
vendored
Normal file
@ -0,0 +1,38 @@
|
||||
'use strict';
|
||||
|
||||
var _setup_error = require('./setup_error');
|
||||
|
||||
var _setup_error2 = _interopRequireDefault(_setup_error);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
module.exports = function (server, mappings) {
|
||||
var _server$plugins$elast = server.plugins.elasticsearch.getCluster('admin');
|
||||
|
||||
const callWithInternalUser = _server$plugins$elast.callWithInternalUser;
|
||||
|
||||
const index = server.config().get('kibana.index');
|
||||
|
||||
function handleError(message) {
|
||||
return function (err) {
|
||||
throw new _setup_error2.default(server, message, err);
|
||||
};
|
||||
}
|
||||
|
||||
return callWithInternalUser('indices.create', {
|
||||
index: index,
|
||||
body: {
|
||||
settings: {
|
||||
number_of_shards: 1,
|
||||
number_of_replicas: 0,
|
||||
'index.mapper.dynamic': false
|
||||
},
|
||||
mappings
|
||||
}
|
||||
}).catch(handleError('Unable to create Kibana index "<%= kibana.index %>"')).then(function () {
|
||||
return callWithInternalUser('cluster.health', {
|
||||
waitForStatus: 'yellow',
|
||||
index: index
|
||||
}).catch(handleError('Waiting for Kibana index "<%= kibana.index %>" to come online failed.'));
|
||||
});
|
||||
};
|
BIN
docker/elk/kibana/dist/elk.ico
vendored
Normal file
BIN
docker/elk/kibana/dist/elk.ico
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 805 B |
64
docker/elk/kibana/dist/kibana.svg
vendored
Normal file
64
docker/elk/kibana/dist/kibana.svg
vendored
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 7.0 KiB |
BIN
docker/elk/kibana/elkbase.tgz
Normal file
BIN
docker/elk/kibana/elkbase.tgz
Normal file
Binary file not shown.
Reference in New Issue
Block a user