-
Notifications
You must be signed in to change notification settings - Fork 214
ADAL .NET Build & Run
This is documentation about how to build an run the project. I wrote this because I had a lot of problems building the project (it is not the obvious build an run in visual studio) and I would figure that somebody else would have the same problems.
Before you build and run you will need a set of SDK's and tools installed on your box. You can see the pre-requisites here
Please click here to view the the Visual Studio 2017 required components.
Important: At this point in time all tools has to be run as Admin.
To build for targets for Windows 8.1 for the following target platforms ARM, x86 and x64 you'll need VS2015 (latest update). See also prerequisites for additional details.
- Open the VS2015 Developer Command Prompt and navigate to the folder where you have the GitHub project.
- Start the build using the
buildVS2015.cmd
script.
To build targets for Xamarin Android (MonoAnroid7), Xamarin iOS (Xamarin.iOS10), Windows (net45), UWP (win81, netstandard1.1;netstandard1.3) you will need VS2017 (latest update). See also prerequisites for additional details.
- Open the VS2017 Developer Command Prompt and navigate to the folder where you have the GitHub project.
- Restore packages using the
restore.cmd
script. - Build using the
buildVS2017.cmd
script. (This only builds the core components and the unit tests) - To build everything run the
buildAll.cmd
script (This script also does the strongnaming required to run and build the unit tests and the sample apps) - You can run the
strongname.cmd
to ensure you have strong naming disabled for your dev box. This is required to run tests and sample apps with bits that are not signed.
- Note:
build.cmd
callsbuildVS2017.cmd
.
All steps are to be performed from the Visual Studio 2017 Developer Prompt, unless stated otherwise.
- NuGet restore packages for Combined.NoWinRT.sln
msbuild /t:restore Combined.NoWinRT.sln
- NuGet restore packages for adal\ADAL.NET.VS2015.sln
- Build Combined.NoWinRT.sln
msbuild Combined.NoWinRT.sln /p:configuration=Release
- (from the VS 2015 developer prompt) msbuild adal\ADAL.NET.VS2015.sln /p:configuration=Release
Troubleshooting: if you get messages related to Designer.cs not present, try to build in VS 2017 as well
- First, build ADAL following the instructions above
- NuGet restore packages for msal\MSAL.sln
- msbuild msal\MSAL.sln
Packaging MSAL is done manually, by laying out the assemblies and the nuspec file. This is because the new way of packaging (msbuild /t:pack) does not yet support the scenario of packaging 2 assemblies (see https://github.com/NuGet/Home/issues/3891)
- Make sure you have build MSAL in release mode. When building, you can pass extra params that control assembly versioning: /p:$(CoreSemVer) /p:$(MsalClientSemVer)
- Layout the assemblies and the nuspec file
msbuild msal/src/Microsoft.Identity.Client/Microsoft.Identity.Client.csproj /t:LayoutNuGet /p:PackagePdb=true /p:NugetPackageRootFolder=<layout dir>
- Package using nuget.exe (the tool has to be downloaded)
nuget pack <layout dir> -Properties Configuration=Release;version=<package version> -Symbols
- First open the Developer command prompt as administrator
- Change the branch to adalv3/dev
- Run the following command:
msbuild Adal.net.nowinrt.sln /t:restore /p:configuration=release
- this will restore the nuget packages needed for the project. - Now run
msbuild Adal.net.nowinrt.sln /t:build /p:configuration=release
- this will build the project. - Then you can build it inside visual studio no problems.
I got all the info from the following issue.
When you try to run the project, you will get the following exception: System.IO.FileLoadException: 'Could not load file or assembly 'Microsoft.IdentityModel.Clients.ActiveDirectory, Version=0.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35' or one of its dependencies. Strong name validation failed. (Exception from HRESULT: 0x8013141A)'
To fix this follow these steps
- First open the Developer command prompt as administrator
- Go to the bin/debug folder of the selected test project.
- Run the following command to fix this dll issue: sn.exe -Vr Microsoft.IdentityModel.Clients.ActiveDirectory.dll
- Now you can run the project!
I got all the info from the following issue.
- Home
- Why use ADAL.NET?
- Register your app with AAD
- AuthenticationContext
- Acquiring Tokens
- Calling a protected API
- Acquiring a token interactively
- Acquiring tokens silently
- Using Device Code Flow
- Using Embedded Webview and System Browser in ADAL.NET and MSAL.NET
- With no user
- In the name of a user
- on behalf of (Service to service calls)
- by authorization code (Web Apps)
- Use async controller actions
- Exception types
- using Broker on iOS and Android
- Logging
- Token Cache serialization
- User management
- Using ADAL with a proxy
- Authentication context in multi-tenant scenarios
- Troubleshooting MFA in a WebApp or Web API
- Provide your own HttpClient
- iOS Keychain Access