blob: 82eb7b865ac485c099f1b7c72bcd97c28cda0735 [file] [log] [blame]
Scott Bakerbba67b62019-01-28 17:38:21 -08001# Copyright 2017-present Open Networking Foundation
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
Zack Williams5c2ea232019-01-30 15:23:01 -070015from __future__ import absolute_import, print_function
16
Scott Bakerbba67b62019-01-28 17:38:21 -080017import sys
18import threading
19import time
Scott Bakerbba67b62019-01-28 17:38:21 -080020
Scott Bakerbba67b62019-01-28 17:38:21 -080021from multistructlog import create_logger
Zack Williams5c2ea232019-01-30 15:23:01 -070022from xosconfig import Config
Scott Bakerbba67b62019-01-28 17:38:21 -080023
24log = create_logger(Config().get("logging"))
25
26
27class Backend:
28 def run(self):
29 # start model policies thread
30 policies_dir = Config("model_policies_dir")
31 if policies_dir:
32 from synchronizers.model_policy import run_policy
33
34 model_policy_thread = threading.Thread(target=run_policy)
35 model_policy_thread.start()
36 else:
37 model_policy_thread = None
38 log.info("Skipping model policies thread due to no model_policies dir.")
39
40 while True:
41 try:
42 time.sleep(1000)
43 except KeyboardInterrupt:
44 print("exiting due to keyboard interrupt")
45 if model_policy_thread:
46 model_policy_thread._Thread__stop()
47 sys.exit(1)