blob: 70866bf268afeba675661139f8207ed64f35e695 [file] [log] [blame]
Scott Baker82b2b082018-04-16 16:02:14 -07001
2# Copyright 2017-present Open Networking Foundation
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
16"""
17 kubernetes-synchronizer.py
18
19 This is the main entrypoint for the synchronizer. It loads the config file, and then starts the synchronizer.
20"""
21
Scott Baker82b2b082018-04-16 16:02:14 -070022#!/usr/bin/env python
23
24# Runs the standard XOS synchronizer
25
26import importlib
Scott Baker3fd18e52018-04-17 09:18:21 -070027import logging
Scott Baker82b2b082018-04-16 16:02:14 -070028import os
29import sys
Scott Bakera30fae72019-02-01 16:14:43 -080030from xossynchronizer import Synchronizer
Scott Baker82b2b082018-04-16 16:02:14 -070031from xosconfig import Config
32
Scott Baker987748d2018-08-09 16:14:11 -070033base_config_file = os.path.abspath(os.path.dirname(os.path.realpath(__file__)) + '/config.yaml')
34mounted_config_file = os.path.abspath(os.path.dirname(os.path.realpath(__file__)) + '/mounted_config.yaml')
35
36if os.path.isfile(mounted_config_file):
37 Config.init(base_config_file, 'synchronizer-config-schema.yaml', mounted_config_file)
38else:
39 Config.init(base_config_file, 'synchronizer-config-schema.yaml')
Scott Baker82b2b082018-04-16 16:02:14 -070040
Zack Williams3dc97602018-09-13 22:33:26 -070041from xoskafka import XOSKafkaProducer
42
Scott Baker3fd18e52018-04-17 09:18:21 -070043# prevent logging noise from k8s API calls
44logging.getLogger("kubernetes.client.rest").setLevel(logging.WARNING)
45
Zack Williams3dc97602018-09-13 22:33:26 -070046# init kafka producer connection
47XOSKafkaProducer.init()
48
Scott Bakera30fae72019-02-01 16:14:43 -080049Synchronizer().run()