From bfd247e73f3ef339706aee6b750789173a2c08f6 Mon Sep 17 00:00:00 2001 From: Erwin van Hunen <erwin.van.hunen@outlook.com> Date: Thu, 21 Nov 2024 16:46:06 +0100 Subject: [PATCH] Remove of UseWebLogin --- .vscode/tasks.json | 7 +- documentation/Connect-PnPOnline.md | 26 +--- src/Commands/Base/ConnectOnline.cs | 39 ------ src/Commands/Base/PnPConnection.cs | 51 +------- src/Commands/Features/EnableFeature.cs | 2 - src/Commands/Utilities/AzureAuthHelper.cs | 4 +- src/Commands/Utilities/BrowserHelper.cs | 138 +--------------------- 7 files changed, 12 insertions(+), 255 deletions(-) diff --git a/.vscode/tasks.json b/.vscode/tasks.json index 9966bf384..17ce35284 100644 --- a/.vscode/tasks.json +++ b/.vscode/tasks.json @@ -37,7 +37,12 @@ "group": { "kind": "build", "isDefault": true - } + }, + "icon": { + "id": "run", + "color": "terminal.ansiYellow" + }, + }, { "label": "Build with local copy of PnP Framework/PnP Core SDK", diff --git a/documentation/Connect-PnPOnline.md b/documentation/Connect-PnPOnline.md index cf7d7885c..f631b2170 100644 --- a/documentation/Connect-PnPOnline.md +++ b/documentation/Connect-PnPOnline.md @@ -666,29 +666,6 @@ Accept pipeline input: False Accept wildcard characters: False ``` -### -UseWebLogin -Windows only: Connects to SharePoint using legacy cookie based authentication. -Notice this type of authentication is limited in its functionality. -We will for instance not be able to acquire an access token for the Graph, and as a result none of the Graph related cmdlets will work. -Also some of the functionality of the provisioning engine (Get-PnPSiteTemplate, Get-PnPTenantTemplate, Invoke-PnPSiteTemplate, Invoke-PnPTenantTemplate) will not work because of this reason. -The cookies will in general expire within a few days and if you use -UseWebLogin within that time popup window will appear that will disappear immediately, this is expected. -Use -ForceAuthentication to reset the authentication cookies and force a new login. - -```yaml -Type: SwitchParameter -Parameter Sets: Web Login for Multi Factor Authentication -Aliases: - -Required: True -Position: Named -Default value: False -Accept pipeline input: False -Accept wildcard characters: False -``` - -### -RelativeUrl -The site-relative URL of the site you're collecting to. Only applies if you're using -UseWebLogin. - ```yaml Type: String Parameter Sets: Web Login for Multi Factor Authentication @@ -703,7 +680,6 @@ Accept wildcard characters: False ### -Interactive Connects to the Entra ID (Azure AD) using interactive login, allowing you to authenticate using multi-factor authentication. -This parameter has preference over \`-UseWebLogin\`. ```yaml Type: SwitchParameter @@ -718,7 +694,7 @@ Accept wildcard characters: False ``` ### -ForceAuthentication -Will clear the stored authentication information when using -UseWebLogin (Windows Only) or -Interactive (all platforms) and allows you to authenticate again towards a site with different credentials. +Will clear the stored authentication information when using Interactive login (all platforms) and allows you to authenticate again towards a site with different credentials. ```yaml Type: SwitchParameter diff --git a/src/Commands/Base/ConnectOnline.cs b/src/Commands/Base/ConnectOnline.cs index 52e4e132d..5f4bfa727 100644 --- a/src/Commands/Base/ConnectOnline.cs +++ b/src/Commands/Base/ConnectOnline.cs @@ -30,7 +30,6 @@ public class ConnectOnline : BasePSCmdlet private const string ParameterSet_SPOMANAGEMENT = "SPO Management Shell Credentials"; private const string ParameterSet_DEVICELOGIN = "PnP Management Shell / DeviceLogin"; private const string ParameterSet_ACCESSTOKEN = "Access Token"; - private const string ParameterSet_WEBLOGIN = "Web Login for Multi Factor Authentication"; private const string ParameterSet_SYSTEMASSIGNEDMANAGEDIDENTITY = "System Assigned Managed Identity"; private const string ParameterSet_USERASSIGNEDMANAGEDIDENTITYBYCLIENTID = "User Assigned Managed Identity by Client Id"; private const string ParameterSet_USERASSIGNEDMANAGEDIDENTITYBYPRINCIPALID = "User Assigned Managed Identity by Principal Id"; @@ -49,7 +48,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADTHUMBPRINT, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_SPOMANAGEMENT, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_DEVICELOGIN, ValueFromPipeline = true)] - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ACCESSTOKEN, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE, ValueFromPipeline = true)] @@ -67,7 +65,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADTHUMBPRINT, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_SPOMANAGEMENT, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_DEVICELOGIN, ValueFromPipeline = true)] - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ACCESSTOKEN, ValueFromPipeline = true)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE, ValueFromPipeline = true)] @@ -86,7 +83,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = true, Position = 0, ParameterSetName = ParameterSet_SPOMANAGEMENT, ValueFromPipeline = true)] [Parameter(Mandatory = true, Position = 0, ParameterSetName = ParameterSet_ACCESSTOKEN, ValueFromPipeline = true)] [Parameter(Mandatory = true, Position = 0, ParameterSetName = ParameterSet_DEVICELOGIN, ValueFromPipeline = true)] - [Parameter(Mandatory = true, Position = 0, ParameterSetName = ParameterSet_WEBLOGIN, ValueFromPipeline = true)] [Parameter(Mandatory = true, Position = 0, ParameterSetName = ParameterSet_INTERACTIVE, ValueFromPipeline = true)] [Parameter(Mandatory = false, Position = 0, ParameterSetName = ParameterSet_SYSTEMASSIGNEDMANAGEDIDENTITY, ValueFromPipeline = true)] [Parameter(Mandatory = false, Position = 0, ParameterSetName = ParameterSet_USERASSIGNEDMANAGEDIDENTITYBYCLIENTID, ValueFromPipeline = true)] @@ -130,7 +126,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADTHUMBPRINT)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_SPOMANAGEMENT)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_DEVICELOGIN)] - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_OSLOGIN)] @@ -142,7 +137,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADTHUMBPRINT)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_SPOMANAGEMENT)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_DEVICELOGIN)] - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_OSLOGIN)] @@ -220,7 +214,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADCERTIFICATE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_APPONLYAADTHUMBPRINT)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_SPOMANAGEMENT)] - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_OSLOGIN)] @@ -246,13 +239,6 @@ public class ConnectOnline : BasePSCmdlet [Parameter(Mandatory = false, ParameterSetName = ParameterSet_ENVIRONMENTVARIABLE)] public SwitchParameter TransformationOnPrem; - [Parameter(Mandatory = true, ParameterSetName = ParameterSet_WEBLOGIN)] - public SwitchParameter UseWebLogin; - - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN)] - public string RelativeUrl; - - [Parameter(Mandatory = false, ParameterSetName = ParameterSet_WEBLOGIN)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_INTERACTIVE)] [Parameter(Mandatory = false, ParameterSetName = ParameterSet_OSLOGIN)] public SwitchParameter ForceAuthentication; @@ -396,9 +382,6 @@ protected void Connect(ref CancellationToken cancellationToken) case ParameterSet_USERASSIGNEDMANAGEDIDENTITYBYAZURERESOURCEID: newConnection = ConnectManagedIdentity(); break; - case ParameterSet_WEBLOGIN: - newConnection = ConnectWebLogin(); - break; case ParameterSet_INTERACTIVE: newConnection = ConnectInteractive(); break; @@ -788,28 +771,6 @@ private PnPConnection ConnectManagedIdentity() return PnPConnection.CreateWithManagedIdentity(this, Url, TenantAdminUrl, UserAssignedManagedIdentityObjectId, UserAssignedManagedIdentityClientId, UserAssignedManagedIdentityAzureResourceId); } - private PnPConnection ConnectWebLogin() - { - WriteVerbose("Connecting using WebLogin"); - WriteWarning("Consider using -Interactive or -OSLogin instead, which provides better functionality. This will be removed in a future release. See the documentation at https://pnp.github.io/powershell/cmdlets/Connect-PnPOnline.html#interactive-for-multi-factor-authentication"); - - if (Utilities.OperatingSystem.IsWindows()) - { - if (!string.IsNullOrWhiteSpace(RelativeUrl)) - { - return PnPConnection.CreateWithWeblogin(new Uri(Url.ToLower()), TenantAdminUrl, ForceAuthentication, siteRelativeUrl: RelativeUrl); - } - else - { - return PnPConnection.CreateWithWeblogin(new Uri(Url.ToLower()), TenantAdminUrl, ForceAuthentication); - } - } - else - { - throw new PSArgumentException("-UseWebLogin only works when running on Microsoft Windows due to the requirement to show a login window."); - } - } - private PnPConnection ConnectInteractive() { WriteVerbose("Connecting using Interactive login"); diff --git a/src/Commands/Base/PnPConnection.cs b/src/Commands/Base/PnPConnection.cs index ac3f98c26..9381c81a0 100644 --- a/src/Commands/Base/PnPConnection.cs +++ b/src/Commands/Base/PnPConnection.cs @@ -572,57 +572,10 @@ internal static PnPConnection CreateWithCredentials(Cmdlet cmdlet, Uri url, PSCr return spoConnection; } - - /// <summary> - /// Creates a PnPConnection using web login authentication - /// </summary> - /// <param name="url">Url to the SharePoint Online site to connect to</param> - /// <param name="tenantAdminUrl">Url to the SharePoint Online Admin Center site to connect to</param> - /// <param name="clearCookies">Clears cookies before logging in</param> - /// <param name="azureEnvironment">Azure environment to use for authentication (defaults to standard "Production" cloud)</param> - /// <param name="siteRelativeUrl">Relative URL of the page to log in to (defaults to "/_layouts/15/settings.aspx" which is a known performant page)</param> - /// <returns>Instantiated PnPConnection</returns> - internal static PnPConnection CreateWithWeblogin(Uri url, string tenantAdminUrl, bool clearCookies, AzureEnvironment azureEnvironment = AzureEnvironment.Production, string siteRelativeUrl = "/_layouts/15/settings.aspx") - { - if (Utilities.OperatingSystem.IsWindows()) - { - // Log in to a specific page on the tenant - var specificPageUri = new Uri(string.Format("{0}/{1}", url.AbsoluteUri.TrimEnd('/'), siteRelativeUrl.TrimStart('/'))); - var webLoginClientContext = BrowserHelper.GetWebLoginClientContext(url.ToString(), clearCookies, scriptErrorsSuppressed: false, loginRequestUri: specificPageUri); - - // Ensure the login process has been completed - if (webLoginClientContext == null) - { - return null; - } - - var context = PnPClientContext.ConvertFrom(webLoginClientContext); - context.ExecutingWebRequest += (sender, e) => - { - e.WebRequestExecutor.WebRequest.UserAgent = $"NONISV|SharePointPnP|PnPPS/{((AssemblyFileVersionAttribute)Assembly.GetExecutingAssembly().GetCustomAttribute(typeof(AssemblyFileVersionAttribute))).Version} ({System.Environment.OSVersion.VersionString})"; - }; - if (context != null) - { - context.ApplicationName = Resources.ApplicationName; - context.DisableReturnValueCache = true; - var spoConnection = new PnPConnection(context, ConnectionType.O365, null, url.ToString(), tenantAdminUrl, PnPPSVersionTag, InitializationType.InteractiveLogin); - spoConnection.ConnectionMethod = Model.ConnectionMethod.WebLogin; - spoConnection.AzureEnvironment = azureEnvironment; - return spoConnection; - } - - throw new Exception("Error establishing a connection, context is null"); - } - else - { - return null; - } - } - internal static PnPConnection CreateWithInteractiveLogin(Uri uri, string clientId, string tenantAdminUrl, bool launchBrowser, AzureEnvironment azureEnvironment, CancellationTokenSource cancellationTokenSource, bool forceAuthentication, string tenant, bool enableLoginWithWAM) { - var htmlMessageSuccess = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You are signed in now and can close this page.</div></div>"; - var htmlMessageFailure = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>An error occured while signing in: {{{{0}}}}</div></div>"; + var htmlMessageSuccess = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;height:26px;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You are signed in now and can close this page.</div></div>"; + var htmlMessageFailure = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;height:26px;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>An error occured while signing in: {{{{0}}}}</div></div>"; PnP.Framework.AuthenticationManager authManager = null; if (PnPConnection.CachedAuthenticationManager != null && !forceAuthentication) diff --git a/src/Commands/Features/EnableFeature.cs b/src/Commands/Features/EnableFeature.cs index bc5023404..4e58c1e96 100644 --- a/src/Commands/Features/EnableFeature.cs +++ b/src/Commands/Features/EnableFeature.cs @@ -23,13 +23,11 @@ protected override void ExecuteCmdlet() if (Scope == FeatureScope.Web) { pnpContext.Web.LoadAsync(w => w.Features).GetAwaiter().GetResult(); - // pnpContext.Web.EnsureProperties(w => w.Features); pnpContext.Web.Features.EnableAsync(Identity).GetAwaiter().GetResult(); } else { pnpContext.Site.LoadAsync(s => s.Features).GetAwaiter().GetResult(); - // pnpContext.Site.EnsureProperties(s => s.Features); pnpContext.Site.Features.EnableAsync(Identity).GetAwaiter().GetResult(); } } diff --git a/src/Commands/Utilities/AzureAuthHelper.cs b/src/Commands/Utilities/AzureAuthHelper.cs index 413c01201..18ee22781 100644 --- a/src/Commands/Utilities/AzureAuthHelper.cs +++ b/src/Commands/Utilities/AzureAuthHelper.cs @@ -78,8 +78,8 @@ internal static string AuthenticateDeviceLogin(CancellationTokenSource cancellat internal static string AuthenticateInteractive(CancellationTokenSource cancellationTokenSource, CmdletMessageWriter messageWriter, bool noPopup, AzureEnvironment azureEnvironment, string tenantId, string customGraphEndpoint = "") { - var htmlMessageSuccess = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You are signed in now and can close this page.</div></div>"; - var htmlMessageFailure = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>An error occured while signing in: {{{{0}}}}</div></div>"; + var htmlMessageSuccess = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;height:26px;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You are signed in now and can close this page.</div></div>"; + var htmlMessageFailure = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Sign In</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;height:26px;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>An error occured while signing in: {{{{0}}}}</div></div>"; try { using (var authManager = PnP.Framework.AuthenticationManager.CreateWithInteractiveWebBrowserLogin(CLIENTID, (url, port) => diff --git a/src/Commands/Utilities/BrowserHelper.cs b/src/Commands/Utilities/BrowserHelper.cs index bb881b20d..682ef96f2 100644 --- a/src/Commands/Utilities/BrowserHelper.cs +++ b/src/Commands/Utilities/BrowserHelper.cs @@ -23,143 +23,7 @@ internal static class BrowserHelper #pragma warning disable CS0169,CA1823 // not required when compiling for .NET Framework private static ConcurrentDictionary<string, (string requestDigest, DateTime expiresOn)> requestDigestInfos = new ConcurrentDictionary<string, (string requestDigest, DateTime expiresOn)>(); -#pragma warning restore CS0169,CA1823 - - internal static ClientContext GetWebLoginClientContext(string siteUrl, bool clearCookies, bool scriptErrorsSuppressed = true, Uri loginRequestUri = null, AzureEnvironment azureEnvironment = AzureEnvironment.Production) - { -#if Windows - if (OperatingSystem.IsWindows()) - { - var authCookiesContainer = new CookieContainer(); - var siteUri = new Uri(siteUrl); - var cookieUrl = $"{siteUri.Scheme}://{siteUri.Host}"; - var thread = new Thread(() => - { - if (clearCookies) - { - CookieReader.SetCookie(cookieUrl, "FedAuth", "ignore;expires=Mon, 01 Jan 0001 00:00:00 GMT"); - CookieReader.SetCookie(cookieUrl, "rtFa", "ignore;expires=Mon, 01 Jan 0001 00:00:00 GMT"); - CookieReader.SetCookie(cookieUrl, "EdgeAccessCookie", "ignore;expires=Mon, 01 Jan 0001 00:00:00 GMT"); - } - var form = new System.Windows.Forms.Form(); - - var browser = new System.Windows.Forms.WebBrowser - { - ScriptErrorsSuppressed = scriptErrorsSuppressed, - Dock = System.Windows.Forms.DockStyle.Fill - }; - - form.SuspendLayout(); - form.Icon = null; - form.Width = 1024; - form.Height = 768; - form.MinimizeBox = false; - form.MaximizeBox = false; - form.Text = $"Log in to {siteUrl}"; - form.Controls.Add(browser); - form.ResumeLayout(false); - - browser.Navigate(loginRequestUri ?? siteUri); - - browser.Navigated += (sender, args) => - { - if ((loginRequestUri ?? siteUri).Host.Equals(args.Url.Host)) - { - var cookieString = CookieReader.GetCookie(siteUrl).Replace("; ", ",").Replace(";", ","); - - // Get FedAuth and rtFa cookies issued by ADFS when accessing claims aware applications. - // - or get the EdgeAccessCookie issued by the Web Application Proxy (WAP) when accessing non-claims aware applications (Kerberos). - IEnumerable<string> authCookies = null; - if (Regex.IsMatch(cookieString, "FedAuth", RegexOptions.IgnoreCase)) - { - authCookies = cookieString.Split(',').Where(c => c.StartsWith("FedAuth", StringComparison.InvariantCultureIgnoreCase) || c.StartsWith("rtFa", StringComparison.InvariantCultureIgnoreCase)); - } - else if (Regex.IsMatch(cookieString, "EdgeAccessCookie", RegexOptions.IgnoreCase)) - { - authCookies = cookieString.Split(',').Where(c => c.StartsWith("EdgeAccessCookie", StringComparison.InvariantCultureIgnoreCase)); - } - if (authCookies != null) - { - // Set the authentication cookies both on the SharePoint Online Admin as well as on the SharePoint Online domains to allow for APIs on both domains to be used - //var authCookiesString = string.Join(",", authCookies); - //authCookiesContainer.SetCookies(siteUri, authCookiesString); - var extension = Framework.AuthenticationManager.GetSharePointDomainSuffix(azureEnvironment); - var cookieCollection = new CookieCollection(); - foreach (var cookie in authCookies) - { - var cookieName = cookie.Substring(0, cookie.IndexOf("=")); // cannot use split as there might '=' in the value - var cookieValue = cookie.Substring(cookieName.Length + 1); - cookieCollection.Add(new Cookie(cookieName, cookieValue)); - } - authCookiesContainer.Add(new Uri(cookieUrl), cookieCollection); - var adminSiteUri = new Uri(siteUri.Scheme + "://" + siteUri.Authority.Replace($".sharepoint.{extension}", $"-admin.sharepoint.{extension}")); - authCookiesContainer.Add(adminSiteUri, cookieCollection); - form.Close(); - } - } - }; - form.Focus(); - form.ShowDialog(); - browser.Dispose(); - }); - - thread.SetApartmentState(ApartmentState.STA); - thread.Start(); - thread.Join(); - if (authCookiesContainer.Count > 0) - { - var ctx = new ClientContext(siteUrl); - - ctx.DisableReturnValueCache = true; - // We only have to add a request digest when running in dotnet core - var requestDigestInfo = GetRequestDigestAsync(siteUrl, authCookiesContainer).GetAwaiter().GetResult(); - requestDigestInfos.AddOrUpdate(siteUrl, requestDigestInfo, (key, oldValue) => requestDigestInfo); - - //expiresOn = requestDigestInfo.expiresOn; - ctx.ExecutingWebRequest += (sender, e) => - { - e.WebRequestExecutor.WebRequest.CookieContainer = authCookiesContainer; - var hostUrl = $"https://{e.WebRequestExecutor.WebRequest.Host}"; - var requestUri = e.WebRequestExecutor.WebRequest.RequestUri; - if (requestUri.LocalPath.Contains("/sites/") || requestUri.LocalPath.Contains("/teams/")) - { - var managedPath = requestUri.LocalPath.Substring(0, requestUri.LocalPath.IndexOf('/', 2)); - var siteName = requestUri.LocalPath.Substring(managedPath.Length + 1); - siteName = siteName.Substring(0, siteName.IndexOf('/')); - hostUrl = $"{hostUrl}{managedPath}/{siteName}"; - } - if (requestDigestInfos.TryGetValue(hostUrl, out requestDigestInfo)) - { - // We only have to add a request digest when running in dotnet core - if (DateTime.Now > requestDigestInfo.expiresOn) - { - requestDigestInfo = GetRequestDigestAsync(hostUrl, authCookiesContainer).GetAwaiter().GetResult(); - requestDigestInfos.AddOrUpdate(hostUrl, requestDigestInfo, (key, oldValue) => requestDigestInfo); - } - e.WebRequestExecutor.WebRequest.Headers.Add("X-RequestDigest", requestDigestInfo.digestToken); - } - else - { - // admin url maybe? - requestDigestInfo = GetRequestDigestAsync(hostUrl, authCookiesContainer).GetAwaiter().GetResult(); - requestDigestInfos.AddOrUpdate(hostUrl, requestDigestInfo, (key, oldValue) => requestDigestInfo); - e.WebRequestExecutor.WebRequest.Headers.Add("X-RequestDigest", requestDigestInfo.digestToken); - } - }; - - var settings = new PnP.Framework.Utilities.Context.ClientContextSettings(); - settings.Type = PnP.Framework.Utilities.Context.ClientContextType.Cookie; - settings.AuthenticationManager = new PnP.Framework.AuthenticationManager(); - settings.AuthenticationManager.CookieContainer = authCookiesContainer; - settings.SiteUrl = siteUrl; - - ctx.AddContextSettings(settings); - return ctx; - } - } -#endif - return null; - } +#pragma warning restore CS0169,CA1823 internal enum UrlMatchType {