Esempio n. 1
0
        /// <summary>
        /// Processes the request async.
        /// </summary>
        public async override Task ProcessAsync()
        {
            try
            {
                DepartureBoardRequest dbRequest = await Receive <DepartureBoardRequest>();

                Logging.Log($"Received departure board request from { ((IPEndPoint)client.Client.RemoteEndPoint).Address.ToString() }. Data: { dbRequest.ToString() }");

                DepartureBoardResponse dbRes = null;

                await Task.Run(() =>
                {
                    if (dbRequest is StationInfoRequest)
                    {
                        using (var dbProcessing = new Interop.DepartureBoardManaged(DataFeed.Full, (StationInfoRequest)dbRequest))
                        {
                            dbProcessing.ObtainDepartureBoard();
                            dbRes = dbProcessing.ShowDepartureBoard();
                        }
                    }
                    else if (dbRequest is LineInfoRequest)
                    {
                        using (var dbProcessing = new Interop.DepartureBoardManaged(DataFeed.Full, (LineInfoRequest)dbRequest))
                        {
                            dbProcessing.ObtainDepartureBoard();
                            dbRes = dbProcessing.ShowDepartureBoard();
                        }
                    }
                    else
                    {
                        throw new NotImplementedException();
                    }
                });

                Send(dbRes);

                Logging.Log($"Departure board response to { ((IPEndPoint)client.Client.RemoteEndPoint).Address.ToString() } was successfully send.");
            }
            catch (Exception ex)
            {
                Logging.Log($"Departure board request from { ((IPEndPoint)client.Client.RemoteEndPoint).Address.ToString() } could not be processed. { Logging.LogException(ex) }");
            }
            Dispose();
        }
Esempio n. 2
0
        private static async Task <DepartureBoardResponse> SendDepartureBoardRequestAsync(LineInfoRequest dbRequest, bool forceCache = false)
        {
            DepartureBoardResponse dbResponse = null;

            if (DataFeedDesktop.OfflineMode)
            {
                await Task.Run(() =>
                {
                    using (var dbProcessing = new Interop.DepartureBoardManaged(DataFeedDesktop.Full, dbRequest))
                    {
                        dbProcessing.ObtainDepartureBoard();
                        dbResponse = dbProcessing.ShowDepartureBoard();
                    }
                });
            }

            else
            {
                using (var dbProcessing = new DepartureBoardProcessing())
                {
                    var cached = LineInfoCached.Select(dbRequest.RouteInfoID);

                    if (cached == null || (cached.ShouldBeUpdated || forceCache))
                    {
                        try
                        {
                            if (!await CheckBasicDataValidity())
                            {
                                var results = cached?.FindResultsSatisfyingRequest(dbRequest);
                                return(results?.Departures.Count == 0 ? null : results);
                            }

                            // Process the request immediately so the user does not have to wait until the caching is completed.

                            dbResponse = await dbProcessing.ProcessAsync(dbRequest, dbRequest.Count == -1?int.MaxValue : Settings.TimeoutDuration);

                            // Then update the cache.

#pragma warning disable CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
                            if (cached != null && cached.ShouldBeUpdated && dbRequest.Count != -1)
                            {
                                Task.Run(async() => cached.UpdateCache(await dbProcessing.ProcessAsync(cached.ConstructNewRequest(), int.MaxValue)));
                            }
#pragma warning restore CS4014 // Because this call is not awaited, execution of the current method continues before the call is completed
                        }
                        catch (System.Net.WebException)
                        {
                            MessageBox.Show(Settings.Localization.UnreachableHost, Settings.Localization.Offline, MessageBoxButtons.OK, MessageBoxIcon.Error);
                        }
                    }

                    else
                    {
                        dbResponse = cached?.FindResultsSatisfyingRequest(dbRequest);
                        if (dbResponse?.Departures.Count == 0)
                        {
                            dbResponse = await dbProcessing.ProcessAsync(dbRequest, Settings.TimeoutDuration);
                        }
                    }
                }
            }
            return(dbResponse);
        }