/usr/share/pyshared/freevo/plugins/yac.py is in python-freevo 1.9.2b2-4.2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | # -*- coding: iso-8859-1 -*-
# -----------------------------------------------------------------------
# yac.py - Support for YAC (Caller ID)
# -----------------------------------------------------------------------
# $Id: yac.py 9999 2007-10-18 15:31:31Z duncan $
#
# Notes:
# To activate, put the following line in local_conf.py:
# plugin.activate('yac')
#
# This plugin supports the "YAC" protocol as documented here:
# http://www.sunflowerhead.com/software/yac/
#
# It allows you to use a "YAC Server" to send messages; the yac
# server can run on Windows, and there is also a Linux version
# available: http://bah.org/tivo/ and clients for Windows and
# Linux.
#
# -----------------------------------------------------------------------
# Freevo - A Home Theater PC framework
# Copyright (C) 2002 Krister Lagerstrom, et al.
# Please see the file freevo/Docs/CREDITS for a complete list of authors.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of MER-
# CHANTABILITY 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.,
# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# -----------------------------------------------------------------------
import socket, time, sys
import plugin
from event import *
import rc
class PluginInterface (plugin.DaemonPlugin):
"""
Listen on the default YAC port (10629) for messages from a YAC server
and then display them using OSD_MESSAGE. Anything can be sent, though
it was originally designed to show Caller ID information on a TIVO.
"""
def __init__ ( self):
port = 10629
host = ''
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.sock.bind((host,port))
self.sock.listen(5)
self.sock.setblocking(0)
plugin.DaemonPlugin.__init__( self )
plugin.register( self, "yac")
def poll(self):
try:
conn,addr = self.sock.accept()
data = conn.recv(300) # 300 is max in specification
if data:
if data[:5] == '@CALL':
rc.post_event(Event(OSD_MESSAGE, arg=_('Call: %s') % data[5:-1]))
else:
rc.post_event(Event(OSD_MESSAGE, arg=_('Message: %s') % data[:-1]))
conn.close()
except:
pass
def shutdown(self):
self.sock = None
|