Roku::RCP(3) User Contributed Perl Documentation Roku::RCP(3)
NNAAMMEE
Roku::RCP - Object approach to controlling RCP enabled Roku products,
such as the Roku SoundBridge.
SSYYNNOOPPSSIISS
use Roku::RCP;
# Connect to the sleeping Roku, wake him up and tell him to play
# the All_Dynamic playlist
my $rcp = new Roku::RCP('192.168.0.102');
# You can leave out this whole if-statement if your Roku is already
# connected to a media server (and thus not in standby mode).
if (!$rcp->GetConnectedServer()) {
print "Not connected to firefly. Connecting ...\n";
die "Couldn't connect to Firefly\n" unless $rcp->ServerConnectByName("Firefly");
}
$rcp->PlayPlaylist("All_Dynamic") or die "No Can Do\n";
$rcp->Shuffle("on");
$rcp->Quit();
DDEESSCCRRIIPPTTIIOONN
"Roku::RCP" Gives you an object through which you can communicate with
your Roku Control Protocol-enabled Roku product. For the most part, the
commands are merely passed through onto the connection and the results
are parsed and returned to you either in an array in list context, or a
giant string in scalar context. Should the command fail, undef is
returned.
You'll want to familiarize yourself with the Roku Control Protocol
(RCP) by visting the Roku Labs site http://www.rokulabs.com and reading
the RCP spec. Although this module provides some convenience functions,
you'll need to have an understanding of the basic commands if you'd
like to do anything more fancy.
MMEETTHHOODDSS
"my $rcp = new Roku::RCP($hostname, %options)"
Construct a new object.
$rcp = new Roku::RCP('192.168.0.102', Debug=>1, RawResults=>1, Port=>5555, Timeout=>50);
If RawResults is set, you'll get back everything Roku sends back.
If it's not set, you'll just get back the data without any meta-
data. You can probably use RawResults along with Port=>4444 to send
non RCP commands over to the normal Roku telnet interface. The tel-
net interface listening on port 4444 is mostly operating system-
type commands and aren't related to media playback. Using Roku::RCP
to communicate with the regular telnet interface is a usage case
that hasn't been tested, but it should work. The module uses
AUTOLOAD to take whatever function you call and send that down the
connection.
"$rcp->ServerConnectByName($server_name)"
"ServerConnectByName()" Is a convenience function that takes a par-
tial or complete media server name and tries to connect to it. An
example of such would be "FireFly";
"$rcp->PlayPlayList($playlist_name)"
A convenience function that takes a partial or complete playlist
name and tries to start playing it.
"$rcp->PlayArtist($artist_name)"
A convenience function that takes an exact, case-sensitive artist
name and tries to play all the songs by that artist. Note that if
you'd like to do partial matching, you'll have to first call
$rcp->SearchArtists("vast"), get the resulting list back, pick one
and then call _P_l_a_y_A_r_t_i_s_t_(_) with that string.
"$rcp->PlayAlbum($album_name)"
A convenience function that takes an exact, case-sensitive album
name and tries to play all the songs on that album. Note that if
you'd like to do partial matching, you'll have to first call
$rcp->SearchAlbums("visual audio sensory theat"), get the resulting
list back, pick one and then call _P_l_a_y_A_l_b_u_m_(_) with that string.
"$rcp->PlaySong($song_name)"
A convenience function that takes a partial, case insensitive song
name and tries to play all the songs matching that string.
"$rcp->InsertSong($song_name)"
A convenience function that takes a partial, case insensitive song
name and tries to insert all matching songs into the queue and play
them. Note that if the song/s is/are already in your queue, the
position won't change and the next song in your queue will start
playing.
"$rcp->Quit()"
Cleanly close the connection. This will get called automatically
when the object is destroyed.
"$rcp->ROKU_RCP_COMMAND($arg1, $arg2, ...)"
Any commands not specifically listed here are considered to be RCP
commands and sent along down the connection. Here are a few to wet
your whistle: Next, Previous, Reboot, QueueAndPlay, GetTimeZone,
ListServers, ListPlaylists. Generally the paradigm is that you con-
nect to Roku, issue a command that lists out songs and then you
QueueAndPlay. Roku assumes you mean the last listing of songs.
Unless you want to wait for thousands and thousands of song titles
to come back, you generally want to tell Roku to forgo sending you
the entire list and just send you the total number.
$rcp->SetListResultType("partial") is your friend. Take a look at
how I did the _P_l_a_y_A_r_t_i_s_t_(_) convenience function as a good starting
place.
LLEEGGAALLEESSEE
Copyright 2007 by Robert Powers, all rights reserved. This program is
free software, you can redistribute it and/or modify it under the same
terms as Perl itself.
BBUUGGSS
This module is not 100% tested, but I use it every day, so it'll get
better over time.
AAUUTTHHOORR
2007, Robert Powers <batman@cpan.org>
perl v5.6.1 2007-03-31 Roku::RCP(3)