Sunday, September 10, 2023
Custom Timeouts for Citrix StoreFront - Revisited
Sunday, July 16, 2023
Custom Timeouts for Citrix StoreFront
One of the features that I have found missing in StoreFront is the ability to set different timeouts for different categories of users. For example, you may wish to have a shorter timeout for users in a sensitive department (e.g. Finance). If you feel the same way, read on ...
Let's assume that you would like the Finance department to have a shorter timeout period (e.g. 5 minutes) rather than the default value of 20 minutes. First, you would need a way to determine if the user logging on to StoreFront is in the Finance department. You would then need to set the appropriate timeout based on the user's membership.
The first requirement may be accomplished by adding the following .Net .aspx file (inGroup.aspx) to the custom directory. You pass it the user's ID and the department (OU) you wish to check for membership. and it will return true if the user is a member of that OU or false if the user is not. It is beyond the scope of this post to explain each of the routines in the file, but two points need to be mentioned.
1) You must edit the file at line #11 to reflect the user root OU and your company's domain:
string rootOU = "OU=Accounts,DC=domain,DC=com";
2) You need to add an assembly to the file web.config in your store's web directory (e.g. /Citrix/StoreWeb). To do this:
- make a backup of the web.config file.
- open the file and search for <assemblies>
<assemblies>
<add assembly="System.Web.Mvc, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Abstractions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Routing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
</assemblies>
- insert the following line right before the closing </assemblies> tag
<add assembly="System.DirectoryServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
- which should then look like
<add assembly="System.Web.Mvc, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Abstractions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Routing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.DirectoryServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</assemblies>
- save the file
You also need to copy the contents of this script file (script.js) into the script file currently in the custom directory (after backing it up, of course). At the very top of the file you will see:
var specialGroup = "Finance";
var specialTimeoutMins = 5;
Sunday, May 28, 2023
QoS Indicator for Citrix StoreFront
After the successful release of Setting user Expectations, which showed you how to add a QoS (Quality of Service) indicator to the NetScaler logon screen, I've had requests for a similar indicator for StoreFront.
As a bonus, we will have the display auto-refresh at a custom-defined interval. We will set it to every 15 seconds, but you can very easily modify that.
Note: The code in this post has been written for StoreFront version 2203. The code may need to be tweaked for other versions of StoreFront.
All of the modifications may be done via updates within the custom directory of the site, which means that they will be replicated to all servers in the StoreFront group when you propagate.
The following code should be added to script.js (in the custom directory):
var refreshIntervalSecs = 15;
Sunday, April 16, 2023
Setting User Expectations - Part 3
In Part 1 of this series, we discussed how to create a QoS indicator to inform the user of their expected experience before they even logon by making a few simple changes to the NetScaler. In Part 2 of the series, we added a graphical representation of the results. In this final installment, we will add a reference page that will display the various ranges of the QoS indicator to the user.
All of the graphics needed have already been created and uploaded in Part 2. We simply need to create a page that references the various ranges, and change the display into a hyperlink that when clicked, opens up the reference page.
You can download the above page here:
https://samjacobs.sharefile.com/d-s4eaf8e876fe449afada749110b5ae48c
Let's modify the original display by adding a hyperlink to the above page.
Make a backup of our original file: /var/netscaler/logon/LogonPoint/tmindex.html
Open up the file and search for:
QoStext.innerHTML = 'Connection Strength:<br>'+QoSrange;
Add a hyperlink to our reference page by changing the above to:
QoStext.innerHTML = '<a href="QoS.html">Connection Strength:<br>'+QoSrange+'</a>';
Then save the file. Now when you click on the text of the QoS indicator, the reference page will be displayed.
Sunday, February 26, 2023
Setting User Expectations - Part 2
In Part 1 of this series, we discussed how to create a QoS indicator to inform the user of their expected experience before they even logon by making a few simple changes to the NetScaler. In part 2 of the series, we will add a graphical representation of the results. The strength of the connection will be represented by the number of bars in the graphic - the more bars, the stronger the connection.
The first step will be to upload the bar images which may be found here:
https://samjacobs.sharefile.com/d-s15afc8842d044e8cb6f0da39dc6e0381
into the following directory:
/var/netscaler/logon/themes/QoS/custom_media.
Next, we need to add some css to the file: /var/netscaler/logon/themes/QoS/css/theme.css.
Insert the following:
display:table-cell;
min-width:70px;
height:40px;
}
min-width:70px;
height:40px;
background-repeat: no-repeat;
}
background-image: url("../custom_media/FourBars.png");
}
.ThreeBars {
background-image: url("../custom_media/ThreeBars.png");
}
.TwoBars {
background-image: url("../custom_media/TwoBars.png");
}
.OneBar {
background-image: url("../custom_media/OneBar.png");
}
.NoBars {
background-image: url("../custom_media/NoBars.png");
}
Now when you browse to your logon page, in addition to having the connection strength is milliseconds, you will also have the strength displayed graphically.
Sunday, January 8, 2023
Setting User Expectations - Part 1
One of the main gripes from Citrix administrators are clients complaining that Citrix is slow when the issue is not anything in the Citrix infrastructure, but rather at the user's endpoint. This can include issues such as the user's PC (e.g. slow or pegged CPU), or a weak Wi-Fi connection.
In this 3-part series, I will show you how to set the user's expectations before they even log on by placing what I call a QoS (Quality of Service) indicator on your NetScaler's logon page. This is accomplished by measuring what is known as Time To First Byte (TTFB). TTFB is a metric that measures the time between the request for a resource and when the first byte of a response begins to arrive by downloading a very small file from the NetScaler.
For this series, we will be using firmware version 13.1 of NetScaler, and we will be using the RfWebUI (Receiver for Web UI) theme. The tool we will use for most of our work will be WinSCP - a free secure copy utility (https://winscp.net/eng/download.php).
In Part 1, we will get the basics of the QoS indicator done, and when finished, it should look something like this:
We begin by creating a NetScaler theme which will contain the look and feel of our customizations. The easier way to do this is by opening up a PuTTY (terminal emulation software) session to the primary node and entering:
add vpn portaltheme QoS -basetheme RfWebUI
These changes will be replicated from the primary node to the secondary node. Make sure you make these changes to the primary, or they will be removed the next time the config is synched from the primary node.
The above command will create a new theme called QoS in the following directory: /var/netscaler/logon/themes.
Open the file /var/netscaler/logon/themes/QoS/css/theme.css and insert the following:
display:table-row;
height:125px;
width:250px;
float:right;
color: #fff;
}
#QoStext {
display:table-cell;
font-family:'Open Sans', sans-serif;
font-size:12px;
width:170px;
min-height:30px;
margin-left:10px;
vertical-align:middle;
padding-top:7px;
text-align:left;
}
#QoStext a {
color:white;
}
Then save the file.
We then need to make a backup up of the following file on the NetScaler: /var/logon/LogonPoint/tmindex.html. Open the file. Around line 386, you should see:
<div class="logon-spacer"></div>
Add the following lines between <div class="logon-spacer"> and </div>:
<div id="QoStext"> </div>
</div>
This is where the QoS indicator will be inserted on the screen.
When done, it should look like this:
The final step will be to insert the JavaScript code for the Time To First Byte calculation and to insert the result into the QoStext <div> above.
Scroll to the bottom of the file and locate the following two lines:
<script src="receiver/js/ctxs.webui.min.js"></script>
Insert the following:
var testImgUrl = "https://" + location.hostname + "/vpn/images/Tick32.gif";
function checkLatency(url, callback) {
//alert("checkLatency()...");
var t=[], n=2, tcp, rtt;
var ld = function() {
t.push(+new Date);
if(t.length > n) {
rtt=t[2]-t[1];
callback(rtt);
}
else {
var img = new Image;
img.onload = ld;
img.src=url+"?" + Math.random() + '=' + new Date;
}
};
ld();
}
function displayQoS(latency) {
var QoStext = document.getElementById("QoStext");
for (i=0; i<aLatencyRanges.length;i++) {
if(latency<=aLatencyRanges[i][0]) {
var QoSclass = aLatencyRanges[i][1];
var QoSrange = aLatencyRanges[i][2] + ' (' + latency + ' ms.)';
QoStext.innerHTML = 'Connection Strength:<br>'+QoSrange;
break;
}
}
}
function runQoS() {
checkLatency(testImgUrl, displayQoS);
}
runQoS();
</script>
Then save the file. Note: if you have an HA pair, any changes to this file must be done to both NetScalers - source code changes are not replicated between the nodes.
That's it! In Part 2, we will add a graphical representation of the QoS indicator.
Thursday, September 15, 2022
Citrix Application Performance Reports
- Application usage report with the number of users for a particular timespan








