root/StormSiren/StormWeather.py

Revision 190:75d280708ff5, 3.7 KB (checked in by cfreeze@…, 22 months ago)

correct merge problems that are showing up from bad branching

  • Property exe set to *
Line 
1#!/usr/bin/env python
2
3"""
4StormSiren
5Copyright (C) 2008  Chris Freeze <cfreeze/cfreeze_com\>
6
7Redistribution and use in source and binary forms, with or without
8modification, are permitted provided that the following conditions
9are met:
10
111. Redistributions of source code must retain the above copyright
12   notice, this list of conditions and the following disclaimer.
132. Redistributions in binary form must reproduce the above copyright
14   notice, this list of conditions and the following disclaimer in the
15   documentation and/or other materials provided with the distribution.
16
17THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27"""
28
29"""
30This is StormSiren a program inspired by the StormSiren application
31written by Roy McManus <slorf/users_sourceforge_net>.  Much like the
32original StormSiren written by Roy McManus <slorf/users_sourceforge_net>,
33this program is a simple script capable of scanning and providing
34notifications of weather bulletins issued by the National
35Weather Service.  StormSiren supports a wide range of paging devices
36and filtering of alert types per alert device.  While inspired by
37StormSiren, StormSiren is a complete rewrite that is capable of using
38the new CAP/XML feeds provided at http://www.weather.gov/alerts/.
39
40For more information there is see the README.TXT file located in the root
41of this directory.
42"""
43
44import logging
45import time
46
47from WeatherTypes import *
48from WeatherAlert import *
49from XmlWeather import *
50
51class StormWeather(XmlWeather):
52        def __init__(self, state, history, simfetch = False, simalert = False, proxy = None):
53                super(StormWeather,self).__init__(state,simfetch,proxy)
54                self.log = logging.getLogger("StormWeather")
55                self.__alert_devs = []
56                self.__simalert = simalert
57                self.__history = history
58
59                self.log.setLevel(logging.INFO)
60       
61        def __str__(self):
62                str  = "StormWeather: " + "\n"
63                if(self.__simalert):
64                        str  += "Sim Alert: yes\n"
65                else:
66                        str  += "Sim Alert: no\n"
67
68                str += super(StormWeather,self).__str__()
69                return str
70
71        def registerDevice(self, dev):
72                self.log.debug("Registering Device")
73                self.__alert_devs.append(dev)
74
75        def logAtomShort(self, cap_atom):
76                self.log.info("---------CAP ATOM---------")
77                for l in (cap_atom.__str__().split('\n')):
78                        self.log.info(l)
79                self.log.info("---------CAP ATOM---------")
80
81        def logAtomFull(self, cap_atom):
82                self.log.info("---------CAP ATOM---------")
83                for l in (cap_atom.__str__().split('\n')):
84                        self.log.info(l)
85                self.log.info("========DESCRIPTION=======")
86                if(cap_atom.description):
87                        for l in (cap_atom.description.split('\n')):
88                                self.log.info(l)
89                self.log.info("========DESCRIPTION=======")
90                self.log.info("---------CAP ATOM---------")
91
92        def handleAtom(self, cap_atom):
93                self.logAtomShort(cap_atom)
94                if(not self.__history.exists(cap_atom.id)):
95                        for dev in self.__alert_devs:
96                                if(dev.isAlertWanted(cap_atom)):
97                                        if(not self.__simalert):
98                                                cap_atom.expand(self.simfetch,self.proxy)
99                                                self.logAtomFull(cap_atom)
100                                                dev.send(cap_atom)
101                                                self.__history.add(cap_atom.id)
102                                        else:
103                                                self.log.info("Simulated Alert on: %s" % cap_atom.id)
104                else:
105                        self.log.debug("Ignoring %s: Already alerted on" % cap_atom.id)
Note: See TracBrowser for help on using the browser.