-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathREADME
111 lines (76 loc) · 3.05 KB
/
README
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
103
104
105
106
107
108
109
This is the Unix Guest Agent for Openstack
This guest agent provides functionality such as configuring the networking
for a guest.
Layout:
src/ -- The main agent daemon code, written in C, which embeds the
python interpreter
include/ -- Include files for src/
lib/ -- Supporting code for the main agent daemon, along with a
python module wrapper
plugins/ -- Python plugin modules (for communication and command parsing)
commands/ -- Python modules that implement the real code for commands
tests/ -- Unit tests
scripts/ -- Startup and misc scripts
PLUGIN INFO
----------
There are currently 2 types of plugins, exchanges and parsers. Exchange
plugins are those that handle the low level communication between a
client and the daemon. Parser plugins are those that can decode the
communication protocol.
Currently, there's 1 exchange plugin, xscomm.py, and 1 parser plugin,
jsonparser.py. xscomm.py handles communication via XenStore and the
parser plugin will decode/encode json for the requests/responses.
EXCHANGE PLUGIN
---------------
Needs to define a class that contains the following methods:
get_request():
- Has no arguments
- Returns some sort of request object
put_response(request, response):
- Has request and response arguments
- Returns None (return value is ignored)
PARSER PLUGIN
--------------
Needs to define a class that contains the following methods:
parse_request(request):
- Takes a request object returned from an Exchange plugin's get_request()
- Returns a response object that will be passed to an Exchange
plugin's put_response()
COMMAND MODULES
---------------
commands/__init__.py implements a class called 'CommandBase' that is used to
create commands by subclassing it. This automatic registering of commands
via the subclassing occurs via a metaclass.
To create a new command:
1) create a class that derrives from commands.CommandBase
2) define a method in your class that uses this decorator:
@commands.command_add('<command_name>')
(obviously replace the decorator argument with the right command name)
MISC
----
jsonparser.py requires a class instance to be passed on init which
defines a 'run_command' method.
When importing 'commands', it replaces the 'commands' module with a
wrapper, so you can use the 'commands' attribute directly instead of
having to use commands.CommandBase
Call commands.init() to init all of the command classes
Pass the result to JsonParser
EXAMPLE CONFIG FILE
-------------------
# Needed to register the exchange/parser plugin combiniation with the
# main daemon
import agentlib
# To get jsonparser and xscomm
import plugins
# Loads 'commands' plus all modules that contain command classes
import commands.command_list
# Not required, as the default is False
test_mode = False
# Inits all command classes
c = commands.init()
# Creates instance of JsonParser, passing in available commands
parser = plugins.JsonParser(c)
# Create the XSComm intance
xs = plugins.XSComm()
# Register an exchange/parser combination with the main daemon
agentlib.register(xs, parser)