diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthState.cs b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthState.cs similarity index 100% rename from XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthState.cs rename to XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthState.cs diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthorizationService.cs b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthorizationService.cs similarity index 100% rename from XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthorizationService.cs rename to XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthorizationService.cs diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthorizationServiceConfiguration.cs b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthorizationServiceConfiguration.cs similarity index 100% rename from XPlat/OpenId/Android/source/OpenId.AppAuth.Android/AuthorizationServiceConfiguration.cs rename to XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Additions/AuthorizationServiceConfiguration.cs diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/OpenId.AppAuth.Android.csproj b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/OpenId.AppAuth.Android.csproj index 60caba5936..610ff7f808 100644 --- a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/OpenId.AppAuth.Android.csproj +++ b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/OpenId.AppAuth.Android.csproj @@ -1,77 +1,55 @@ - - - - XAJavaInterop1 - v4.4 - - - Debug - AnyCPU - {DDD84AB4-80CE-4C3E-A6D0-8284A881A7A8} - {10368E6C-D01B-4462-8E8B-01FC667A7035};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} - Library - OpenId.AppAuth - OpenId.AppAuth.Android - Resources - Assets - false - class-parse - - - true - full - false - bin\Debug - DEBUG; - prompt - 4 - None - false - - - true - pdbonly - true - bin\Release - prompt - 4 - true - false - false - - - - - - - - ..\packages\Xamarin.Android.Support.v4.23.3.0\lib\MonoAndroid403\Xamarin.Android.Support.v4.dll - - - ..\packages\Xamarin.Android.Support.CustomTabs.23.3.0\lib\MonoAndroid403\Xamarin.Android.Support.CustomTabs.dll - - - - - - - - - - - - - - - - Native\appauth.aar - - - - - - - - - + + + + MonoAndroid9.0 + true + OpenId.AppAuth.Android + Resources + Assets + False + True + Resources\Resource.designer.cs + OpenId.AppAuth + class-parse + XAJavaInterop1 + + + + Xamarin.OpenId.AppAuth.Android + OpenID AppAuth (OAuth Client) for Android + + AppAuth for Android is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. + It strives to directly map the requests and responses of those specifications, while following the idiomatic style of the implementation language. + In addition to mapping the raw protocol flows, convenience methods are available to assist with common tasks like performing an action with fresh tokens. + + Microsoft + Microsoft + © Microsoft Corporation. All rights reserved. + https://raw.githubusercontent.com/xamarin/XamarinComponents/master/XPlat/OpenId/images/logo_128x128.png + https://go.microsoft.com/fwlink/?linkid=865038 + https://go.microsoft.com/fwlink/?linkid=864980 + true + 0.9.0 + + + + + + + + + appauth.aar + + + + + + + + + + + + + \ No newline at end of file diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Properties/AssemblyInfo.cs b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Properties/AssemblyInfo.cs index 21a0651230..02a9501470 100644 --- a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Properties/AssemblyInfo.cs +++ b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/Properties/AssemblyInfo.cs @@ -1,28 +1 @@ -using System.Reflection; -using System.Runtime.CompilerServices; -using Android.App; - -// Information about this assembly is defined by the following attributes. -// Change them to the values specific to your project. - -[assembly: AssemblyTitle("OpenId.AppAuth.Android")] -[assembly: AssemblyDescription("")] -[assembly: AssemblyConfiguration("")] -[assembly: AssemblyCompany("")] -[assembly: AssemblyProduct("")] -[assembly: AssemblyCopyright("(c) Matthew Leibowitz")] -[assembly: AssemblyTrademark("")] -[assembly: AssemblyCulture("")] - -// The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}". -// The form "{Major}.{Minor}.*" will automatically update the build and revision, -// and "{Major}.{Minor}.{Build}.*" will update just the revision. - -[assembly: AssemblyVersion("1.0.0.0")] -[assembly: AssemblyFileVersion("0.7.0.0")] - -// The following attributes are used to specify the signing key for the assembly, -// if desired. See the Mono documentation for more information about signing. - -//[assembly: AssemblyDelaySign(false)] -//[assembly: AssemblyKeyFile("")] +[assembly: Android.LinkerSafe] \ No newline at end of file diff --git a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/packages.config b/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/packages.config deleted file mode 100644 index 553131600e..0000000000 --- a/XPlat/OpenId/Android/source/OpenId.AppAuth.Android/packages.config +++ /dev/null @@ -1,5 +0,0 @@ - - - - - \ No newline at end of file diff --git a/XPlat/OpenId/build.cake b/XPlat/OpenId/build.cake index 9fe6b968a5..62270b35a9 100644 --- a/XPlat/OpenId/build.cake +++ b/XPlat/OpenId/build.cake @@ -1,10 +1,11 @@ - -#load "../../common.cake" +#addin nuget:?package=Cake.XCode&version=4.2.0 +#addin nuget:?package=Cake.Xamarin.Build&version=4.1.2 +#addin nuget:?package=Cake.FileHelpers&version=3.2.1 var TARGET = Argument ("t", Argument ("target", "ci")); -var ANDROID_VERSION = "0.7.0"; -var ANDROID_NUGET_VERSION = "0.7.0"; +var ANDROID_VERSION = "0.9.0"; +var ANDROID_NUGET_VERSION = "0.9.0"; var IOS_VERSION = "0.92.0"; var IOS_NUGET_VERSION = "0.92.0"; @@ -18,108 +19,191 @@ var PODFILE = new List { "end", }; -var buildSpec = new BuildSpec { - Libs = new [] { - new DefaultSolutionBuilder { - SolutionPath = "./iOS/source/OpenId.AppAuth.iOS.sln", - Configuration="Release", - OutputFiles = new [] { - new OutputFileCopy { - FromFile = "./iOS/source/OpenId.AppAuth.iOS/bin/Release/OpenId.AppAuth.iOS.dll", - } - } - }, - new DefaultSolutionBuilder { - SolutionPath = "./Android/source/OpenId.AppAuth.Android.sln", - OutputFiles = new [] { - new OutputFileCopy { - FromFile = "./Android/source/OpenId.AppAuth.Android/bin/Release/OpenId.AppAuth.Android.dll", - } - } - } - }, - - NuGets = new [] { - new NuGetInfo { NuSpec = "./nuget/OpenId.AppAuth.Android.nuspec", Version = ANDROID_NUGET_VERSION }, - new NuGetInfo { NuSpec = "./nuget/OpenId.AppAuth.iOS.nuspec", Version = IOS_NUGET_VERSION }, - }, - - Samples = new [] { - new IOSSolutionBuilder { SolutionPath = "./iOS/samples/OpenIdAuthSampleiOS.sln", Configuration = "Release", Platform="iPhone" }, - new DefaultSolutionBuilder { SolutionPath = "./Android/samples/OpenIdAuthSampleAndroid.sln" } - }, - - Components = new [] { - new Component { ManifestDirectory = "./component" } - } -}; - -Task ("externals-android") - .WithCriteria (!FileExists ("./externals/android/appauth.aar")) - .Does (() => +Task("externals-ios") + .WithCriteria(IsRunningOnUnix()) + .WithCriteria(!FileExists("./externals/ios/libAppAuth.a")) + .Does(() => { - EnsureDirectoryExists ("./externals/android"); - - DownloadFile (AAR_URL, "./externals/android/appauth.aar"); -}); -Task ("externals-ios") - .WithCriteria (!FileExists ("./externals/ios/libAppAuth.a")) - .Does (() => -{ - if (CocoaPodVersion (new CocoaPodSettings ()) < new System.Version (1, 0)) - PODFILE.RemoveAt (1); - EnsureDirectoryExists ("./externals/ios"); - FileWriteLines ("./externals/ios/Podfile", PODFILE.ToArray ()); + FileWriteLines("./externals/ios/Podfile", PODFILE.ToArray()); + CocoaPodRepoUpdate(); + CocoaPodInstall("./externals/ios", new CocoaPodInstallSettings { NoIntegrate = true }); - CocoaPodRepoUpdate (); - - CocoaPodInstall ("./externals/ios", new CocoaPodInstallSettings { NoIntegrate = true }); - - XCodeBuild (new XCodeBuildSettings { + XCodeBuild(new XCodeBuildSettings { Project = "./externals/ios/Pods/Pods.xcodeproj", Target = "AppAuth", Sdk = "iphoneos", Configuration = "Release", }); - XCodeBuild (new XCodeBuildSettings { + XCodeBuild(new XCodeBuildSettings { Project = "./externals/ios/Pods/Pods.xcodeproj", Target = "AppAuth", Sdk = "iphonesimulator", Configuration = "Release", }); - /* - fatal error: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/lipo: - externals/ios/build/Release-iphoneos/AppAuth/libAppAuth.a - and - externals/ios/build/Release-iphonesimulator/AppAuth/libAppAuth.a - have the same architectures (arm64) and can't be in the same fat output file - */ - /* - RunLipoCreate ("./", - "./externals/ios/libAppAuth.a", - "./externals/ios/build/Release-iphoneos/AppAuth/libAppAuth.a", - "./externals/ios/build/Release-iphonesimulator/AppAuth/libAppAuth.a"); - */ - CopyFile("./externals/ios/build/Release-iphonesimulator/AppAuth/libAppAuth.a", "./externals/ios/libAppAuth.a"); + // RunLipoCreate("./", + // "./externals/ios/libAppAuth.a", + // "./externals/ios/build/Release-iphoneos/AppAuth/libAppAuth.a", + // "./externals/ios/build/Release-iphonesimulator/AppAuth/libAppAuth.a"); + + CopyFile("./externals/ios/build/Release-iphonesimulator/AppAuth/libAppAuth.a", "./externals/ios/libAppAuth.a"); + + XmlPoke("./iOS/source/OpenId.AppAuth.iOS/OpenId.AppAuth.iOS.csproj", "/Project/PropertyGroup/PackageVersion", IOS_NUGET_VERSION); +}); + +Task("externals-android") + .WithCriteria(!FileExists("./externals/android/appauth.aar")) + .Does(() => +{ + EnsureDirectoryExists("./externals/android"); + + DownloadFile(AAR_URL, "./externals/android/appauth.aar"); + + XmlPoke("./Android/source/OpenId.AppAuth.Android/OpenId.AppAuth.Android.csproj", "/Project/PropertyGroup/PackageVersion", ANDROID_NUGET_VERSION); +}); + +Task("libs-ios") + .WithCriteria(IsRunningOnUnix()) + .IsDependentOn("externals-ios") + .Does(() => +{ + MSBuild("./iOS/source/OpenId.AppAuth.iOS.sln", c => { + c.Configuration = "Release"; + c.Restore = true; + c.Targets.Clear(); + c.Targets.Add("Rebuild"); + c.Properties.Add("DesignTimeBuild", new [] { "false" }); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/libs-ios.binlog" + }; + }); +}); + +Task("libs-android") + .IsDependentOn("externals-android") + .Does(() => +{ + MSBuild("./Android/source/OpenId.AppAuth.Android.sln", c => { + c.Configuration = "Release"; + c.Restore = true; + c.Targets.Clear(); + c.Targets.Add("Rebuild"); + c.Properties.Add("DesignTimeBuild", new [] { "false" }); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/libs-android.binlog" + }; + }); }); -Task ("externals") - .IsDependentOn ("externals-android") - .IsDependentOn ("externals-ios"); -Task ("clean").IsDependentOn ("clean-base").Does (() => +Task("nuget-ios") + .WithCriteria(IsRunningOnUnix()) + .IsDependentOn("libs-ios") + .Does(() => { - if (DirectoryExists ("./externals")) - DeleteDirectory ("./externals", true); + MSBuild("./iOS/source/OpenId.AppAuth.iOS.sln", c => { + c.Configuration = "Release"; + c.Targets.Clear(); + c.Targets.Add("Pack"); + c.Properties.Add("PackageOutputPath", new [] { MakeAbsolute(new FilePath("./output")).FullPath }); + c.Properties.Add("PackageRequireLicenseAcceptance", new [] { "true" }); + c.Properties.Add("DesignTimeBuild", new [] { "false" }); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/nuget-ios.binlog" + }; + }); +}); + +Task("nuget-android") + .IsDependentOn("libs-android") + .Does(() => +{ + MSBuild("./Android/source/OpenId.AppAuth.Android.sln", c => { + c.Configuration = "Release"; + c.Targets.Clear(); + c.Targets.Add("Pack"); + c.Properties.Add("PackageOutputPath", new [] { MakeAbsolute(new FilePath("./output")).FullPath }); + c.Properties.Add("PackageRequireLicenseAcceptance", new [] { "true" }); + c.Properties.Add("DesignTimeBuild", new [] { "false" }); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/nuget-android.binlog" + }; + }); +}); + +Task("samples-ios") + .WithCriteria(IsRunningOnUnix()) + .IsDependentOn("nuget-ios") + .Does(() => +{ + MSBuild("./iOS/samples/OpenIdAuthSampleiOS.sln", c => { + c.Configuration = "Release"; + c.Restore = true; + c.Targets.Clear(); + c.Targets.Add("Build"); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/samples-ios.binlog" + }; + }); +}); + +Task("samples-android") + .IsDependentOn("nuget-android") + .Does(() => +{ + MSBuild("./Android/samples/OpenIdAuthSampleAndroid.sln", c => { + c.Configuration = "Release"; + c.Restore = true; + c.Targets.Clear(); + c.Targets.Add("Build"); + c.BinaryLogger = new MSBuildBinaryLogSettings { + Enabled = true, + FileName = "./output/samples-android.binlog" + }; + }); +}); + +Task("externals") + .IsDependentOn("externals-ios") + .IsDependentOn("externals-android"); + +Task("libs") + .IsDependentOn("libs-ios") + .IsDependentOn("libs-android"); + +Task("nuget") + .IsDependentOn("nuget-ios") + .IsDependentOn("nuget-android"); + +Task("samples") + .IsDependentOn("samples-ios") + .IsDependentOn("samples-android"); + +Task("clean") + .Does(() => +{ + if(DirectoryExists ("./externals/android")) + DeleteDirectory ("./externals/android", new DeleteDirectorySettings { + Recursive = true, + Force = true + }); + + if(DirectoryExists ("./externals/ios")) + DeleteDirectory ("./externals/ios", new DeleteDirectorySettings { + Recursive = true, + Force = true + }); }); Task("ci") .IsDependentOn("nuget"); -SetupXamarinBuildTasks (buildSpec, Tasks, Task); - RunTarget (TARGET); diff --git a/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/OpenId.AppAuth.iOS.csproj b/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/OpenId.AppAuth.iOS.csproj index 0be85799d2..e3142a68e7 100644 --- a/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/OpenId.AppAuth.iOS.csproj +++ b/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/OpenId.AppAuth.iOS.csproj @@ -1,53 +1,55 @@ - - - - Debug - AnyCPU - {CEE5309A-3522-4BAC-A305-9127C323420E} - {8FFB629D-F513-41CE-95D2-7ECE97B6EEEC};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} - Library - OpenId.AppAuth - OpenId.AppAuth.iOS - Resources - - - true - full - false - bin\Debug - DEBUG; - prompt - 4 - true - - - true - bin\Release - - prompt - 4 - true - - - - - - - - - - - - - - - - - - Static - True - SafariServices - - - + + + Xamarin.iOS10 + true + OpenId.AppAuth + OpenId.AppAuth.iOS + 1.0.0.0 + Resources + true + + + + Xamarin.OpenId.AppAuth.iOS + OpenID AppAuth (OAuth Client) for iOS + + AppAuth for iOS is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. + It strives to directly map the requests and responses of those specifications, while following the idiomatic style of the implementation language. + In addition to mapping the raw protocol flows, convenience methods are available to assist with common tasks like performing an action with fresh tokens. + + Microsoft + Microsoft + © Microsoft Corporation. All rights reserved. + https://raw.githubusercontent.com/xamarin/XamarinComponents/master/XPlat/OpenId/images/logo_128x128.png + https://go.microsoft.com/fwlink/?linkid=864982 + https://go.microsoft.com/fwlink/?linkid=864984 + true + 0.92.0 + + + + + + + + + Static + True + SafariServices + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/Properties/AssemblyInfo.cs b/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/Properties/AssemblyInfo.cs deleted file mode 100644 index f729158201..0000000000 --- a/XPlat/OpenId/iOS/source/OpenId.AppAuth.iOS/Properties/AssemblyInfo.cs +++ /dev/null @@ -1,35 +0,0 @@ -using System.Reflection; -using System.Runtime.CompilerServices; - -using Foundation; - -// This attribute allows you to mark your assemblies as “safe to link”. -// When the attribute is present, the linker—if enabled—will process the assembly -// even if you’re using the “Link SDK assemblies only” option, which is the default for device builds. - -[assembly: LinkerSafe] - -// Information about this assembly is defined by the following attributes. -// Change them to the values specific to your project. - -[assembly: AssemblyTitle("OpenId.AppAuth.iOS")] -[assembly: AssemblyDescription("")] -[assembly: AssemblyConfiguration("")] -[assembly: AssemblyCompany("")] -[assembly: AssemblyProduct("")] -[assembly: AssemblyCopyright("(c) Matthew Leibowitz")] -[assembly: AssemblyTrademark("")] -[assembly: AssemblyCulture("")] - -// The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}". -// The form "{Major}.{Minor}.*" will automatically update the build and revision, -// and "{Major}.{Minor}.{Build}.*" will update just the revision. - -[assembly: AssemblyVersion("1.0.0.0")] -[assembly: AssemblyFileVersion("0.92.0.0")] - -// The following attributes are used to specify the signing key for the assembly, -// if desired. See the Mono documentation for more information about signing. - -//[assembly: AssemblyDelaySign(false)] -//[assembly: AssemblyKeyFile("")] diff --git a/XPlat/OpenId/nuget/OpenId.AppAuth.Android.nuspec b/XPlat/OpenId/nuget/OpenId.AppAuth.Android.nuspec deleted file mode 100644 index 1d2b342743..0000000000 --- a/XPlat/OpenId/nuget/OpenId.AppAuth.Android.nuspec +++ /dev/null @@ -1,24 +0,0 @@ - - - - Xamarin.OpenId.AppAuth.Android - OpenID AppAuth (OAuth Client) for Android - $version$ - Microsoft - Microsoft - true - AppAuth for Android is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. - AppAuth for Android is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. -It strives to directly map the requests and responses of those specifications, while following the idiomatic style of the implementation language. -In addition to mapping the raw protocol flows, convenience methods are available to assist with common tasks like performing an action with fresh tokens. - - © Microsoft Corporation. All rights reserved. - https://go.microsoft.com/fwlink/?linkid=864980 - https://github.com/xamarin/XamarinComponents/raw/master/XPlat/OpenId/images/logo_1024x1024.png - https://go.microsoft.com/fwlink/?linkid=865038 - - - - - - \ No newline at end of file diff --git a/XPlat/OpenId/nuget/OpenId.AppAuth.iOS.nuspec b/XPlat/OpenId/nuget/OpenId.AppAuth.iOS.nuspec deleted file mode 100644 index eda5d74f08..0000000000 --- a/XPlat/OpenId/nuget/OpenId.AppAuth.iOS.nuspec +++ /dev/null @@ -1,24 +0,0 @@ - - - - Xamarin.OpenId.AppAuth.iOS - OpenID AppAuth (OAuth Client) for iOS - $version$ - Microsoft - Microsoft - true - AppAuth for iOS is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. - AppAuth for iOS is a client SDK for communicating with OAuth 2.0 and OpenID Connect providers. -It strives to directly map the requests and responses of those specifications, while following the idiomatic style of the implementation language. -In addition to mapping the raw protocol flows, convenience methods are available to assist with common tasks like performing an action with fresh tokens. - - © Microsoft Corporation. All rights reserved. - https://go.microsoft.com/fwlink/?linkid=864984 - https://github.com/xamarin/XamarinComponents/raw/master/XPlat/OpenId/images/logo_1024x1024.png - https://go.microsoft.com/fwlink/?linkid=864982 - - - - - - \ No newline at end of file diff --git a/manifest.yaml b/manifest.yaml index 49443d05d2..5c15887645 100644 --- a/manifest.yaml +++ b/manifest.yaml @@ -697,11 +697,10 @@ BuildScript: ./XPlat/GoogleVR/iOS/build.cake TriggerPaths: [ XPlat/GoogleVR/iOS ] MacBuildTargets: [ nuget, samples ] -# Obsolete -# - Name: OpenId -# BuildScript: ./XPlat/OpenId/build.cake -# TriggerPaths: [ XPlat/OpenId ] -# MacBuildTargets: [ nuget, samples ] +- Name: OpenId + BuildScript: ./XPlat/OpenId/build.cake + TriggerPaths: [ XPlat/OpenId ] + MacBuildTargets: [ nuget, samples ] - Name: AzureMessaging BuildScript: ./XPlat/AzureMessaging/build.cake TriggerPaths: [ XPlat/AzureMessaging ]