/usr/share/irssi/scripts/isdn.pl is in irssi-scripts 20131030.
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 | # DESCRIPTION
# Displays incoming ISDN calls to active window
# Looks even nicer with entries in
# /etc/isdn/callerid.conf - see callerid.conf(5)
#
# CHANGELOG
# 17.06.04
# Script now runs for several days without any
# problems. Added documentation.
use Irssi;
use vars qw($VERSION %IRSSI);
$VERSION = "0.3";
%IRSSI = (
authors => "Uli Baumann",
contact => "f-zappa\@irc-muenster.de",
name => "isdn",
description => "Displays incoming ISDN calls",
license => "GPL",
changed => "Thu Jun 17 12:49:55 CEST 2004",
);
sub incoming_call() # triggered by a timer; use of input_add
{ # caused crash
while ($message = <ISDNLOG>)
{
chomp($message);
if ($message =~ / Call to tei .* RING/) # just incoming calls
{
my $from = $message; # extract caller
$from =~ s/.*Call to tei.*from (.*) on.*RING.*/$1/;
my $to = $message; # extract callee
$to =~ s/.*Call to tei.*from .* on (.*) RING.*/$1/;
my $window = Irssi::active_win(); # write message to active win
$window->print("%YISDN:%n call from $from");
$window->print(" to $to");
}
}
}
sub isdn_unload() # for a clean unload
{
close $ISDNLOG;
Irssi::timeout_remove($timer);
}
# when starting, open the isdnlog file and set pointer to eof
open ISDNLOG, "< /var/log/isdn/isdnlog" or die "Can't open isdnlog";
seek ISDNLOG,0,2;
# install timeout for the incoming_call subroutine
$timer=Irssi::timeout_add(1000, \&incoming_call, \&args);
# disable timer and close file when script gets unloaded
Irssi::signal_add_first('command script unload','isdn_unload');
|