public void Configuration(IAppBuilder app) { if (SetupConfig.OwinEnabled()) { ConfigureAuth(app); } app.UseApplicationRestartPluginMessage(new PluginMessageOptions()); app.UsePortalBus <ApplicationRestartPortalBusMessage>(); app.UsePortalBus <CacheInvalidationPortalBusMessage>(); // DMS SignalR // //GlobalHost.DependencyResolver.UseSqlServer(ConfigurationManager.ConnectionStrings["Xrm"].ConnectionString.ToString();); //this.ConfigureAuth(app); app.MapSignalR(); }
void Application_Start(object sender, EventArgs e) { AntiForgeryConfig.CookieName = "__RequestVerificationToken"; // static name as its dependent on the ajax handler. MvcHandler.DisableMvcResponseHeader = true; _setupRunning = SetupConfig.ApplicationStart(); if (_setupRunning) { return; } var areaRegistrationState = new PortalAreaRegistrationState(); Application[typeof(IPortalAreaRegistrationState).FullName] = areaRegistrationState; AreaRegistration.RegisterAllAreas(areaRegistrationState); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); }
public static void PreApplicationStart() { if (!SetupConfig.IsPortalConfigured()) { ADXTrace.Instance.TraceInfo(TraceCategory.Application, "Configuring setup components."); DynamicModuleUtility.RegisterModule(typeof(SetupRoutingModule)); RegisterBundles(BundleTable.Bundles); } else { ADXTrace.Instance.TraceInfo(TraceCategory.Application, "Configuring standard portal components."); DynamicModuleUtility.RegisterModule(typeof(PortalRoutingModule)); AntiForgeryConfig.SuppressXFrameOptionsHeader = true; // read the connection settings from the local file CrmConfigurationProvider.ConfigurationCreated += OnConfigurationCreated; PortalCrmConfigurationProvider.ConfigurationCreated += OnConfigurationCreated; } }
void Application_Start(object sender, EventArgs e) { // Mainly created to disable the use of Ssl v3 which is no longer supported by the Organization Service // Now the Security Protocols to support can be set on the appSettings configuration section. ServicePointManager.SecurityProtocol = GetSecurityProtocolFromConfigurationOrDefault(); AntiForgeryConfig.CookieName = "__RequestVerificationToken"; // static name as its dependent on the ajax handler. MvcHandler.DisableMvcResponseHeader = true; _setupRunning = SetupConfig.ApplicationStart(); if (_setupRunning) { return; } var areaRegistrationState = new PortalAreaRegistrationState(); Application[typeof(IPortalAreaRegistrationState).FullName] = areaRegistrationState; AreaRegistration.RegisterAllAreas(areaRegistrationState); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); }
public void ConfigurePortal(IAppBuilder app) { var host = new PortalHostingEnvironment(); var webAppSettings = WebAppSettings.Instance; // For cache we create one subscription per instance of web app, that's why we use instance id as the subscription name. var cacheEventHubJobSettings = new EventHubJobSettings(webAppSettings.InstanceId, EventHubSubscriptionType.CacheSubscription); // For search we create one subscription per webapp, that's why we use site name as the subscription name. var searchEventHubJobSettings = new EventHubJobSettings(webAppSettings.SiteName, EventHubSubscriptionType.SearchSubscription); var requireSslOptions = new RequireSslOptions(webAppSettings); var warmupCacheSettings = new WarmupCacheSettings(); app.ConfigureApplicationLifecycleEvents(); app.UseETWMiddleware(); app.UseRequireSsl(requireSslOptions); app.UseAppInfo(); app.UseHealth(); app.UseScaleOutTelemetry(); app.UseRequestTelemetry(SetupConfig.IsPortalConfigured); app.UseApplicationRestartPluginMessage(new PluginMessageOptions()); app.UsePortalBus <ApplicationRestartPortalBusMessage>(webAppSettings, cacheEventHubJobSettings); app.UsePortalBus <CacheInvalidationPortalBusMessage>(webAppSettings, cacheEventHubJobSettings); app.CreatePerOwinContext <RequestElapsedTimeContext>(RequestElapsedTimeContext.Create); if (!SetupConfig.InitialSetupIsRunning() && !SetupConfig.ProvisioningInProgress()) { using (PerformanceProfiler.Instance.StartMarker(PerformanceMarkerName.Startup, PerformanceMarkerArea.Crm, PerformanceMarkerTagName.StartUpConfiguration)) { // indepdendent components app.CreatePerOwinContext(ApplicationDbContext.Create); var portalSolutions = app.ConfigurePortalSolutionsDetails(ApplicationDbContext.Create()); app.CreatePerOwinContext <ApplicationOrganizationManager>(ApplicationOrganizationManager.Create); app.CreatePerOwinContext <ApplicationWebsiteManager>(ApplicationWebsiteManager.Create); app.CreatePerOwinContext <CrmWebsite>((options, context) => ApplicationWebsite.Create(options, context, host)); // Set the culture for this request. app.UseCurrentThreadCulture(); ApplicationWebsiteManager websiteManager; try { var settings = new CrmEntityStoreSettings { PortalSolutions = portalSolutions }; websiteManager = ApplicationWebsiteManager.Create(ApplicationDbContext.Create(), settings); } catch { //We need to unload app domain in order to reinitialize owin during next request TelemetryState.ApplicationEndInfo = ApplicationEndFlags.Configuration; Adxstudio.Xrm.Web.Extensions.RestartWebApplication(); return; } var website = websiteManager.Find(HttpContext.Current.Request.RequestContext, host); var hstsOptions = new StrictTransportSecurityOptions(website); // components that depend on the website app.UpdatePrimaryDomainName(websiteManager, website, portalSolutions); app.ConfigureDisplayModes(website); app.UseWebsiteHeaderSettings(website); app.UseStrictTransportSecuritySettings(hstsOptions); app.ConfigureSearchProvider(website); var contentMapProvider = app.ConfigureContentMap(ApplicationDbContext.Create, website, cacheEventHubJobSettings, portalSolutions); // configure user dependencies this.ConfigureAuth(app, website); // components that depend on the user app.CreatePerOwinContext <ContextLanguageInfo>(ContextLanguageInfo.Create); // Complete the authentication stage prior to invoking page handler app.UseStageMarker(PipelineStage.Authenticate); // components that depend on content map app.ConfigureCulture(website, contentMapProvider, BundleTable.Bundles, BundleConfig.RegisterLanguageSpecificBundles); // tail end components app.ConfigureEventHubCacheInvalidation(website.Id, ApplicationDbContext.Create, cacheEventHubJobSettings, searchEventHubJobSettings, new CacheInvalidationJobSettings(webAppSettings)); app.WarmupCache(ApplicationDbContext.Create, warmupCacheSettings); app.StartupComplete(); } } }