2018-03-27 15:39:04 -05:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2020-07-09 21:45:21 -05:00
|
|
|
EXIT_TELEMETRY_VARS_FILE_NOT_FOUND=1
|
2023-09-27 19:20:18 -05:00
|
|
|
INCORRECT_TELEMETRY_VALUE=2
|
2020-07-09 21:45:21 -05:00
|
|
|
TELEMETRY_VARS_FILE=/usr/share/sonic/templates/telemetry_vars.j2
|
|
|
|
|
|
|
|
if [ ! -f "$TELEMETRY_VARS_FILE" ]; then
|
|
|
|
echo "Telemetry vars template file not found"
|
|
|
|
exit $EXIT_TELEMETRY_VARS_FILE_NOT_FOUND
|
|
|
|
fi
|
|
|
|
|
2020-03-24 02:04:36 -05:00
|
|
|
# Try to read telemetry and certs config from ConfigDB.
|
2018-03-27 15:39:04 -05:00
|
|
|
# Use default value if no valid config exists
|
2020-07-09 21:45:21 -05:00
|
|
|
TELEMETRY_VARS=$(sonic-cfggen -d -t $TELEMETRY_VARS_FILE)
|
2020-07-08 12:27:05 -05:00
|
|
|
TELEMETRY_VARS=${TELEMETRY_VARS//[\']/\"}
|
|
|
|
X509=$(echo $TELEMETRY_VARS | jq -r '.x509')
|
|
|
|
GNMI=$(echo $TELEMETRY_VARS | jq -r '.gnmi')
|
|
|
|
CERTS=$(echo $TELEMETRY_VARS | jq -r '.certs')
|
2018-03-27 15:39:04 -05:00
|
|
|
|
|
|
|
TELEMETRY_ARGS=" -logtostderr"
|
SONiC Management Framework Release 1.0 (#3488)
* Added sonic-mgmt-framework as submodule / docker
* fix build issues
* update sonic-mgmt-framework submodule branch to master
* Merged changes 70007e6d2ba3a4c0b371cd693ccc63e0a8906e77..00d4fcfed6a759e40d7b92120ea0ee1f08300fc6
00d4fcfed6a759e40d7b92120ea0ee1f08300fc6 Modified environemnt variables
* Changes to build sonic-mgmt-framework docker
* bumped up sonic-mgmt-framework commit-id
* version bump for sonic-mgmt-framework commit-it
* bumped up sonic-mgmt-framework commit-id
* Add python packages to docker
* Build fix for docker with python packages
* added libyang as dependent package
* Allow building images on NFS-mounted clones
Prior to this change, `build_debian.sh` would generate a Debian
filesystem in `./fsroot`. This needs root permissions, and one of the
tests that is performed is whether the user can create a character
special file in the filesystem (using mknod).
On most NFS deployments, `root` is the least privileged user, and cannot
run mknod. Also, attempting to run commands like rm or mv as root would
fail due to permission errors, since the root user gets mapped to an
unprivileged user like `nobody`.
This commit changes the location of the Debian filesystem to `/fsroot`,
which is a tmpfs mount within the slave Docker. The default squashfs,
docker tarball and zip files are also created within /tmp, before being
copied back to /sonic as the regular user.
The side effect of this change is that the contents of `/fsroot` are no
longer available once the slave container exits, however they are
available within the squashfs image.
Signed-off-by: Nirenjan Krishnan <Nirenjan.Krishnan@dell.com>
* bumped up sonc-mgmt-framework commit to include PR #18
* REST Server startup script is enahnced to read the settings from
ConfigDB. Below table provides mapping of db field to command line
argument name.
============================================================
ConfigDB entry key Field name REST Server argument
============================================================
REST_SERVER|default port -port
REST_SERVER|default client_auth -client_auth
REST_SERVER|default log_level -v
DEVICE_METADATA|x509 server_crt -cert
DEVICE_METADATA|x509 server_key -key
DEVICE_METADATA|x509 ca_crt -cacert
============================================================
* Replace src/telemetry as submodule to sonic-telemetry
* Update telemetry commit HEAD
* Update sonic-telemetry commit HEAD
* libyang env path update
* Add libyang dependency to telemetry
* Add scripts to create JSON files for CLI backend
Scripts to create /var/platform/syseeprom and /var/platform/system, which are back-end
files for CLI, for system EEPROM and system information.
Signed-off-by: Howard Persh <Howard_Persh@dell.com>
* In startup script, create directory where CLI back-end files live
Signed-off-by: Howard Persh <Howard_Persh@dell.com>
* build dependency pkgs added to docker for build failure fix
* Changes to fix build issue for mgmt framework
* Fix exec path issue with telemetry
* s5232[device] PSU detecttion and default led state support
* Processing of first boot in rc.local should not have premature exit
Signed-off-by: Howard Persh <Howard_Persh@dell.com>
* docker mount options added for platform, system features
* bumped up sonic-mgmt-framework commit id to pick 23rd July 2019 changes
* Added mount options for telemetry docker to get access for system and platform info.
* Update commit for sonic-utilities
* [dell]: Corrected dport map and renamed config files for S5232F
* Fix telemetry submodule commit
* added support for sonic-cli console
* [Dell S5232F, Z9264F] Harden FPGA driver kernel module
For Dell S5232F and Z9264F platforms, be more strict when checking state
in ISR of FPGA driver, to harden against spurious interrupts.
Signed-off-by: Howard Persh <Howard_Persh@dell.com>
* update mgmt-framework submodule to 27th Aug commit.
* remove changes not related to mgmt-framework and sonic-telemetry
* Revert "Replace src/telemetry as submodule to sonic-telemetry"
This reverts commit 11c31929759a17122782d4944066a6ac8453b78d.
* Revert "Replace src/telemetry as submodule to sonic-telemetry"
This reverts commit 11c31929759a17122782d4944066a6ac8453b78d.
* make submodule changes and remove a change not related to PR
* more changes
* Update .gitmodules
* Update Dockerfile.j2
* Update .gitmodules
* Update .gitmodules
* Update .gitmodules
reverting experimental change
* Removed syspoll for release_1.0
Signed-off-by: Jeff Yin <29264773+jeff-yin@users.noreply.github.com>
* Update docker-sonic-mgmt-framework.mk
* Update sonic-mgmt-framework.mk
* Update sonic-mgmt-framework.mk
* Update docker-sonic-mgmt-framework.mk
* Update docker-sonic-mgmt-framework.mk
* Revert "Processing of first boot in rc.local should not have premature exit"
This reverts commit e99a91ffc28a0fd13f4ad458719d2511c3665431.
* Remove old telemetry directory
* Update docker-sonic-mgmt-framework.mk
* Resolving merge conflict with Azure
* Reverting the wrong merge
* Use CVL_SCHEMA_PATH instead of changing directory for telemetry startup
* Add missing export
* Add python mmh3 to slave dockerfile
* Remove sonic-mgmt-framework build dep for telemetry, fix dialout startup issues
* Provided flag to disable compiling mgmt-framework
* Update sonic-utilites point latest commit id
* Point sonic-utilities to Azure accepted SHA
* Updating mgmt framework to right sha
* Add sonic-telemetry submodule
* Update the mgmt-framework commit id
Co-authored-by: jghalam <joe.ghalam@gmail.com>
Co-authored-by: Partha Dutta <51353699+dutta-partha@users.noreply.github.com>
Co-authored-by: srideepDell <srideep_devireddy@dell.com>
Co-authored-by: nirenjan <nirenjan@users.noreply.github.com>
Co-authored-by: Sachin Holla <51310506+sachinholla@users.noreply.github.com>
Co-authored-by: Eric Seifert <seiferteric@gmail.com>
Co-authored-by: Howard Persh <hpersh@yahoo.com>
Co-authored-by: Jeff Yin <29264773+jeff-yin@users.noreply.github.com>
Co-authored-by: Arunsundar Kannan <31632515+arunsundark@users.noreply.github.com>
Co-authored-by: rvasanthm <51932293+rvasanthm@users.noreply.github.com>
Co-authored-by: Ashok Daparthi-Dell <Ashok_Daparthi@Dell.com>
Co-authored-by: anand-kumar-subramanian <51383315+anand-kumar-subramanian@users.noreply.github.com>
2019-12-23 23:47:16 -06:00
|
|
|
export CVL_SCHEMA_PATH=/usr/sbin/schema
|
2018-03-27 15:39:04 -05:00
|
|
|
|
2020-07-08 12:27:05 -05:00
|
|
|
if [ -n "$CERTS" ]; then
|
|
|
|
SERVER_CRT=$(echo $CERTS | jq -r '.server_crt')
|
|
|
|
SERVER_KEY=$(echo $CERTS | jq -r '.server_key')
|
2020-03-24 02:04:36 -05:00
|
|
|
if [ -z $SERVER_CRT ] || [ -z $SERVER_KEY ]; then
|
|
|
|
TELEMETRY_ARGS+=" --insecure"
|
|
|
|
else
|
|
|
|
TELEMETRY_ARGS+=" --server_crt $SERVER_CRT --server_key $SERVER_KEY "
|
|
|
|
fi
|
|
|
|
|
2020-07-08 12:27:05 -05:00
|
|
|
CA_CRT=$(echo $CERTS | jq -r '.ca_crt')
|
2020-03-24 02:04:36 -05:00
|
|
|
if [ ! -z $CA_CRT ]; then
|
|
|
|
TELEMETRY_ARGS+=" --ca_crt $CA_CRT"
|
|
|
|
fi
|
|
|
|
elif [ -n "$X509" ]; then
|
2020-07-08 12:27:05 -05:00
|
|
|
SERVER_CRT=$(echo $X509 | jq -r '.server_crt')
|
|
|
|
SERVER_KEY=$(echo $X509 | jq -r '.server_key')
|
2020-03-24 02:04:36 -05:00
|
|
|
if [ -z $SERVER_CRT ] || [ -z $SERVER_KEY ]; then
|
|
|
|
TELEMETRY_ARGS+=" --insecure"
|
|
|
|
else
|
2018-03-27 15:39:04 -05:00
|
|
|
TELEMETRY_ARGS+=" --server_crt $SERVER_CRT --server_key $SERVER_KEY "
|
|
|
|
fi
|
|
|
|
|
2020-07-08 12:27:05 -05:00
|
|
|
CA_CRT=$(echo $X509 | jq -r '.ca_crt')
|
2020-03-24 02:04:36 -05:00
|
|
|
if [ ! -z $CA_CRT ]; then
|
|
|
|
TELEMETRY_ARGS+=" --ca_crt $CA_CRT"
|
|
|
|
fi
|
|
|
|
else
|
2021-02-17 19:23:00 -06:00
|
|
|
TELEMETRY_ARGS+=" --noTLS"
|
2018-03-27 15:39:04 -05:00
|
|
|
fi
|
|
|
|
|
|
|
|
# If no configuration entry exists for TELEMETRY, create one default port
|
2020-07-08 12:27:05 -05:00
|
|
|
if [ -z "$GNMI" ]; then
|
|
|
|
PORT=8080
|
|
|
|
else
|
|
|
|
PORT=$(echo $GNMI | jq -r '.port')
|
2018-03-27 15:39:04 -05:00
|
|
|
fi
|
|
|
|
TELEMETRY_ARGS+=" --port $PORT"
|
|
|
|
|
2020-07-08 12:27:05 -05:00
|
|
|
CLIENT_AUTH=$(echo $GNMI | jq -r '.client_auth')
|
2018-03-27 15:39:04 -05:00
|
|
|
if [ -z $CLIENT_AUTH ] || [ $CLIENT_AUTH == "false" ]; then
|
2020-03-24 02:04:36 -05:00
|
|
|
TELEMETRY_ARGS+=" --allow_no_client_auth"
|
2018-03-27 15:39:04 -05:00
|
|
|
fi
|
|
|
|
|
2020-07-08 12:27:05 -05:00
|
|
|
LOG_LEVEL=$(echo $GNMI | jq -r '.log_level')
|
2023-03-20 18:22:11 -05:00
|
|
|
if [[ $LOG_LEVEL =~ ^[0-9]+$ ]]; then
|
2020-03-24 02:04:36 -05:00
|
|
|
TELEMETRY_ARGS+=" -v=$LOG_LEVEL"
|
2018-03-27 15:39:04 -05:00
|
|
|
else
|
2020-03-24 02:04:36 -05:00
|
|
|
TELEMETRY_ARGS+=" -v=2"
|
2018-03-27 15:39:04 -05:00
|
|
|
fi
|
|
|
|
|
2023-05-04 18:47:02 -05:00
|
|
|
# Server will handle threshold connections consecutively
|
2023-04-18 16:29:30 -05:00
|
|
|
THRESHOLD_CONNECTIONS=$(echo $GNMI | jq -r '.threshold')
|
|
|
|
if [[ $THRESHOLD_CONNECTIONS =~ ^[0-9]+$ ]]; then
|
|
|
|
TELEMETRY_ARGS+=" --threshold $THRESHOLD_CONNECTIONS"
|
|
|
|
else
|
2023-11-22 09:51:34 -06:00
|
|
|
if [ -z $GNMI ] || [[ $THRESHOLD_CONNECTIONS == "null" ]]; then
|
2023-05-04 18:47:02 -05:00
|
|
|
TELEMETRY_ARGS+=" --threshold 100"
|
|
|
|
else
|
|
|
|
echo "Incorrect threshold value, expecting positive integers" >&2
|
|
|
|
exit $INCORRECT_TELEMETRY_VALUE
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Close idle connections after certain duration (in seconds)
|
|
|
|
IDLE_CONN_DURATION=$(echo $GNMI | jq -r '.idle_conn_duration')
|
|
|
|
if [[ $IDLE_CONN_DURATION =~ ^[0-9]+$ ]]; then
|
|
|
|
TELEMETRY_ARGS+=" --idle_conn_duration $IDLE_CONN_DURATION"
|
|
|
|
else
|
2023-11-22 09:51:34 -06:00
|
|
|
if [ -z $GNMI ] || [[ $IDLE_CONN_DURATION == "null" ]]; then
|
2023-05-04 18:47:02 -05:00
|
|
|
TELEMETRY_ARGS+=" --idle_conn_duration 5"
|
|
|
|
else
|
|
|
|
echo "Incorrect idle_conn_duration value, expecting positive integers" >&2
|
|
|
|
exit $INCORRECT_TELEMETRY_VALUE
|
|
|
|
fi
|
2023-04-18 16:29:30 -05:00
|
|
|
fi
|
2023-11-22 09:51:34 -06:00
|
|
|
|
2023-05-04 18:47:02 -05:00
|
|
|
|
2018-03-27 15:39:04 -05:00
|
|
|
exec /usr/sbin/telemetry ${TELEMETRY_ARGS}
|