public static BrowseInstance ( [ instance, [ owner, [ virtualPath, bool isFrontEnd, [ browser = null, [ parameters = null ) : void | ||
instance | [ | |
owner | [ | |
virtualPath | [ | |
isFrontEnd | bool | |
browser | [ | |
parameters | [ | |
return | void |
internal static void LoginAsAdmin([NotNull] Instance instance, [NotNull] Window owner, [CanBeNull] string pageUrl = null, [CanBeNull] string browser = null, [CanBeNull] string[] parameters = null) { Assert.ArgumentNotNull(instance, "instance"); Assert.ArgumentNotNull(owner, "owner"); if (!InstanceHelperEx.PreheatInstance(instance, owner, true)) { return; } // Generating unique url to authenticate user var url = CoreInstanceAuth.GenerateAuthUrl(); var destFileName = CoreInstanceAuth.CreateAuthFile(instance, url); // Schedule deletion of the file var async = new Action(() => DeleteFile(destFileName)); async.BeginInvoke(null, null); var userName = CoreAppSettings.AppLoginAsAdminUserName.Value; var isFrontEnd = false; var clipboard = pageUrl == "$(clipboard)"; if (clipboard) { pageUrl = string.Empty; } if (string.IsNullOrEmpty(pageUrl)) { var value = CoreAppSettings.AppLoginAsAdminPageUrl.Value; if (!string.IsNullOrEmpty(value) && !value.EqualsIgnoreCase("/sitecore") && !value.EqualsIgnoreCase("sitecore")) { pageUrl = value; if (!value.StartsWith("/sitecore/")) { isFrontEnd = true; } } } var querystring = (string.IsNullOrEmpty(pageUrl) ? string.Empty : "&page=" + pageUrl) + (string.IsNullOrEmpty(userName) || userName.EqualsIgnoreCase("admin") || userName.EqualsIgnoreCase("sitecore\\admin") ? string.Empty : "&user="******"?" + querystring; } if (clipboard) { Clipboard.SetDataObject(instance.GetUrl(url + querystring)); } else { InstanceHelperEx.BrowseInstance(instance, owner, url + querystring, isFrontEnd, browser, parameters); } }
internal static void LoginAsAdmin([NotNull] Instance instance, [NotNull] Window owner, [CanBeNull] string pageUrl = null, [CanBeNull] string browser = null, [CanBeNull] string[] parameters = null) { Assert.ArgumentNotNull(instance, "instance"); Assert.ArgumentNotNull(owner, "owner"); if (!InstanceHelperEx.PreheatInstance(instance, owner, true)) { return; } // Generating unique key to authenticate user var authKey = GetTempAuthKey(); // Generating <guid>.aspx page that will one-time security bypasser var pageName = authKey + ".aspx"; var destFileName = Path.Combine(instance.WebRootPath, "sitecore\\shell\\sim-agent", pageName); CreateFile(destFileName); var async = new Action(() => DeleteFile(destFileName)); async.BeginInvoke(null, null); string url = "/sitecore/shell/sim-agent/" + pageName; var userName = CoreAppSettings.AppLoginAsAdminUserName.Value; bool isFrontEnd = false; bool clipboard = pageUrl == "$(clipboard)"; if (clipboard) { pageUrl = string.Empty; } if (string.IsNullOrEmpty(pageUrl)) { var value = CoreAppSettings.AppLoginAsAdminPageUrl.Value; if (!string.IsNullOrEmpty(value) && !value.EqualsIgnoreCase("/sitecore") && !value.EqualsIgnoreCase("sitecore")) { pageUrl = value; if (!value.StartsWith("/sitecore/")) { isFrontEnd = true; } } } var querystring = (string.IsNullOrEmpty(pageUrl) ? string.Empty : "&page=" + pageUrl) + (string.IsNullOrEmpty(userName) || userName.EqualsIgnoreCase("admin") || userName.EqualsIgnoreCase("sitecore\\admin") ? string.Empty : "&user="******"?" + querystring; } if (clipboard) { Clipboard.SetDataObject(instance.GetUrl(url + querystring)); return; } InstanceHelperEx.BrowseInstance(instance, owner, url + querystring, isFrontEnd, browser, parameters); }