forked from CiscoDevNet/pathman-sr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver_sr.py
executable file
·102 lines (81 loc) · 3.14 KB
/
server_sr.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#! /usr/bin/env python2.7
"""
* Copyright (c) 2014 by Cisco Systems, Inc.
* All rights reserved.
Rest command server
-- used for various tasks
-- here for running the Pathman REST API
Maintainer: Niklas Montin ([email protected])
20140710 - v1 basic command support, based on work by [email protected]
20140716 - v2 SSL support and other http extras
20140728 - v3 Adopted to Pathman
20140824 - v4 Commandhandler2
20141120 - v5 Removed need for Launcher - main section added
"""
__author__ = 'niklas'
# Import standard Python library modules.
import json
import copy
import re
import time
# Import third party library modules.
import tornado.ioloop
import tornado.web
import tornado.httpserver
from pathman_sr import *
from pathman_ini import *
Response_Flag = True
response_list_sr = []
# for certs
data_dir = ''
class CommandHandlerSR(tornado.web.RequestHandler):
"""Class to handle received API commands."""
def get(self):
self.write("Hello, world")
def set_default_headers(self):
# logging.info('set default headers')
self.set_header("Access-Control-Allow-Origin", "*")
self.set_header("Access-Control-Allow-Methods", "GET,PUT,POST,DELETE,OPTIONS")
self.set_header("Access-Control-Allow-Headers",
"Content-Type, Depth, User-Agent, X-File-Size, X-Requested-With,"
" X-Requested-By, If-Modified-Since, X-File-Name, Cache-Control")
def options(self):
# logging.info('option request')
self.write({"response": "Success"})
def post(self):
"""Examine POST request and react to subcommands."""
list_subreplies = []
for reply in response_list_sr:
list_subreplies.append(reply)
dict_reply = {'response': list_subreplies}
self.write(dict_reply)
logging.info(json.dumps(dict_reply))
def initialize(self, debug):
"""Save desired debug level."""
self.__debug = debug
logging.info('Init 2 done - debug saved')
def prepare(self):
"""Log the command request."""
global Response_Flag
global response_list_sr
debug = self.__debug
request = self.request
self.set_header("Access-Control-Allow-Origin", "*")
try:
json_body = request.body
dict_body = json.loads(json_body)
list_subcommands = dict_body['request']
response_list_sr = rest_interface_parser(list_subcommands, debug)
except SyntaxError, e:
response_list_sr = [{'success' :False,
'cause': "SyntaxError: %s"% e.message ,
'option': 'unknown'}]
except KeyError, e:
response_list_sr = [{'success' :False,
'cause': "KeyError: %s"% e.message ,
'option': 'unknown'}]
except ValueError, e:
response_list_sr = [{'success' :False,
'cause': "ValueError: %s"% e.message ,
'option': 'unknown'}]
# Bye bye.