Beispiel #1
0
        private static async Task CreateReport()
        {
            ITradesFetcher         tradesFetcher    = new TradesFetcher(ConfigurationManager.Service, ConfigurationManager.TradeType, logger);
            ITradeVolumeCalculator volumeCalculator = new TradeVolumeCalculator(logger);
            IReportCreator         reportCreator    = new ReportCreator(tradesFetcher, volumeCalculator);

            while (true)
            {
                await reportCreator.CreateTradeVolumeReportAsync(DateTime.Now, ConfigurationManager.TradeReportsPath);

                logger.LogEvent(ServiceEvent.ReportCreatedSuccessfully);

                ConfigurationManager.RefreshAppSettings();

                TimeSpan newInterval = ConfigurationManager.GenerationIntervalInMinutes;

                if (IntervalChanged(newInterval))
                {
                    initialInterval = newInterval;

                    logger.LogEvent(ServiceEvent.GenerationIntervalChanged, string.Format("Interval changed to: {0}", newInterval));
                }

                logger.LogEvent(ServiceEvent.Sleeping);

                await Task.Delay(newInterval);
            }
        }
Beispiel #2
0
        static void Main(string[] args)
        {
            initialInterval = ConfigurationManager.GenerationIntervalInMinutes;
            logger          = new ServiceLogger(LogStrategy.Console);

            logger.LogEvent(ServiceEvent.ServiceInitialized, string.Format("Interval: {0}", initialInterval));

            Task.Run(() => CreateReport()).GetAwaiter().GetResult();

            logger.LogEvent(ServiceEvent.ServiceStopped);
        }