TF30063 Errors accessing a TFS 2015 server via the C# API after upgrade from 2013
Background
We upgraded our production TFS 2013.4 server to TFS 2015 RTM this week. As opposed to an in-place upgrade we chose to make a few change on the way; so whilst leaving our DBs on our SQL 2012 cluster
- We moved to a new VM for our AT (to upgrade from Windows 2008R2 to 2012R2)
- Split the SSRS instance off the AT to a separate VM with a new SSAS server (again to move to 2012R2 and to ease management, getting all the reporting bits in one place)
But we do not touch
- Our XAML Build systems leaving them at 2013 as we intend to migrate to vNext build ASAP
- Our Test Controller/Release Management/Lab Environment leaving it at 2013 for now, as we have other projects on the go to update the hardware/cloud solutions underpinning theses.
All went well, no surprises, the running of the upgrade tool took about 1 hour.
The Problem
The only problem we have had was to do with my TFS Alerts DSL Processor, which listens for TFS Alerts and runs custom scripts . I host this on the TFS AT, and I would expect it to set build retention and send emails when a TFS XAML Build quality changes. This did not occur, in the Windows error log I was seeing
12015-08-12 21:04:02.4195 ERROR TFSEventsProcessor.DslScriptService: TF30063: You are not authorized to access [https://tfs.blackmarble.co.uk/tfs/DefaultCollection](https://tfs.blackmarble.co.uk/tfs/DefaultCollection).
After much fiddling, including writing a small command line test client, I confirmed that the issue was specific to the production server. The tool ran fine on other PCs, but on the live server a Window authentication dialog was shown which would not accept any valid credentials
It was not as I had feared a change in the TFS API, in fact there is no reason my 2012 or 2013 API targeted version of the TFS Alert DSL should not be able to talk to a TFS 2015 server as long as the correct version of the TFS API is installed on the machine hosting the DSL.
The Solution
The issue was due to Windows loopback protection. This had been disabled on our old old TFS AT, but not on the new one. As we wanted to avoid changing the global loopback protection setting we set the following via Regedit to allow it for a single CName
**HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlLsaMSV1_0
ValueName - BackConnectionHostNames
Type - multistring
** Data - tfs.blackmarble.co.uk
Once this was done(and without a reboot) my alerts processing work without any problems.