Contents
- CardioLog Client-Side API
- The SendEvent JavaScript Function
- The SetReferer JavaScript Function
- The SendGoal JavaScript Function
- Monitoring Internal E-Mail Campaigns using the __referrer Parameter
- CardioLog Server-Side API
- Event Types
- Non-Browser Apps
- Data Export API
With the CardioLog APIs you can -
- Track visitor interactions with the browser such as clicks on a button or a banner, filling out form fields, playing videos and more, using our JavaScript API.
- Monitor internal E-mail campaigns.
- Send events to CardioLog from any application using the CardioLog Events API web service.
- Create custom events and build custom reports using the CardioLog SDK.
- Build applications to request data from the CardioLog reporting engine using the Data Export API, refine the results, display them anywhere you would like and brand your data with your organization’s colors and logos.
- Track visitor actions for non-browser apps, such as mobile apps.
CardioLog Client-Side API
The CardioLog tracking agent exposes a client-side API for sending custom events and easily monitoring clicks on a button or a banner, playing videos, or interactions with other types of UI components. On any monitored page, you can call the following JavaScript methods:
- The SendEvent JavaScript Function
- The SetReferer JavaScript Function
- The SendGoal JavaScript Function
The SendEvent JavaScript Function
This function allows for sending events via the client agent. The Agent uses Ajax (Asynchronous JavaScript and XML) to send the event to the server and will not affect the user interaction with the page in any way.
Code sample for sending a page view event:
The SendEvent function accepts the following parameters:
- Event Type - Required. The event type title (such as "Visit", "Search" or custom event types).
- URL - Required. This is usually the URL of the visited page, but can be any text that represents an action (make sure to define a unique prefix for each logical group of objects for optimal reports) - limited to 1000 characters.
- Param 1 - Optional. Used to store additional information about the event (for custom event types) - limited to 1000 characters. In built-in events it is reserved by the the system. For example - in a "Visit" event it is used to store the referrer information, in a "Search" event it is used to store the search term.
- Param 2 - Optional. Used to store additional information about the event (for custom event types) - limited to 50 characters. In built-in events it is reserved by the the system. For example - in a "Search" event it is used to store the number of results.
Note: when calling the “SendEvent” function within a different frame from where it is defined, make sure to reference the frame object containing it. (e.g. by using parent.document.__Page.SendEvent())
Monitoring Banner Clicks
You can monitor clicks on UI elements such as banners, buttons, navigation menu entries, links etc.
For example, in order to capture the click on a banner that links to an external site such as Google - before redirecting the user to the external destination page, make a call to the CardioLog SendEvent function.
Assuming the banner was implemented with simple HTML:
<a href="http://www.google.com" onclick="document.__Page.SendEvent('Visit', 'Banners > My Links > Google.com');"><img src="google_logo.gif"></a>
In our example, when a user clicks on the banner, before redirecting to Google, CardioLog will send an event of type "Visit" to the server, specifying which banner has been clicked by the user (in this case, "Banners > My Links> Google.com").
Define a unique prefix for each logical group of UI components (in this case - "Banners") that will be displayed in reports.
How many times my banners were clicked?
To see how many times your banners were clicked, use the Page Views > Events (Page Views by URL) report (either chart or table), and enter "Banners” in the Website Item field.
Who clicked on my banners?
To see who clicked on your banners, use the Unique Users > Vistors by Events (Unique Users by URL) report (either chart or table), and enter "Banners” in the Website Item URL field.
Please note that CardioLog tracks outbound links from SharePoint sites to external destinations out of the box. To see how many times your links were clicked, use the Navigation > External Destinations report.
The SetReferrer JavaScript Function
When dealing with internal links, besides monitoring the referring pages, you can monitor the referring navigation component (such as banners).
The SetReferrer function allows setting custom page referrer details, to be sent to the CardioLog server in future events (by SendEvent).
Code Sample:
The SetReferrer function accepts the following parameters:
- Id - Required. The custom page referrer details. This can be any string representation (make sure to define a unique prefix for each logical group of objects for optimal reports).
- Param 1 - Optional. Used to store additional information about the event (for custom reports).
Monitoring UI Referrers
In order to capture the referring UI component before redirecting the user, make a call to the CardioLog SetReferrer function.
Assuming the banner was implemented with simple HTML:
<a href="http://mysite/rnd/index.aspx" onclick="document.__Page.SetReferrer('Banners > MySite > Research and Development');"><img src="rnd.gif"></a>
How many visitors arrived on my page through my UI referrer?
To see how many visitors arrived on your page through your UI referrer, use the Navigation > Internal Traffic Sources report (either chart or table), and select the page in the Website Item URL field.
The SendGoal JavaScript Function
This function allows for sending JavaScript based goals via the client agent. The Agent uses Ajax (Asynchronous JavaScript and XML) to send the goal event to the server and will not affect the user interaction with the page in any way.
Code Sample:
The SendGoal function accepts the following parameter:
- Goal ID - Required.
Note: Goals are created in CardioLog > Administration > Goals. See "how to create a goal". After creating the goal, the Goal ID can be found in the tab_goals table (column - id) in the CardioLog database.
Monitoring JavaScript-Based Goals
In order to capture a JavaScript based goal, such as signing up to a newsletter, define the goal in CardioLog > Administration (See "how to create a goal"), and make a call to the CardioLog SendGoal function.
Assuming the signup button was implemented with simple HTML:
<input type="button" value="Signup to Newsletter" onclick="document.__Page.SendGoal(1);" />
Goal Reports
To see reports about your goals, use the Goals reports, and select the goal in the Visitor Segments > Goal field.
Monitoring Internal E-Mail Campaigns using the __referrer Parameter
The CardioLog Client-Side API supports capturing external referrers. You can use the _referrer parameter whenever you publish a link to your monitored environment and you wish to track the source of the referring page (e.g. email).
For example, if you have included an internal link in a promotional email add the __referrer parameter to be able to track the number of visits this link produced:
Define a unique referrer name that will be displayed in reports, such as __referrer=email_promotion_12_Dec_2008
How many visitors arrived on my page through my email campaign?
To see how many visitors arrived on your page through your email campaign, use the Navigation > Internal Traffic Sources report (either chart or table), and select the page in the Website Item URL field.
CardioLog Server-Side API
By Using the CardioLog Server-Side API - CardioLogAPI/Events.asmx web service and the SendEvent method - you can send view, duration and search events, as well as custom events, and track the URL of the referrer page.
The SendEvent Method
The SendEvent method in the CardioLogAPI/Events.asmx web service accepts the following parameters:
- UserName - Optional. The user associated with the event. If not passed, the method will use the current user credentials.
- SessionId - Required. The unique session Id associated with the event.
- Event Type - Required. The event type Id (such as 0 for "View").
- URL - Required. The URL associated with the event.
- UserAgent - Optional. The user details, such as browser type and OS version.
- ClientIP - Optional. The IP address of the client station.
- Param1 - Optional. Used to store additional information about the event (for custom event types) - limited to 1000 characters. In built-in events it is reserved by the the system. For example - in a "View" event it is used to store the referrer information, in a "Search" event it is used to store the search term.
- Param2 - Optional. Used to store additional information about the event (for custom event types) - limited to 50 characters. In built-in events it is reserved by the the system. For example - in a "Search" event it is used to store the number of results.
After the event is sent, the web service XML response will include the event identifier for future use, which you can later use to send events related to this event.
<log>
<status id='0'>OK</status>
<event id='211022'/>
</log>
</agent>
In case of an error, the XML response will include the error description:
<log>
<status id='-1'>Invalid Path</status>
</log>
</agent>
Event Types
The SendEvent method supports the following event types:
- View - single page viewed or element clicked
- Event Type Id - 0 (the Id is used in the Server-Side API)
- Event Type Title - "Visit" (the title is used in the Client-Side API)
To set the page referrer, use the following optional parameters for tracking the source of the page:
- Param1 -The related view event ID or a string representing referrer types (traffic sources such as navigation toolbars, campaigns, banners etc.).
- Param2 -The referrer page URL
Referrer pages can be retrieved in CardioLog with the "Navigation" visual controls.
- Duration - time spent on a page or element (in seconds).
- Event Type Id - 1
- Event Type Title - "Leave"
- URL - The related view event URL.
- Param1 - Duration in seconds.
- Param2 - The related view event ID.
- Search -
- Event Type Id - 2
- Event Type Title - "Search"
- URL - The related view event URL.
- Param1 - Search keyword/phrase.
- Param2 - Number of search results.
Search events can be viewed in CardioLog with the "Onsite Searches" visual control. The popular search terms are displayed in the “Onsite Search Phrases” visual control.
- Search Result Click -
- Event Type Id - 5
- Event Type Title - "SearchResultClick"
- URL - The search result URL.
- Param1 - The search result position within search results.
- Param2 - The related search event ID.
Creating Custom Event Types
You can create custom event types and build custom reports using the CardioLog SDK. The custom event types can be used in the SendEvent function (in both Client-Side and Server-Side APIs).
For example, if your website is a sales site and you wish to track each sale, and then create a report on the number of items sold, you can create a custom event type in CardioLog named "Item-Sold":
1. Add the custom event type to the CardioLog database by executing the following query against the CardioLog database:
INSERT INTO tab_event_type(id,description)
VALUES(100, 'Item-Sold')
GO
Id - must be 100 or higher
description - event type title
2. Add the custom event type to the CardioLog tracking agent events array - edit the __eEvents array and add the custom event type in:
For MOSS 2007 only:
[CardioLog installation directory]\CardioLogAgent\MOSS2007_1.2.js
For SharePoint 2010 only:
[CardioLog installation directory]\CardioLogAgent\SP2010_1.2.js
For SharePoint 2013 only:
[CardioLog installation directory]\CardioLogAgent\SP2013_1.2.js
Note: If you have implemented the Tracking Agent using the "CardioLog Analytics" SharePoint Feature on your WFEs - edit the __eEvents array and add the custom event type in:
For MOSS 2007 only:
C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\12\TEMPLATE\LAYOUTS\CardioLogAgent\MOSS2007_1.2.js
For SharePoint 2010 only:
C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\14\TEMPLATE\LAYOUTS\CardioLogAgent\SP2010_1.2.js
For SharePoint 2013 only:
C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\14\TEMPLATE\LAYOUTS\CardioLogAgent\SP2013_1.2.js
__eEvents = {
Visit: { id: 0, name: "Visit" },
Leave: { id: 1, name: "Leave" },
Search: { id: 2, name: "Search" },
SearchResultItem: { id: 4, name: "SearchResultItem" },
SearchResultClick: { id: 5, name: "SearchResultClick" },
External: { id: 10, name: "External" },
Goal: { id: 20, name: "Goal" },
"Goal-Test": { id: 21, name: "Goal-Test" },
Test: { id: 22, name: "Test" },
Score: { id: 23, name: "Score" },
Ping: { id: 24, name: "Ping" },
Item-Sold: { id: 100, name: "Item-Sold" },
Unknown: { id: -1, name: "Unknown" }
};
3. Implement the call to the SendEvent function when an item is sold (using our Client-Side API or Server-Side API).
4. Create a custom report to display the number of items sold using the CardioLog SDK.
Non-Browser Apps
Since non-browser apps, such as mobile apps, don't contain HTML pages, developers simply determine when their apps should trigger page view requests. CardioLog Analytics then aggregates this data in reports to display the number of visits, unique visitors, session length, bounce rates, etc. This data gives insight into how users interact with the client app.
Developers can also track visitor actions that don't correspond directly to page views using other Event types. These user actions can include views of embedded videos, button clicks, downloads and more. App developers can then use this data to understand which features are most popular and inform decisions about which features should be promoted or prioritized for further development.
The REST API
In order to track visitor actions for non-browser apps, developers must send usage event objects to the CardioLogAgent web application through HTTP POST requests in JSON format. The JSON string must be embedded in the request body. The POST response is provided in JSON format as well.
- The request must include a “Content-Type: application/json” header
- The request may optionally include an “Accept: application/json” header
The Event Object
CardioLog Analytics usage event objects have the following properties:
- u - URL of the page the event is related to. For example, in a “View” event, the URL will be the current page, while in search result click it will be the URL of the result clicked.
- X - Holds the following information:
- In Search event - the search term
- In View event:
- If __Referrer parameter was passed to this page, its value
- If there is a Referrer cookie, sends the ReferrerReason cookie value
- If this is the first page the user views in this session, send “First In Session” and append the data from __Referreragent
- In Duration event - time on page (in seconds)
- Y - Holds the following information:
- In Search event - Number of total results
- In Visit event - If there is a Referrer cookie, send its content
- In Duration event - last visit event id
- Z - In Search event - First result on page (number of result)
- RI - Last event id
- et - Event type code (for example, Goal event is 20, Leave event is 1 etc.)
- events - The event can have sub events sent with it (for example, when a search event is sent or when there are saved events).
In addition to event objects, the request body may include the following properties:
- browserType - the user-agent information
- sessionid (any string format accepted)
- un - user id (any string format accepted)
The JSON request format
The full JSON request format is as follows:
{ "events": { "event": [ { "u": "http://www.intlock.com/", "X": "|referral|blog.intlock.com|/about/||", "et": 0, "RI": 564940 }, { "X": "1", "Y": "7", "et": 23, "RI": 0 } ] }, "browserType": "Apple-iPhone5C2/1001.525", "sessionid": "861529144.325047542", "un": "INTLOCK\\tomj" }
The API URL
The API URL for a SharePoint site is:
https://[SharePoint WFE]/_layouts/CardioLogAgent/tunnel.aspx?random= 895.3324414324015
- Replace [SharePoint WFE] with your SharePoint URL address
- The random param is used as a cache buster
Data Export API
With the Data Export API you can develop client applications to retreive data from the CardioLog reporting engine, and refine the results of the request using query parameters. It allows for more flexibility and customization than the CardioLog UI, giving you a great deal of freedom over how to display your reports, in terms of their design, filters and data content, and where the reports are displayed. It’s also possible to brand your data with your organization’s colors and logos to really take ownership of it.
The CardioLog reporting engine generates the report in XML format and as a chart image.
Use the Reports API Helper to generate a URL which can be embedded in a client application. When calling this URL the report will be generated based on the selected parameters.
- Browse: http://<cardiolog_server>:<port>/CardioLog/CLReport/ReportsAPIHelper.aspx
- Select a Report.
- Select the report parameters – Date Range, Time Interval, Website Item, Users and Groups
- Check Generate Chart Image to create an image and set its Width and Height (pixels).
- Click Get URL to generate the report URL
- Click Generate Report to generate the report.
- Click Show Advanced Options and Get Report Preferences to modify report preferences.
The CardioLog Report XML Schema
The CardioLog report XML contains a preferences (prefs node) and a data section (data node).
Chart
The chart x-axis values are displayed in the categories node, while y-axis values are displayed in the dataset node (each chart series is represented by a dataset node).
Table
The data section for Table reports is ready for HTML deployment.
<prefs>
<showhelp>false</showhelp>
<showpreferences>false</showpreferences>
<timeframe>36000000000</timeframe>
<timeInterval>36000000000</timeInterval>
<maxrows>10</maxrows>
<mincount>1</mincount>
<reporttype>120</reporttype>
<columns>
<column id="title" title="Title" width="35%" type="SPPage" />
<column id="url" title="Url" width="0" type="hidden" />
<column id="views" title="Views" sorted="true" width="15%" type="number" />
<column id="users" title="Unique Users" sorted="false" width="20%" type="number" />
<column id="avgDuration" title="Duration" sorted="false" width="15%" type="string" />
<column id="exitRate" title="Exit Rate" sorted="false" width="15%" type="number" />
</columns><ctitle>Page Views</ctitle><chartType>static</chartType><adgroup></adgroup><adgroupname></adgroupname><categories></categories><entityId>0:b0426e68-8f34-4eb2-8702-012d5de1c143</entityId><entityName>All</entityName><entityTree>0</entityTree>
</prefs>
<thead>
<td type='SPPage' width='35%' id='title'>Title</td>
<td type='hidden' width='0' id='url'>Url</td>
<td type='number' width='15%' sorted='true' direction='-1' id='views'>Views</td>
<td type='number' width='20%' id='users'>Unique Users</td>
<td type='string' width='15%' id='avgDuration'>Duration</td>
<td type='number' width='15%' id='exitRate'>Exit Rate</td>
</thead>
<tbody from='0' to='10' total='10'>
<tr>
<td>bl_SecondaryNav_Divider.jpg</td>
<td>http://scotland:81/Style Library/Images/bl_SecondaryNav_Divider.jpg</td>
<td>3</td>
<td>3</td>
<td>00:00:04</td>
<td>0%</td>
</tr>
<tr>
<td>Links</td>
<td>http://scotland:81/Lists/Links/AllItems.aspx</td>
<td>3</td>
<td>3</td>
<td>00:00:02</td>
<td>0%</td>
</tr>
<tr>
<td>Workflow Tasks</td>
<td>http://scotland:81/News/WorkflowTasks/AllItems.aspx</td>
<td>3</td>
<td>3</td>
<td>00:00:07</td>
<td>0%</td>
</tr>
<tr>
<td>Total Problems</td>
<td>http://scotland:81/Reports/Lists/Sample Dashboard KPI Definitions/DispForm.aspx?ID=1</td>
<td>3</td>
<td>3</td>
<td>00:00:05</td>
<td>0%</td>
</tr>
</tbody>
<startTime>1/1/0001 12:00:00 AM</startTime><endTime>1/1/0001 12:00:00 AM</endTime><rules>1</rules></table>]]>
</data>
</call>
</report>
</xml>
Meter
The Meter data is displayed in the value node.
<report>
<call controlId="412" action="get" cached="True">
<controlTitle>Meter</controlTitle><title>Page Views</title>
<prefs>
<prefs><showhelp>false</showhelp><showpreferences>false</showpreferences><timeframe>36000000000</timeframe><timeInterval>36000000000</timeInterval><minvalue>0</minvalue><maxvalue>100</maxvalue><undershoot>0</undershoot><overshoot>100</overshoot><ctitle>Page Views</ctitle><chartType>static</chartType><adgroup></adgroup><adgroupname></adgroupname><categories></categories><entityId>0:b0426e68-8f34-4eb2-8702-012d5de1c143</entityId><entityName>All</entityName><entityTree>0</entityTree></prefs>
</prefs>
falsefalse3600000000036000000000101120Page Viewsstatic0:b0426e68-8f34-4eb2-8702-012d5de1c143All0 Title Url Views Unique Users Duration Exit Rate bl_SecondaryNav_Divider.jpg http://scotland:81/Style Library/Images/bl_SecondaryNav_Divider.jpg 3 3 00:00:04 0% Links http://scotland:81/Lists/Links/AllItems.aspx 3 3 00:00:02 0% Workflow Tasks http://scotland:81/News/WorkflowTasks/AllItems.aspx 3 3 00:00:07 0% Total Problems http://scotland:81/Reports/Lists/Sample Dashboard KPI Definitions/DispForm.aspx?ID=1 3 3 00:00:05 0% 1/1/0001 12:00:00 AM1/1/0001 12:00:00 AM1]]></data>
</call>
</report>
</xml>
Examples:
1. How to add values to the chart image
2. How to display the page views meter value
<script>
function getPageViews() {
// 1. Call the web service "http://cardiologservername:port/CardioLog/clreport/reportsapi.aspx" with the parameters "action=xml&controlId=3015&timeframe=77760000000000&urls=&usersAndGroups=&categoryId="
// 2. Create an XML file from the response and find the <data> node: selectSingleNode("//data").text;
// 3. Find the <value> node value with regex. Example:
var re = new RegExp("(^[^$]*<value>)([^<]*)(<\/value>[^$]*$)", "i");
if (response.match(re)) value = response.replace(re, "$2");
document.getElementById("pageviews").innerHTML = "This Year this site was viewed " + value + " times!";
window.onload = function () {
getPageViews();
}
</script>
<body>
<div id ="pageviews" class="sample"> </div>
</body>
</html>
0 Comments