forked from splunk/splunk-sdk-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbinding1.py
executable file
·56 lines (44 loc) · 1.75 KB
/
binding1.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
# Copyright 2011 Splunk, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"): you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
"""An example that shows how to use the Splunk binding module to create a
convenient 'wrapper' interface around the Splunk REST APIs. The example
binds to a sampling of endpoints showing how to access collections,
entities and 'method-like' endpoints."""
import sys
from splunk.binding import connect
from utils import parse
class Service:
def __init__(self, context):
self.context = context
def apps(self):
return self.context.get("apps/local")
def indexes(self):
return self.context.get("data/indexes")
def info(self):
return self.context.get("server/info")
def settings(self):
return self.context.get("server/settings")
def search(self, query, **kwargs):
return self.context.post("search/jobs/export", search=query, **kwargs)
def main(argv):
opts = parse(argv, {}, ".splunkrc")
context = connect(**opts.kwargs)
service = Service(context)
assert service.apps().status == 200
assert service.indexes().status == 200
assert service.info().status == 200
assert service.settings().status == 200
assert service.search("search 404").status == 200
if __name__ == "__main__":
main(sys.argv[1:])