mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-04-26 22:34:22 +02:00
* Renamed 'apis/PyPAD/examples/pypad_test.py' to 'apisPyPAD/tests/pad_test.py'. * Added a 'hostName' field to the JSON PAD 'padUpdate' object. * Added a 'PyPAD.Update::hostName()' method. * Added a 'shortHostName' field to the JSON PAD 'padUpdate' object. * Added a 'PyPAD.Update::shortHostName()' method. * Added a 'PyPAD.Update::resolveFilepath()' method. * Added 'apis/PyPAD/tests/filepath_test.py. * Added 'api/PyPAD/examples/pypad_filewrite.py'.
89 lines
3.1 KiB
Python
Executable File
89 lines
3.1 KiB
Python
Executable File
#%PYTHON_BANGPATH%
|
|
|
|
# pypad_filewrite.py
|
|
#
|
|
# Write PAD updates to files
|
|
#
|
|
# (C) Copyright 2018 Fred Gleason <fredg@paravelsystems.com>
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License version 2 as
|
|
# published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public
|
|
# License along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
#
|
|
|
|
import sys
|
|
import configparser
|
|
import PyPAD
|
|
|
|
def eprint(*args,**kwargs):
|
|
print(*args,file=sys.stderr,**kwargs)
|
|
|
|
def processUpdate(update,section):
|
|
try:
|
|
if config.get(section,'ProcessNullUpdates')=='0':
|
|
return True
|
|
if config.get(section,'ProcessNullUpdates')=='1':
|
|
return update.hasPadType(PyPAD.TYPE_NOW)
|
|
if config.get(section,'ProcessNullUpdates')=='2':
|
|
return update.hasPadType(PyPAD.TYPE_NEXT)
|
|
if config.get(section,'ProcessNullUpdates')=='3':
|
|
return update.hasPadType(PyPAD.TYPE_NOW) and update.hasPadType(PyPAD.TYPE_NEXT)
|
|
except configparser.NoOptionError:
|
|
return True
|
|
|
|
log_dict={1: 'MasterLog',2: 'Aux1Log',3: 'Aux2Log',
|
|
101: 'VLog101',102: 'VLog102',103: 'VLog103',104: 'VLog104',
|
|
105: 'VLog105',106: 'VLog106',107: 'VLog107',108: 'VLog108',
|
|
109: 'VLog109',110: 'VLog110',111: 'VLog111',112: 'VLog112',
|
|
113: 'VLog113',114: 'VLog114',115: 'VLog115',116: 'VLog116',
|
|
117: 'VLog117',118: 'VLog118',119: 'VLog119',120: 'VLog120'}
|
|
if config.get(section,log_dict[update.machine()]).lower()=='yes':
|
|
return True
|
|
if config.get(section,log_dict[update.machine()]).lower()=='no':
|
|
return False
|
|
if config.get(section,log_dict[update.machine()]).lower()=='onair':
|
|
return update.onairFlag()
|
|
|
|
def ProcessPad(update):
|
|
n=1
|
|
try:
|
|
while(True):
|
|
section='File'+str(n)
|
|
if processUpdate(update,section):
|
|
fmtstr=config.get(section,'FormatString')
|
|
mode='w'
|
|
if config.get(section,'Append')=='1':
|
|
mode='a'
|
|
f=open(update.resolveFilepath(config.get(section,'Filename'),update.dateTime()),mode)
|
|
f.write(update.resolvePadFields(fmtstr,int(config.get(section,'Encoding'))))
|
|
f.close()
|
|
n=n+1
|
|
|
|
except configparser.NoSectionError:
|
|
return
|
|
|
|
#
|
|
# Read Configuration
|
|
#
|
|
if len(sys.argv)>=2:
|
|
fp=open(sys.argv[1])
|
|
config=configparser.ConfigParser(interpolation=None)
|
|
config.readfp(fp)
|
|
fp.close()
|
|
else:
|
|
eprint('pypad_filewrite.py: you must specify a configuration file')
|
|
sys.exit(1)
|
|
|
|
rcvr=PyPAD.Receiver()
|
|
rcvr.setCallback(ProcessPad)
|
|
rcvr.start('localhost',PyPAD.PAD_TCP_PORT)
|