blob: a8e826b48de588cdae50ce5dac539068ed5b6a46 [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
15from __future__ import print_function
16import os
17import inspect
18import imp
19import sys
20import threading
21import time
22from syncstep import SyncStep
23from synchronizers.new_base.event_loop import XOSObserver
24
25from xosconfig import Config
26from multistructlog import create_logger
27
28log = create_logger(Config().get("logging"))
29
30
31class Backend:
32 def run(self):
33 # start model policies thread
34 policies_dir = Config("model_policies_dir")
35 if policies_dir:
36 from synchronizers.model_policy import run_policy
37
38 model_policy_thread = threading.Thread(target=run_policy)
39 model_policy_thread.start()
40 else:
41 model_policy_thread = None
42 log.info("Skipping model policies thread due to no model_policies dir.")
43
44 while True:
45 try:
46 time.sleep(1000)
47 except KeyboardInterrupt:
48 print("exiting due to keyboard interrupt")
49 if model_policy_thread:
50 model_policy_thread._Thread__stop()
51 sys.exit(1)