Exemple #1
0
        public static void Main()
        {
            var tag = "8600856-10:45";

            Dictionary<string, string> messageData = new Dictionary<string, string>
            {
                ["delayedCount"] = "4",
                ["departureName0"] = "Test Train",
                ["departureTime0"] = "11:23",
                ["departureDelay0"] = "0",
                ["departureName1"] = "Marcin is testing",
                ["departureTime1"] = "00:03",
                ["departureDelay1"] = "5",
                ["departureName2"] = "Train 3",
                ["departureTime2"] = "",
                ["departureDelay2"] = "10",
                ["departureName3"] = "Train 4",
                ["departureTime3"] = "11:23",
                ["departureDelay3"] = "61"
            };

            var notificationOutcome = new PushNotificationSender(Console.WriteLine).SendAsync(messageData, tag).Result;
            Console.WriteLine($"State: {notificationOutcome.State}");
            Console.WriteLine($"Success: {notificationOutcome.Success}");
            Console.WriteLine($"Failure: {notificationOutcome.Failure}");
            Console.WriteLine($"NotificationId: {notificationOutcome.NotificationId}");
            Console.WriteLine($"TrackingId: {notificationOutcome.TrackingId}");
        }
        public static async Task ProcessQueueMessage([ServiceBusTrigger("dsbforsinketqueue")] BrokeredMessage message, TextWriter log)
        {
            log.WriteLine($"Got message: {message}");
            var isDebugMode = Convert.ToBoolean(ConfigurationManager.AppSettings["APP_DEBUG_MODE"]);
            log.WriteLine($"DEBUG MODE: {isDebugMode}");

            string stationId = (string)message.Properties["station"];
            string tag = (string)message.Properties["tag"];
            bool isTestSend = (bool)message.Properties["istest"];
            var service = new DSBLabsStationService(new Uri(BaseUrl));

            log.WriteLine($"stationId: {stationId} tag: {tag} isTestSend: {isTestSend}");
            log.WriteLine("Preparing the query.");

            var delayedDeparturesQuery =
                from departure in service.Queue
                where (departure.StationUic == stationId) &&
                      (departure.Cancelled == true || departure.DepartureDelay > 0 || isDebugMode)
                select departure;

            log.WriteLine("Executing the query.");
            var delayedDepartures = delayedDeparturesQuery.ToList();
            log.WriteLine("Query executed.");
            log.WriteLine($"Delayed departures: {delayedDepartures.Count}.");

            if (delayedDepartures.Any() || isTestSend || isDebugMode)
            {
                log.WriteLine($"Sending push message to tag: {tag}.");

                delayedDepartures = delayedDepartures.OrderBy(d => d.ScheduledDeparture).ToList();

                Dictionary<string, string> messageData = new Dictionary<string, string>
                {
                    ["delayedCount"] = delayedDepartures.Count.ToString(CultureInfo.InvariantCulture)
                };

                foreach (var departure in delayedDepartures.Take(5).Select((data, index) => new { index, data }))
                {
                    var destinationName = string.IsNullOrWhiteSpace(departure.data.Line)
                                                ?  departure.data.DestinationName
                                                : $"{departure.data.Line} <i>{departure.data.DestinationName}</i>";
                    messageData[$"departureName{departure.index}"] = destinationName;
                    messageData[$"departureTime{departure.index}"] = departure.data.ScheduledDeparture.HasValue 
                                                                        ? departure.data.ScheduledDeparture.Value.ToString("HH:mm", CultureInfo.InvariantCulture)
                                                                        : string.Empty;
                    long delayInMinutes = (departure.data.DepartureDelay / 60) ?? 0;
                    messageData[$"departureDelay{departure.index}"] = Convert.ToString(delayInMinutes);
                }

                var notificationSender = new PushNotificationSender(log.WriteLine);

                var notificationOutcome = await notificationSender.SendAsync(messageData, tag);

                log.WriteLine($"State: {notificationOutcome.State}");
                log.WriteLine($"Success: {notificationOutcome.Success}");
                log.WriteLine($"Failure: {notificationOutcome.Failure}");
                log.WriteLine($"NotificationId: {notificationOutcome.NotificationId}");
                log.WriteLine($"TrackingId: {notificationOutcome.TrackingId}");
            }
        }