Domain Authentication from .NET Client over VPN

Posted by Holy Christ on Stack Overflow See other posts from Stack Overflow or by Holy Christ
Published on 2010-04-28T14:35:32Z Indexed on 2010/04/28 16:13 UTC
Read the original article Hit count: 221

Filed under:
|
|
|
|

I am writing a ClickOnce WPF app that will sometimes be used over VPN. The app uses resources available only to domain authenticated users. Some of the things include accessing SSRS Reports, accessing LDAP to lookup user information, hitting web services, etc.

When a user logs in from a machine that is not authenticated on the domain, I need to somehow get his credentials, authenticate him on the domain, and store his credentials.

  1. What is the recommended approach for authenticating domain users over VPN?
  2. How can I securely store the credentials?

I've found several articles but, not much posted recently and a lot of the solutions seem kinda hacky, or aren't very secure (ie - storing strings clear text in memory).

It would be cool if I could use the ActiveDicrtoryMembershipProvider, but that seems to be geared for use in web apps.

EDIT: The above is kind of a workaround. The user must enter their domain credentials to authenticate on the VPN. It would be ideal to access the credentials the user has already entered to login to the VPN instead of the WindowsIdentity.GetCurrent() (which returns the user logged into the computer). Any ideas on how that could work? We use Juniper Networks to connect to the VPN.

Thanks!

© Stack Overflow or respective owner

Related posts about wpf

Related posts about c#