This file is indexed.

/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