TV: Difference between revisions

From Leeds Hackspace Wiki
Jump to navigation Jump to search
m (update IP (how do we get DNS working?))
(Document new IRC camera control commands, and update repo locations)
Line 7: Line 7:
After much experimentation, I (HEx) settled on 1024x768 over VGA, software scaled to 1366x768.
After much experimentation, I (HEx) settled on 1024x768 over VGA, software scaled to 1366x768.


== Sauron ==
== Hardware ==


Driving the screen is an Athlon 64 box named sauron (172.31.26.112).  It runs debian jessie.
Driving the screen is an Athlon 64 box named sauron (172.31.26.112).  It runs debian jessie.
Line 19: Line 19:
* Twitter feed
* Twitter feed
* Mailing list feed
* Mailing list feed
* IRC
* IRC (Sauron is a member of the channel using the nickname Sauron-tv)
* Camera feed
* Camera feed


The code is stored on [https://github.com/hexwab/lhs-status GitHub] and is checked out locally to <code>/srv/lhs-status</code> on Sauron, which is then served by Apache.  
The code is stored on [https://github.com/leedshackspace/lhs-status GitHub] and is checked out locally to <code>/srv/lhs-status</code> on Sauron, which is then served by Apache.  


=== Mailing list feed ===
=== Mailing list feed ===
Line 28: Line 28:
The list of topics on the mailing list is served as an RSS feed by Google Groups, but due to [https://en.wikipedia.org/wiki/Cross-origin_resource_sharing CORS] restrictions it cannot be accessed using an AJAX request directly from the status page. As a workaround, Apache is configured to reverse-proxy requests to <code>topics.xml</code> in the main lhs-status directory to the actual Google Groups [https://groups.google.com/forum/feed/leeds-hack-space/msgs/rss.xml?num=15 RSS URL].
The list of topics on the mailing list is served as an RSS feed by Google Groups, but due to [https://en.wikipedia.org/wiki/Cross-origin_resource_sharing CORS] restrictions it cannot be accessed using an AJAX request directly from the status page. As a workaround, Apache is configured to reverse-proxy requests to <code>topics.xml</code> in the main lhs-status directory to the actual Google Groups [https://groups.google.com/forum/feed/leeds-hack-space/msgs/rss.xml?num=15 RSS URL].


=== IRC client ===
== Control through IRC ==


==== Commands ====
Sauron has some functions that can be triggered through the IRC channel. They can be run by mentioning the name of the bot in the Leeds Hackspace channel, followed by the command name, then the command arguments. Example: "Sauron-tv: bigtext This message will appear big onscreen". They don't work by private messaging Sauron-tv (yet).


The IRC client has some commands that can be run from the IRC channel. They can be triggered by mentioning the name of the bot in the Leeds Hackspace channel, followed by the command name, then the command arguments. Example: "Sauron-tv: bigtext This message will appear big onscreen". They don't work by private messaging Sauron-tv.
=== Commands ===


Currently available commands are:
==== General ====
* bigtext - show a short message in big flashing text on screen for 10 seconds. Args: the string to show
* bigtext - show a short message in big flashing text on screen for 10 seconds. Args: the string to show


==== Implementation ====
==== Camera view control ====
Controls what camera is currently displayed on the screen. Current camera choices are ''carpark'', ''main1'' (camera by the soldering station), ''main2'' (camera on the arcade cab), ''door'' (the internal door), ''outside'' (the external door), and ''3dprinter''.
* cam fix ''camname'' - View the specified camera indefinitely.
* cam resume - Resume rotating through cameras (Sauron starts up in this mode)
* cam view ''camname'' - View the specified camera for 30 seconds, then resume rotating


The IRC client embedded within the status page is a [https://github.com/ultrafez/shout fork] of the [https://github.com/erming/shout Shout] Node JS-based web IRC client. The fork includes Hackspace-specific additions such as a theme that hides all UI elements apart from the main chat messages window, in addition to having several pull requests on the main Shout repository merged ([https://github.com/erming/shout/pull/414 automatically joining the channel on load], and [https://github.com/erming/shout/pull/320 adding a framework for client plugins]).
=== Implementation ===
 
The IRC client embedded within the status page is a [https://github.com/leedshackspace/shout fork] of the [https://github.com/erming/shout Shout] Node JS-based web IRC client. The fork includes Hackspace-specific additions such as a theme that hides all UI elements apart from the main chat messages window, in addition to having several pull requests on the main Shout repository merged ([https://github.com/erming/shout/pull/414 automatically joining the channel on load], and [https://github.com/erming/shout/pull/320 adding a framework for client plugins]).


The client runs as a node process (managed by <code>supervisord</code>), which listens for HTTP connections on port 3000. The status page then embeds the client in an <code>iframe</code> pointing at <code>http://localhost:3000</code>.
The client runs as a node process (managed by <code>supervisord</code>), which listens for HTTP connections on port 3000. The status page then embeds the client in an <code>iframe</code> pointing at <code>http://localhost:3000</code>.

Revision as of 23:01, 22 September 2015

A plasma screen is affixed to the wall. It displays status information about the space.

The Screen

It's a Hitachi 42PD5000. Native resolution is 1024x1024, but it does not accept digital input at this resolution, or any sane resolution. The screen itself is 16:9, but all the advertised EDID modes are 4:3. The manual suggests that it should be capable of more, but these are specific to which inputs are used (DVI accepts different resolutions to VGA).

After much experimentation, I (HEx) settled on 1024x768 over VGA, software scaled to 1366x768.

Hardware

Driving the screen is an Athlon 64 box named sauron (172.31.26.112). It runs debian jessie.

User "kiosk" is logged in on boot, running Chromium in kiosk mode.

Status page

The status page displays:

  • General status from the API (open or closed, who's here, current temperature).
  • Twitter feed
  • Mailing list feed
  • IRC (Sauron is a member of the channel using the nickname Sauron-tv)
  • Camera feed

The code is stored on GitHub and is checked out locally to /srv/lhs-status on Sauron, which is then served by Apache.

Mailing list feed

The list of topics on the mailing list is served as an RSS feed by Google Groups, but due to CORS restrictions it cannot be accessed using an AJAX request directly from the status page. As a workaround, Apache is configured to reverse-proxy requests to topics.xml in the main lhs-status directory to the actual Google Groups RSS URL.

Control through IRC

Sauron has some functions that can be triggered through the IRC channel. They can be run by mentioning the name of the bot in the Leeds Hackspace channel, followed by the command name, then the command arguments. Example: "Sauron-tv: bigtext This message will appear big onscreen". They don't work by private messaging Sauron-tv (yet).

Commands

General

  • bigtext - show a short message in big flashing text on screen for 10 seconds. Args: the string to show

Camera view control

Controls what camera is currently displayed on the screen. Current camera choices are carpark, main1 (camera by the soldering station), main2 (camera on the arcade cab), door (the internal door), outside (the external door), and 3dprinter.

  • cam fix camname - View the specified camera indefinitely.
  • cam resume - Resume rotating through cameras (Sauron starts up in this mode)
  • cam view camname - View the specified camera for 30 seconds, then resume rotating

Implementation

The IRC client embedded within the status page is a fork of the Shout Node JS-based web IRC client. The fork includes Hackspace-specific additions such as a theme that hides all UI elements apart from the main chat messages window, in addition to having several pull requests on the main Shout repository merged (automatically joining the channel on load, and adding a framework for client plugins).

The client runs as a node process (managed by supervisord), which listens for HTTP connections on port 3000. The status page then embeds the client in an iframe pointing at http://localhost:3000.