public static IServiceCollection AddBTCPayServer(this IServiceCollection services, IConfiguration configuration) { #if NETCOREAPP21 services.AddSingleton <MvcNewtonsoftJsonOptions>(); #else services.AddSingleton <MvcNewtonsoftJsonOptions>(o => o.GetRequiredService <IOptions <MvcNewtonsoftJsonOptions> >().Value); #endif services.AddDbContext <ApplicationDbContext>((provider, o) => { var factory = provider.GetRequiredService <ApplicationDbContextFactory>(); factory.ConfigureBuilder(o); o.UseOpenIddict <BTCPayOpenIdClient, BTCPayOpenIdAuthorization, OpenIddictScope <string>, BTCPayOpenIdToken, string>(); }); services.AddHttpClient(); services.AddHttpClient(nameof(ExplorerClientProvider), httpClient => { httpClient.Timeout = Timeout.InfiniteTimeSpan; }); services.AddMoneroLike(); services.TryAddSingleton <SettingsRepository>(); services.TryAddSingleton <TorServices>(); services.TryAddSingleton <SocketFactory>(); services.TryAddSingleton <LightningClientFactoryService>(); services.TryAddSingleton <InvoicePaymentNotification>(); services.TryAddSingleton <BTCPayServerOptions>(o => o.GetRequiredService <IOptions <BTCPayServerOptions> >().Value); services.AddStartupTask <MigrationStartupTask>(); services.TryAddSingleton <InvoiceRepository>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); var dbContext = o.GetRequiredService <ApplicationDbContextFactory>(); var dbpath = Path.Combine(opts.DataDir, "InvoiceDB"); if (!Directory.Exists(dbpath)) { Directory.CreateDirectory(dbpath); } return(new InvoiceRepository(dbContext, dbpath, o.GetRequiredService <BTCPayNetworkProvider>())); }); services.AddSingleton <BTCPayServerEnvironment>(); services.TryAddSingleton <TokenRepository>(); services.TryAddSingleton <WalletRepository>(); services.TryAddSingleton <EventAggregator>(); services.TryAddSingleton <PaymentRequestService>(); services.TryAddSingleton <U2FService>(); services.TryAddSingleton <CoinAverageSettings>(); services.TryAddSingleton <ApplicationDbContextFactory>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); ApplicationDbContextFactory dbContext = null; if (!String.IsNullOrEmpty(opts.PostgresConnectionString)) { Logs.Configuration.LogInformation($"Postgres DB used ({opts.PostgresConnectionString})"); dbContext = new ApplicationDbContextFactory(DatabaseType.Postgres, opts.PostgresConnectionString); } else if (!String.IsNullOrEmpty(opts.MySQLConnectionString)) { Logs.Configuration.LogInformation($"MySQL DB used ({opts.MySQLConnectionString})"); Logs.Configuration.LogWarning("MySQL is not widely tested and should be considered experimental, we advise you to use postgres instead."); dbContext = new ApplicationDbContextFactory(DatabaseType.MySQL, opts.MySQLConnectionString); } else { var connStr = "Data Source=" + Path.Combine(opts.DataDir, "sqllite.db"); Logs.Configuration.LogInformation($"SQLite DB used ({connStr})"); Logs.Configuration.LogWarning("MySQL is not widely tested and should be considered experimental, we advise you to use postgres instead."); dbContext = new ApplicationDbContextFactory(DatabaseType.Sqlite, connStr); } return(dbContext); }); services.TryAddSingleton <BTCPayNetworkProvider>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); return(opts.NetworkProvider); }); services.TryAddSingleton <AppService>(); services.TryAddTransient <Safe>(); services.TryAddSingleton <Ganss.XSS.HtmlSanitizer>(o => { var htmlSanitizer = new Ganss.XSS.HtmlSanitizer(); htmlSanitizer.RemovingAtRule += (sender, args) => { }; htmlSanitizer.RemovingTag += (sender, args) => { if (args.Tag.TagName.Equals("img", StringComparison.InvariantCultureIgnoreCase)) { if (!args.Tag.ClassList.Contains("img-fluid")) { args.Tag.ClassList.Add("img-fluid"); } args.Cancel = true; } }; htmlSanitizer.RemovingAttribute += (sender, args) => { if (args.Tag.TagName.Equals("img", StringComparison.InvariantCultureIgnoreCase) && args.Attribute.Name.Equals("src", StringComparison.InvariantCultureIgnoreCase) && args.Reason == Ganss.XSS.RemoveReason.NotAllowedUrlValue) { args.Cancel = true; } }; htmlSanitizer.RemovingStyle += (sender, args) => { args.Cancel = true; }; htmlSanitizer.AllowedAttributes.Add("class"); htmlSanitizer.AllowedTags.Add("iframe"); htmlSanitizer.AllowedTags.Remove("img"); htmlSanitizer.AllowedAttributes.Add("webkitallowfullscreen"); htmlSanitizer.AllowedAttributes.Add("allowfullscreen"); return(htmlSanitizer); }); services.TryAddSingleton <LightningConfigurationProvider>(); services.TryAddSingleton <LanguageService>(); services.TryAddSingleton <NBXplorerDashboard>(); services.TryAddSingleton <StoreRepository>(); services.TryAddSingleton <PaymentRequestRepository>(); services.TryAddSingleton <BTCPayWalletProvider>(); services.TryAddSingleton <CurrencyNameTable>(); services.TryAddSingleton <IFeeProviderFactory>(o => new NBXplorerFeeProviderFactory(o.GetRequiredService <ExplorerClientProvider>()) { Fallback = new FeeRate(100L, 1), BlockTarget = 20 }); services.AddSingleton <CssThemeManager>(); services.Configure <MvcOptions>((o) => { o.Filters.Add(new ContentSecurityPolicyCssThemeManager()); o.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(WalletId))); o.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(DerivationStrategyBase))); }); services.AddSingleton <IHostedService, CssThemeManagerHostedService>(); services.AddSingleton <HostedServices.CheckConfigurationHostedService>(); services.AddSingleton <IHostedService, HostedServices.CheckConfigurationHostedService>(o => o.GetRequiredService <CheckConfigurationHostedService>()); services.AddSingleton <BitcoinLikePaymentHandler>(); services.AddSingleton <IPaymentMethodHandler>(provider => provider.GetService <BitcoinLikePaymentHandler>()); services.AddSingleton <IHostedService, NBXplorerListener>(); services.AddSingleton <LightningLikePaymentHandler>(); services.AddSingleton <IPaymentMethodHandler>(provider => provider.GetService <LightningLikePaymentHandler>()); services.AddSingleton <IHostedService, LightningListener>(); services.AddSingleton <PaymentMethodHandlerDictionary>(); services.AddSingleton <ChangellyClientProvider>(); services.AddSingleton <IHostedService, NBXplorerWaiters>(); services.AddSingleton <IHostedService, InvoiceNotificationManager>(); services.AddSingleton <IHostedService, InvoiceWatcher>(); services.AddSingleton <IHostedService, RatesHostedService>(); services.AddSingleton <IHostedService, BackgroundJobSchedulerHostedService>(); services.AddSingleton <IHostedService, AppHubStreamer>(); services.AddSingleton <IHostedService, AppInventoryUpdaterHostedService>(); services.AddSingleton <IHostedService, DynamicDnsHostedService>(); services.AddSingleton <IHostedService, TorServicesHostedService>(); services.AddSingleton <IHostedService, PaymentRequestStreamer>(); services.AddSingleton <IBackgroundJobClient, BackgroundJobClient>(); services.AddScoped <IAuthorizationHandler, CookieAuthorizationHandler>(); services.AddScoped <IAuthorizationHandler, OpenIdAuthorizationHandler>(); services.AddScoped <IAuthorizationHandler, BitpayAuthorizationHandler>(); services.TryAddSingleton <ExplorerClientProvider>(); services.TryAddSingleton <Bitpay>(o => { if (o.GetRequiredService <BTCPayServerOptions>().NetworkType == NetworkType.Mainnet) { return(new Bitpay(new Key(), new Uri("https://bitpay.com/"))); } else { return(new Bitpay(new Key(), new Uri("https://test.bitpay.com/"))); } }); services.TryAddSingleton <RateProviderFactory>(); services.TryAddSingleton <RateFetcher>(); services.TryAddScoped <IHttpContextAccessor, HttpContextAccessor>(); services.AddTransient <AccessTokenController>(); services.AddTransient <InvoiceController>(); services.AddTransient <AppsPublicController>(); services.AddTransient <PaymentRequestController>(); // Add application services. services.AddSingleton <EmailSenderFactory>(); // bundling services.AddBtcPayServerAuthenticationSchemes(configuration); services.AddAuthorization(o => o.AddBTCPayPolicies()); services.AddSingleton <IBundleProvider, ResourceBundleProvider>(); services.AddTransient <BundleOptions>(provider => { var opts = provider.GetRequiredService <BTCPayServerOptions>(); var bundle = new BundleOptions(); bundle.UseBundles = opts.BundleJsCss; bundle.AppendVersion = true; return(bundle); }); services.AddCors(options => { options.AddPolicy(CorsPolicies.All, p => p.AllowAnyHeader().AllowAnyMethod().AllowAnyOrigin()); }); var rateLimits = new RateLimitService(); rateLimits.SetZone($"zone={ZoneLimits.Login} rate=5r/min burst=3 nodelay"); services.AddSingleton(rateLimits); return(services); }
public static IServiceCollection AddBTCPayServer(this IServiceCollection services, IConfiguration configuration) { services.AddSingleton <MvcNewtonsoftJsonOptions>(o => o.GetRequiredService <IOptions <MvcNewtonsoftJsonOptions> >().Value); services.AddDbContext <ApplicationDbContext>((provider, o) => { var factory = provider.GetRequiredService <ApplicationDbContextFactory>(); factory.ConfigureBuilder(o); }); services.AddHttpClient(); services.AddHttpClient(nameof(ExplorerClientProvider), httpClient => { httpClient.Timeout = Timeout.InfiniteTimeSpan; }); services.AddSingleton <BTCPayNetworkJsonSerializerSettings>(); services.RegisterJsonConverter(n => new ClaimDestinationJsonConverter(n)); services.AddPayJoinServices(); #if ALTCOINS services.AddMoneroLike(); #endif services.TryAddSingleton <SettingsRepository>(); services.TryAddSingleton <LabelFactory>(); services.TryAddSingleton <TorServices>(); services.TryAddSingleton <SocketFactory>(); services.TryAddSingleton <LightningClientFactoryService>(); services.TryAddSingleton <InvoicePaymentNotification>(); services.TryAddSingleton <BTCPayServerOptions>(o => o.GetRequiredService <IOptions <BTCPayServerOptions> >().Value); services.AddStartupTask <MigrationStartupTask>(); services.TryAddSingleton <InvoiceRepository>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); var dbContext = o.GetRequiredService <ApplicationDbContextFactory>(); var dbpath = Path.Combine(opts.DataDir, "InvoiceDB"); if (!Directory.Exists(dbpath)) { Directory.CreateDirectory(dbpath); } return(new InvoiceRepository(dbContext, dbpath, o.GetRequiredService <BTCPayNetworkProvider>())); }); services.AddSingleton <BTCPayServerEnvironment>(); services.TryAddSingleton <TokenRepository>(); services.TryAddSingleton <WalletRepository>(); services.TryAddSingleton <EventAggregator>(); services.TryAddSingleton <PaymentRequestService>(); services.TryAddSingleton <U2FService>(); services.TryAddSingleton <ApplicationDbContextFactory>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); ApplicationDbContextFactory dbContext = null; if (!String.IsNullOrEmpty(opts.PostgresConnectionString)) { Logs.Configuration.LogInformation($"Postgres DB used ({opts.PostgresConnectionString})"); dbContext = new ApplicationDbContextFactory(DatabaseType.Postgres, opts.PostgresConnectionString); } else if (!String.IsNullOrEmpty(opts.MySQLConnectionString)) { Logs.Configuration.LogInformation($"MySQL DB used ({opts.MySQLConnectionString})"); Logs.Configuration.LogWarning("MySQL is not widely tested and should be considered experimental, we advise you to use postgres instead."); dbContext = new ApplicationDbContextFactory(DatabaseType.MySQL, opts.MySQLConnectionString); } else { var connStr = "Data Source=" + Path.Combine(opts.DataDir, "sqllite.db"); Logs.Configuration.LogInformation($"SQLite DB used ({connStr})"); Logs.Configuration.LogWarning("SQLite is not widely tested and should be considered experimental, we advise you to use postgres instead."); dbContext = new ApplicationDbContextFactory(DatabaseType.Sqlite, connStr); } return(dbContext); }); services.TryAddSingleton <BTCPayNetworkProvider>(o => { var opts = o.GetRequiredService <BTCPayServerOptions>(); return(opts.NetworkProvider); }); services.TryAddSingleton <AppService>(); services.TryAddTransient <Safe>(); services.TryAddSingleton <Ganss.XSS.HtmlSanitizer>(o => { var htmlSanitizer = new Ganss.XSS.HtmlSanitizer(); htmlSanitizer.RemovingAtRule += (sender, args) => { }; htmlSanitizer.RemovingTag += (sender, args) => { if (args.Tag.TagName.Equals("img", StringComparison.InvariantCultureIgnoreCase)) { if (!args.Tag.ClassList.Contains("img-fluid")) { args.Tag.ClassList.Add("img-fluid"); } args.Cancel = true; } }; htmlSanitizer.RemovingAttribute += (sender, args) => { if (args.Tag.TagName.Equals("img", StringComparison.InvariantCultureIgnoreCase) && args.Attribute.Name.Equals("src", StringComparison.InvariantCultureIgnoreCase) && args.Reason == Ganss.XSS.RemoveReason.NotAllowedUrlValue) { args.Cancel = true; } }; htmlSanitizer.RemovingStyle += (sender, args) => { args.Cancel = true; }; htmlSanitizer.AllowedAttributes.Add("class"); htmlSanitizer.AllowedTags.Add("iframe"); htmlSanitizer.AllowedTags.Add("style"); htmlSanitizer.AllowedTags.Remove("img"); htmlSanitizer.AllowedAttributes.Add("webkitallowfullscreen"); htmlSanitizer.AllowedAttributes.Add("allowfullscreen"); return(htmlSanitizer); }); services.TryAddSingleton <LightningConfigurationProvider>(); services.TryAddSingleton <LanguageService>(); services.TryAddSingleton <NBXplorerDashboard>(); services.TryAddSingleton <ISyncSummaryProvider, NBXSyncSummaryProvider>(); services.TryAddSingleton <StoreRepository>(); services.TryAddSingleton <PaymentRequestRepository>(); services.TryAddSingleton <BTCPayWalletProvider>(); services.TryAddSingleton <WalletReceiveStateService>(); services.TryAddSingleton <CurrencyNameTable>(CurrencyNameTable.Instance); services.TryAddSingleton <IFeeProviderFactory>(o => new NBXplorerFeeProviderFactory(o.GetRequiredService <ExplorerClientProvider>()) { Fallback = new FeeRate(100L, 1) }); services.AddSingleton <CssThemeManager>(); services.Configure <MvcOptions>((o) => { o.Filters.Add(new ContentSecurityPolicyCssThemeManager()); o.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(WalletId))); o.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(DerivationStrategyBase))); }); services.AddSingleton <IHostedService, CssThemeManagerHostedService>(); services.AddSingleton <HostedServices.CheckConfigurationHostedService>(); services.AddSingleton <IHostedService, HostedServices.CheckConfigurationHostedService>(o => o.GetRequiredService <CheckConfigurationHostedService>()); services.AddSingleton <HostedServices.PullPaymentHostedService>(); services.AddSingleton <IHostedService, HostedServices.PullPaymentHostedService>(o => o.GetRequiredService <PullPaymentHostedService>()); services.AddSingleton <BitcoinLikePaymentHandler>(); services.AddSingleton <IPaymentMethodHandler>(provider => provider.GetService <BitcoinLikePaymentHandler>()); services.AddSingleton <IHostedService, NBXplorerListener>(); services.AddSingleton <LightningLikePaymentHandler>(); services.AddSingleton <IPaymentMethodHandler>(provider => provider.GetService <LightningLikePaymentHandler>()); services.AddSingleton <IHostedService, LightningListener>(); services.AddSingleton <PaymentMethodHandlerDictionary>(); services.AddSingleton <ChangellyClientProvider>(); services.AddSingleton <NotificationManager>(); services.AddScoped <NotificationSender>(); services.AddSingleton <IHostedService, NBXplorerWaiters>(); services.AddSingleton <IHostedService, InvoiceNotificationManager>(); services.AddSingleton <IHostedService, InvoiceWatcher>(); services.AddSingleton <IHostedService, RatesHostedService>(); services.AddSingleton <IHostedService, BackgroundJobSchedulerHostedService>(); services.AddSingleton <IHostedService, AppHubStreamer>(); services.AddSingleton <IHostedService, AppInventoryUpdaterHostedService>(); services.AddSingleton <IHostedService, TransactionLabelMarkerHostedService>(); services.AddSingleton <IHostedService, UserEventHostedService>(); services.AddSingleton <IHostedService, DynamicDnsHostedService>(); services.AddSingleton <IHostedService, TorServicesHostedService>(); services.AddSingleton <IHostedService, PaymentRequestStreamer>(); services.AddSingleton <IHostedService, WalletReceiveCacheUpdater>(); services.AddSingleton <IBackgroundJobClient, BackgroundJobClient>(); services.AddScoped <IAuthorizationHandler, CookieAuthorizationHandler>(); services.AddScoped <IAuthorizationHandler, BitpayAuthorizationHandler>(); services.AddSingleton <IVersionFetcher, GithubVersionFetcher>(); services.AddSingleton <IHostedService, NewVersionCheckerHostedService>(); services.AddSingleton <INotificationHandler, NewVersionNotification.Handler>(); services.AddSingleton <INotificationHandler, InvoiceEventNotification.Handler>(); services.AddSingleton <INotificationHandler, PayoutNotification.Handler>(); #if DEBUG services.AddSingleton <INotificationHandler, JunkNotification.Handler>(); #endif services.TryAddSingleton <ExplorerClientProvider>(); services.TryAddSingleton <Bitpay>(o => { if (o.GetRequiredService <BTCPayServerOptions>().NetworkType == NetworkType.Mainnet) { return(new Bitpay(new Key(), new Uri("https://bitpay.com/"))); } else { return(new Bitpay(new Key(), new Uri("https://test.bitpay.com/"))); } }); services.TryAddSingleton <RateProviderFactory>(); services.TryAddSingleton <RateFetcher>(); services.TryAddScoped <IHttpContextAccessor, HttpContextAccessor>(); services.AddTransient <AccessTokenController>(); services.AddTransient <InvoiceController>(); services.AddTransient <AppsPublicController>(); services.AddTransient <PaymentRequestController>(); // Add application services. services.AddSingleton <EmailSenderFactory>(); services.AddAPIKeyAuthentication(); services.AddBtcPayServerAuthenticationSchemes(); services.AddAuthorization(o => o.AddBTCPayPolicies()); // bundling services.AddSingleton <IBundleProvider, ResourceBundleProvider>(); services.AddTransient <BundleOptions>(provider => { var opts = provider.GetRequiredService <BTCPayServerOptions>(); var bundle = new BundleOptions(); bundle.UseBundles = opts.BundleJsCss; bundle.AppendVersion = true; return(bundle); }); services.AddCors(options => { options.AddPolicy(CorsPolicies.All, p => p.AllowAnyHeader().AllowAnyMethod().AllowAnyOrigin()); }); services.AddSingleton(provider => { var btcPayEnv = provider.GetService <BTCPayServerEnvironment>(); var rateLimits = new RateLimitService(); if (btcPayEnv.IsDeveloping) { rateLimits.SetZone($"zone={ZoneLimits.Login} rate=1000r/min burst=100 nodelay"); rateLimits.SetZone($"zone={ZoneLimits.Register} rate=1000r/min burst=100 nodelay"); rateLimits.SetZone($"zone={ZoneLimits.PayJoin} rate=1000r/min burst=100 nodelay"); } else { rateLimits.SetZone($"zone={ZoneLimits.Login} rate=5r/min burst=3 nodelay"); rateLimits.SetZone($"zone={ZoneLimits.Register} rate=2r/min burst=2 nodelay"); rateLimits.SetZone($"zone={ZoneLimits.PayJoin} rate=5r/min burst=3 nodelay"); } return(rateLimits); }); services.AddLogging(logBuilder => { var debugLogFile = BTCPayServerOptions.GetDebugLog(configuration); if (!string.IsNullOrEmpty(debugLogFile)) { Serilog.Log.Logger = new LoggerConfiguration() .Enrich.FromLogContext() .MinimumLevel.Is(BTCPayServerOptions.GetDebugLogLevel(configuration)) .WriteTo.File(debugLogFile, rollingInterval: RollingInterval.Day, fileSizeLimitBytes: MAX_DEBUG_LOG_FILE_SIZE, rollOnFileSizeLimit: true, retainedFileCountLimit: 1) .CreateLogger(); logBuilder.AddProvider(new Serilog.Extensions.Logging.SerilogLoggerProvider(Log.Logger)); } }); return(services); }
// GET: videos/search public async Task <IActionResult> search(string term, string filter, int?pagenumber) { if (term == null) { return(Redirect("/videos/")); } var _sanitize = new Ganss.XSS.HtmlSanitizer(); term = UtilityBLL.ReplaceHyphinWithSpace(term); /* ***************************************/ // Process Page Meta & BreaCrumb /* ***************************************/ var _meta = PageMeta.returnPageMeta(new PageQuery() { controller = ControllerContext.ActionDescriptor.ControllerName, index = ControllerContext.ActionDescriptor.ActionName, pagenumber = (int)pagenumber, matchterm = term }); if (Jugnoon.Settings.Configs.GeneralSettings.store_searches) { //********************************************* // User Search Tracking Script //******************************************** if (!TagsBLL.Validate_Tags(term.Trim()) && !term.Trim().Contains("@")) { // check if tag doesn't exist var count_tags = await TagsBLL.Count(_context, new TagEntity() { type = TagsBLL.Types.General, tag_type = TagsBLL.TagType.UserSearches, isenabled = EnabledTypes.Enabled }); if (count_tags == 0) { TagsBLL.Add(_context, term.Trim(), TagsBLL.Types.General, 0, TagsBLL.TagType.UserSearches, EnabledTypes.Enabled, term.Trim()); } } } /* List Initialization */ var ListEntity = new VideoListViewModel() { QueryOptions = new VideoEntity() { term = term }, BreadItems = _meta.BreadItems }; /**********************************************/ // Page Meta Setup /**********************************************/ ViewBag.title = _meta.title; ViewBag.description = _meta.description; return(View(ListEntity)); }
static HtmlSanitizer() { sanitizer = new Ganss.XSS.HtmlSanitizer(); }