Web Services Infrastructure and how to Create an Internal Proxy

I am NOT an expert in how to setup a secure network and I do NOT know a lot about firewalls, DMZ setup and all of these things, but I have seen a lot in my 25 years of working with computers and the following (absolutely non-exhaustive) gives a good picture of a common network situation of companies, who wants to interact with customers and partners through Web Applications and/or Web Services.

image

DMZ can be at the customer site or with a hosting center, and yes – there probably is a firewalls between DMZ and Internet.

As you can imagine, this post is NOT about how to setup firewalls and other network infrastructure elements – it is about the software. Let me explain the different machines in this setup (note that there are many different solutions – this is just one possible setup).

  1. This machine is running a Sharepoint server with a time/entry application, document repository linked together with items in the NAV database and KPI’s from NAV using BDC integration from Bugsy’s blog. This machine would typically connect directly to NAV (due to authentication), but can go through the Internal Proxy for some scenarios. There are a lot of posts on my blog and other places on how to connect to NAV Web Services from an internal application like this.
  2. This machine is the internal proxy. It exposes a high level contract for machines in the DMZ on port 8123. The firewall is open for the 2 specific machines in the DMZ on this specific port to this specific machine. This Web Service listener is open for Anonymous access and the machine connects to NAV with a hardcoded user/password.
  3. This is the NAV Service Tier – database could be on the same machine. The Web Service listener listens on port 7047 and uses Windows Authentication.
  4. This machine is a Web Server hosting the company web site and a web shop for selling our products. The authentication between customer and the Web Application is custom and the customer does not have anything to do with the Active Directory in the Intranet.
  5. This machine is a Web Services listener, allowing our top customers to buy our products directly though a module in their own NAV application. The authentication between customer and the Web Service is custom and the customer does not have anything to do with the Active Directory in the Intranet.

In this post – I will concentrate on machine number 2.

My Internal Proxy

I have chosen to create this proxy service as a Windows Service, hosting a WCF Service. The other choice would be to create an asp.net web service application hosted by IIS – which probably is easier to find information about on the internet, but that is just because it has been around for a longer period of time and because the general assumption is that it is complicated.

One advantage you have by making a Windows Service is, that you can have that Windows Service running as a domain account with Access to NAV and this way, you don’t have to have username and password in clear text in your web service host.

Another advantage is that it is lightweight and there really isn’t any reason for having IIS loaded on a computer in the intranet unless it is running your local intranet web site.

I have chosen that the contract I want to implement is to get the Customer name of a specific customer and there really isn’t a lot of code in that.

Writing a WCF service is complicated!

A WCF Service Contract and the service itself is only these few lines of code:

[ServiceContract]
interface IMyInternalProxy
{
[OperationContract]
string GetCustomerName(string No);
}

[ServiceBehavior(InstanceContextMode=InstanceContextMode.Single)]
class MyInternalProxy : IMyInternalProxy
{
#region IMyInternalProxy Members

    public string GetCustomerName(string No)
{
Customer_Service service = new Customer_Service();
service.Credentials = CredentialCache.DefaultNetworkCredentials;
Customer customer = service.Read(No);
return customer.Name;
}

    #endregion
}

as you can see I chose to connect to NAV using a Web Reference. I could of course have done this using Service Reference as well as described in this post.

That’s not complicated!

No and actually by hosting the WCF Service in a Windows service you just need to create the ServiceHost and perform the open and close in the proper event handlers like:

public partial class Service1 : ServiceBase
{
string URL = Uri.UriSchemeHttp + Uri.SchemeDelimiter + Environment.MachineName + ":8123";
ServiceHost host;

    public Service1()
{
InitializeComponent();

        host = new ServiceHost(new MyInternalProxy(), new Uri(URL));
host.AddServiceEndpoint(typeof(IMyInternalProxy), new BasicHttpBinding(), "");
ServiceMetadataBehavior smb = new ServiceMetadataBehavior();
smb.HttpGetEnabled = true;
smb.HttpGetUrl = new Uri(URL);
host.Description.Behaviors.Add(smb);
}

    protected override void OnStart(string[] args)
{
if (host.State != CommunicationState.Opened && host.State != CommunicationState.Opening)
host.Open();
}

    protected override void OnStop()
{
if (host.State != CommunicationState.Closed && host.State != CommunicationState.Closing)
host.Close();
}
}

Well that’s not complicated either – but something must be?

No, it’s easy – if it fits, it ships!

(Ok, bad joke, People who hasn’t seen USPS commercials might be a bit confused now:-))

But what about installing, uninstalling etc. etc.

Ok admitted, there is a bit more to writing a Windows Service hosting a WCF service than just writing two classes – but that is the case with IIS hosted Web Services as well. To describe all these things is actually complicated – so instead, I have created a 16 minute video on how to create MyInternalProxy from scratch, install it and create a very small client application for the proxy – and you can download the video here:

https://www.freddy.dk/MyInternalProxy.wmv

I tried uploading to Youtube, but they have a max. of 10 minutes:-(

And…, you can download the solution from the video here.

Hope this is helpful

Good luck

Freddy Kristiansen PM Architect
Microsoft Dynamics NAV

Comments

  • Anonymous
    November 03, 2010
    Hello, how can i access the internal proxy by using javascript? Thanks!

  • Anonymous
    November 08, 2010
    The comment has been removed

  • Anonymous
    November 29, 2010
    A proxy is always custom development - and the API you want to expose to the user of your proxy might not be the same as everything exposed by NAV. You can make a generic proxy - but I am not sure you want to do that. My next couple of posts will be about how to get access to NAV data (and write NAV data) from applications running in the cloud (or at your customers)

  • Anonymous
    February 23, 2011
    Hello! Thanks in advance for this tutorial. I found this because of searching a possibility to connect my WP7 to a Dynamics NAV R2 Webservice (lets take Customer Card). I am running in trouble when I try this. "Not found" is the exception error. Are you able to connect your WP7 app to a NAV WS without such a Proxy?? I can tell you, that I am not able to.

  • Anonymous
    February 05, 2012
    Hello! Thanks for grate post. I'm interested in external web service on machine number 5. I red your posts about WS and Cloud, but I'm looking to create solution without Azure. Could you please point some directions where to look that could help me. Thanks.

  • Anonymous
    May 09, 2012
    Hi Freddy, a lot of respect for the whole lot of publications you made on the topic. 'been immensely helpful! I just wanted to try and ask a question, that I prefer to warn, is quite tough! We have several architectures in production, with NAV Web Services activated and we pretty well manage the transition to our own private/hybrid cloud/multi-tenant env. The thing is, we currently deal with problems we cannot yet solve, having Nav's Windows Service WCF Web Services and IIS 6-7-7.5 on a same Windows OS instance (WSS and NAV WS on the same "machine"). It seems like IIS pre-empts each and every http request that is made by clients, forbidding the Windows Service to act in its own name an setup (SPN and delegation is an horrible misleading thing here!). We have done Kerb setup, netsh url setup, no port sharing, but no luck until now... Would you have any idea on how we can make the cohabitation possible in this particular case? Many thanks in advance for your ideas, Denis

  • Anonymous
    September 12, 2012
    I think it is too late because this thread has very old posts only but yes, we developed a generic proxy for NAV including some extra features (auto redirecting to different companies based on different configurations, workload balancing etc.). But I`ve met this thread just now...