forked from enesbcs/rpieasy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
_N008_MSTeams.py
98 lines (89 loc) · 2.84 KB
/
_N008_MSTeams.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
#!/usr/bin/env python3
#############################################################################
################## MSTeams notifier plugin for RPIEasy ######################
#############################################################################
#
# Copyright (C) 2021 by Alexander Nagy - https://bitekmindenhol.blog.hu/
#
import nplugin
import webserver
import rpieGlobals
import misc
import commands
import urllib.request
import threading
import requests
import ssl
import json
class Plugin(nplugin.NPluginProto):
NPLUGIN_ID = 8
NPLUGIN_NAME = "MS Teams"
def __init__(self,nindex): # general init
nplugin.NPluginProto.__init__(self,nindex)
self.server = "webhook.office.com"
self.port = 443
self.passw = ""
self.fullurl = ""
self.body="" # template
def getuniquename(self):
fullurl = ""
if self.fullurl !="":
furl = self.fullurl.replace("//","/")
try:
fa = furl.split("/")
fullurl = fullurl[1]
except:
pass
else:
fullurl = self.server
return fullurl
def plugin_init(self,enableplugin=None):
nplugin.NPluginProto.plugin_init(self,enableplugin)
if self.passw=="*****":
self.passw=""
self.initialized = False
if self.fullurl != "" and self.enabled:
self.initialized = True
def webform_load(self): # create html page for settings
webserver.addFormTextBox("Teams channel Webhook URL","fullurl",self.fullurl,512)
webserver.addHtml("<TR><TD>Body:<TD><textarea name='body' rows='5' cols='80' size=255 wrap='off'>")
webserver.addHtml(str(self.body))
webserver.addHtml("</textarea>")
return True
def webform_save(self,params): # process settings post reply
self.fullurl = webserver.arg("fullurl",params)
self.body = webserver.arg("body",params)
self.plugin_init()
return True
def notify(self,pmsg=""):
if self.initialized==False or self.enabled==False:
return False
if pmsg=="":
message = self.msgparse(self.body)
else:
message = self.msgparse(pmsg)
try:
jdata = {'text': str(message) }
urlstr = str(self.fullurl)
except Exception as e:
misc.addLog(rpieGlobals.LOG_LEVEL_ERROR,"Teams notification: "+str(e))
return False
misc.addLog(rpieGlobals.LOG_LEVEL_INFO,"Sending Teams notification")
httpproc = threading.Thread(target=self.urlpost, args=(urlstr,jdata,)) # use threading to avoid blocking
httpproc.daemon = True
httpproc.start()
return True
def urlpost(self,url,postdata):
try:
hdr = {'Content-Type': 'application/json'}
response = requests.post(url, headers=hdr, data=json.dumps(postdata))
# str(response.text.encode('utf8'))=='1'
except Exception as e:
misc.addLog(rpieGlobals.LOG_LEVEL_ERROR,"Controller: "+ self.getuniquename() +" connection failed "+str(e))
def msgparse(self,ostr):
cl, st = commands.parseruleline(ostr)
if st=="CMD":
resstr=str(cl)
else:
resstr=str(ostr)
return resstr