Overview#

The basic flow of data from EPICS to the WWW site is described in the following diagram:

_images/overview.jpg

flow of data from EPICS to WWW site#

The pvWebMonitor service is run on a computer in the same subnet as the EPICS system to be monitored. All configuration files and other resources are placed in a single project directory. pvWebMonitor places an EPICS Channel Access monitor on each PV in the pvlist.xml file and stores updates in-memory. Periodically, as specified in config.xml, pvWebMonitor writes the PV values from memory to an XML file (named rawdata.xml) in the project directory. Once that XML file is written, pvWebMonitor uses rawdata.xml [1] with each of the XSLT files [2] in the project directory to create a corresponding HTML file in the project directory. The complete list of HTML files is written into an index.html file in the project directory. Finally, all content in the project directory (except for the config.xml file) is copied to the WWW site directory. (Only new content is copied, files that do not change are not re-copied.)

It is important to note the WWW site is written as a static web site so that it provides no opportunity to change values in the EPICS system being monitored.

Also, since some browsers do not have XML parsers and thus cannot render XSLT [3], all HTML files are created by pvWebMonitor.

Examples#

Example (very brief [4]) rawdata.xml file:

 1<?xml version="1.0"?>
 2<?xml-stylesheet type="text/xsl" href="short.xsl"?>
 3<pvWebMonitor version="1">
 4  <written_by>pvWebMonitor/PvWatch</written_by>
 5  <datetime>2015-01-15 16:48:36</datetime>
 6  <pv id="VDM_Stripe" name="prj:m1.RBV">
 7    <name>prj:m1.RBV</name>
 8    <id>VDM_Stripe</id>
 9    <description>VDM_Stripe motor</description>
10    <timestamp>2015-01-15 15:30:16.837633</timestamp>
11    <counter>2</counter>
12    <units>deg</units>
13    <value>-1.510</value>
14    <raw_value>-1.51</raw_value>
15    <format>%.3f</format>
16  </pv>
17</pvWebMonitor>

Each XSLT file describes the format of an HTML page. The XSLT file uses XSL markup to pick EPICS PV values from the XML file. Here’s an example that shows the value of the PV prj:m1.RBV. (The id VDM_Stripe is used here as a symbolic reference.):

<xsl:value-of select="//pv[@id='VDM_Stripe']/value"/>

Here’s how to show when that PV value was last updated:

<xsl:value-of select="//pv[@id='VDM_Stripe']/timestamp"/>

Here’s how to show when the EPICS PV data was last posted to the WWW site:

<xsl:value-of select="/pvWebMonitor/datetime"/>

The XSLT language has many additional functions available to help as your page designs get more complex. Look at the supplied livedata.xsl file for additional examples. There are good tutorial web sites available, such as: http://www.w3schools.com/xsl

Here’s an example XSLT file using these example lines above (line breaks, <br />, were added for clarity):

 1<?xml version="1.0" encoding="UTF-8"?>
 2<xsl:stylesheet 
 3    xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
 4    version="1.0"
 5    description="simple example XSLT to EPICS PV value">
 6
 7    <xsl:template match="/">
 8        <html>
 9            <body>
10                EPICS PV: <xsl:value-of select="//pv[@id='VDM_Stripe']/name"/><br />
11                
12                PV value: <xsl:value-of select="//pv[@id='VDM_Stripe']/value"/><br />
13                
14                PV last updated: <xsl:value-of select="//pv[@id='VDM_Stripe']/timestamp"/><br />
15                
16                HTML file written: <xsl:value-of select="/pvWebMonitor/datetime"/>
17            </body>
18        </html>
19    </xsl:template>
20
21</xsl:stylesheet>

The XSLT transformation using the XML file above looks like:

1<html><body>
2                EPICS PV: prj:m1.RBV<br>
3                
4                PV value: -1.510<br>
5                
6                PV last updated: 2015-01-15 15:30:16.837633<br>
7                
8                HTML file written: 2015-01-15 16:48:36</body></html>

Which shows in a browser:

_images/short.jpg

Example HTML web page from above.#