コード例 #1
0
        public string GetBookResult(EmployeeModel employee, CustomFlightDetailModel iter, string tripid)
        {
            BookResponse bookResponse;

            string Result = "";

            try
            {
                WebRequest request = WebRequest.Create("http://online-corporate-traveller.amadeus.com/live/V17_2_0/webapi/api/FlightBook/RequestFlightBook1");
                request.Method      = "POST";
                request.ContentType = "application/json";
                Stream dataStream = request.GetRequestStream();

                // getJson(date, direct, type, quantity, origin, desti);
                // JObject abc = new SearchRequest().GetJson();

                byte[] byteArray = Encoding.UTF8.GetBytes(new BookingJsons().GetBookRequest(employee, iter, tripid, employee.TokenID));
                request.ContentLength = byteArray.Length;
                dataStream.Write(byteArray, 0, byteArray.Length);
                dataStream.Close();
                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                using (Stream receiveStream = Flight_Availability.GetStreamForResponse(response))
                {
                    StreamReader sr = new StreamReader(receiveStream);
                    string       responseFromServer = sr.ReadToEnd();

                    bookResponse = JsonConvert.DeserializeObject <BookResponse>(responseFromServer);
                    if (bookResponse.ResultDescription != "")
                    {
                        Result = bookResponse.ResultDescription;
                    }
                    else
                    {
                        var c = bookResponse.PricedItinerary.FirstOrDefault().Flights.FirstOrDefault();

                        string Message = "Origin :" + c.DepartureCityName + " Desitination : " + bookResponse.PricedItinerary.FirstOrDefault().Flights.LastOrDefault().ArrivalCityName + " flight number :" +
                                         c.FlightNumber + " FareType : " + c.FareType + " ArrivalDate: " + c.ArrivalDate + "DepartureDate : " + c.DepartureDate + "DepartureTime :" + c.DepartureTime;
                        // SendDetail(Message, employee.Email);
                        //string Result = " DepCity : " + c.Flights.FirstOrDefault().DepartureCityName + " ArrivalCity : " + c.Flights.LastOrDefault().ArrivalCityName;
                        Result = "Confirmed.The detail has  been mailed to you on " + employee.Email;
                    }
                }
                dataStream.Close();
                response.Close();
            }
            catch (Exception ex)
            {
                throw ex;
            }


            return(Result);
        }
コード例 #2
0
        public dynamic QueriResult(JObject entities, Query query, string DeviceId)
        {
            dynamic qresult = "";

            //   Query custom= new Query();

            if (query != null)
            {
                var check = entities.GetValue("City") != null?entities.GetValue("City").FirstOrDefault().ToString() : "";

                //|| entities.GetValue("City").FirstOrDefault().ToString()!=query.Origin
                query.Quantity = 1;
                if (query.Origin == null || (check != query.Origin && check != ""))
                {
                    if (entities.GetValue("City") != null)
                    {
                        string x = "";
                        if (entities.GetValue("fromto") != null)
                        {
                            x = entities.GetValue("fromto").FirstOrDefault().ToString();
                            x = x.Length == 2 ? "to" : "from";
                        }
                        if (x.ToString() == "from" || x.ToString() == "")
                        {
                            query.Origin = entities.GetValue("City").FirstOrDefault().ToString();
                            qresult      = Mesg(query);
                        }
                        else
                        {
                            qresult = Mesg(query);
                        }
                    }
                }
                //|| entities.GetValue("City").LastOrDefault().ToString()!=query.Dest
                if (query.Dest == null || (check != query.Dest && check != ""))
                {
                    if (entities.GetValue("City") != null)
                    {
                        dynamic x = "";
                        if (entities.GetValue("fromto") != null)
                        {
                            x = entities.GetValue("fromto").LastOrDefault().ToString();
                        }

                        if ((x == "to" || x == "") && entities.GetValue("City").LastOrDefault().ToString() != query.Origin)
                        {
                            query.Dest = entities.GetValue("City").LastOrDefault().ToString();

                            qresult = Mesg(query);
                        }
                    }
                }
                if (query.Date == null)
                {
                    if (entities.GetValue("datetime") != null)
                    {
                        dynamic date1 = entities.GetValue("datetime").FirstOrDefault();
                        query.Date = Convert.ToDateTime(date1["timex"].First.ToString().Replace("XXXX", DateTime.Now.Year.ToString()));
                        query.Date = query.Date.GetValueOrDefault().Month < DateTime.Now.Month ? query.Date.GetValueOrDefault().AddYears(1) : query.Date;
                        qresult    = Mesg(query);
                    }
                }
                if (query.Quantity == null)
                {
                    if (entities.GetValue("quantity") != null)
                    {
                        query.Quantity = int.Parse(entities.GetValue("quantity").FirstOrDefault().ToString());
                        qresult        = Mesg(query);
                    }
                }
            }
            string days = entities.GetValue("days") != null?entities.GetValue("days").FirstOrDefault().ToString() : "";

            days = days != "" ? days.Substring(0, 1) : "";
            List <CustomFlightDetailModel> customFlights = new List <CustomFlightDetailModel>();
            List <BirdResAWSBot.SBT.Request.Response.PricedItinerary> iteneraries = new List <BirdResAWSBot.SBT.Request.Response.PricedItinerary>();
            string uniqueid = Guid.NewGuid().ToString();

            if (query.Origin != null && query.Dest != null && query.Date != null && query.Quantity != null)
            {
                EmployeeModel em = new EmptyBot().GiveEmployee();

                // List<LexResponse.LexGenericAttachments> attachments = new List<LexResponse.LexGenericAttachments>();
                iteneraries = new Flight_Availability().ApiRes(query.Date.GetValueOrDefault(), days, query.Quantity.ToString(), ACode.GetAirPortCodeByCity(query.Origin), ACode.GetAirPortCodeByCity(query.Dest), uniqueid, em.TokenID, "AI");
                //    qresult = FlightsInfo.ApiRes(query.Date.GetValueOrDefault(), false, false, query.Quantity.ToString(), ACode.GetAirPortCodeByCity(query.Origin), ACode.GetAirPortCodeByCity(query.Dest));
                int iGroup = 0;
                foreach (var iter in iteneraries)
                {
                    //var z = iter.Flights.FirstOrDefault();
                    //var l = iter.Flights.LastOrDefault();

                    //customFlights.Add(new CustomFlightDetailModel
                    //{
                    //    FlightNumber = z.FlightNumber,
                    //    ArrivalAirport = z.ArrivalAirportName,
                    //    DepAirport = z.DepartureAirportName,
                    //    ArrivalDate = z.ArrivalDate,// DateTime.ParseExact(l.ArrivalDate, "yyyyMMdd", System.Globalization.CultureInfo.InvariantCulture).ToShortDateString(),
                    //    ArrivalTime = z.ArrivalTime.Insert(2, ":"),
                    //    DepartureTime = z.DepartureTime.Insert(2, ":"),
                    //    Currency = "INR",
                    //    FlightFare = Convert.ToDecimal(iter.TotalLowestFare),
                    //    Baggage = z.Baggage,
                    //    Duration = z.Duration,
                    //    InterMediateStops = new Flight_Availability().GetInterstops(iter),
                    //    AirLineCode = z.AirlineCode,
                    //    DepartureDate = z.DepartureDate,
                    //    OLocCode = z.DepartureLocationCode,
                    //    ALocCode = z.ArrivalLocationCode,
                    //    Return = days,
                    //    UniqueId = uniqueid,
                    //    ImageUrl = z.AirlineLogo

                    //});

                    List <BirdResAWSBot.SBT.Request.Response.Flight> flights = iter.Flights;
                    iGroup = iGroup + 1;

                    int iSegment = 0;

                    foreach (BirdResAWSBot.SBT.Request.Response.Flight z in flights)
                    {
                        iSegment++;
                        customFlights.Add(new CustomFlightDetailModel
                        {
                            FlightNumber      = z.FlightNumber,
                            ArrivalAirport    = z.ArrivalAirportName,
                            DepAirport        = z.DepartureAirportName,
                            ArrivalDate       = z.ArrivalDate,// DateTime.ParseExact(l.ArrivalDate, "yyyyMMdd", System.Globalization.CultureInfo.InvariantCulture).ToShortDateString(),
                            ArrivalTime       = z.ArrivalTime.Insert(2, ":"),
                            DepartureTime     = z.DepartureTime.Insert(2, ":"),
                            Currency          = iter.PaxFares.CurrencyCode,
                            FlightFare        = Convert.ToDecimal(iter.TotalLowestFare),
                            Baggage           = z.Baggage,
                            Duration          = z.Duration,
                            InterMediateStops = new Flight_Availability().GetInterstops(iter),
                            AirLineCode       = z.AirlineCode,
                            DepartureDate     = z.DepartureDate,
                            OLocCode          = z.DepartureLocationCode,
                            ALocCode          = z.ArrivalLocationCode,
                            Return            = days,
                            UniqueId          = uniqueid,
                            ImageUrl          = z.AirlineLogo,
                            Group             = iGroup,
                            Direction         = z.DirectionInd,
                            AirlineName       = z.AirlineName,
                            Layover           = z.LayoverTime
                        });
                    }
                }



                qresult    = customFlights.Take(20).ToList();
                query.Date = null;
            }



            new PIT(customFlights.Take(20).ToList());



            var myitem = new UtteranceLog();

            myitem.query = query;


            IDictionary <string, object> changes = new Dictionary <string, object>();

            {
                changes.Add(DeviceId + "query", myitem);
            }
            System.Threading.CancellationToken s;
            EmptyBot._myStorage.WriteAsync(changes, s);

            return(qresult);
        }
コード例 #3
0
        public string BookFlight(JObject entities, string[] codes)
        {
            string         Result = "";
            SubmitResponse submitResponse;
            string         x = "";

            try
            {
                var bot = new EmptyBot();
                List <CustomFlightDetailModel> detail = bot.GetIteneraries();
                // new LoginIntent().Login(entities);
                List <CustomFlightDetailModel> iterlst = new List <CustomFlightDetailModel>();
                EmployeeModel employee = bot.GiveEmployee();
                if (entities.GetValue("FlightNumber") == null && codes.Length >= 1)
                {
                    foreach (var c in codes)
                    {
                        string code = c.Remove(0, 3);
                        iterlst.Add((from d in detail where d.FlightNumber == code select d).FirstOrDefault());
                    }
                }
                else
                {
                    string alcode = entities.GetValue("FlightNumber").FirstOrDefault().ToString().Substring(0, 2);
                    string fn     = entities.GetValue("FlightNumber").FirstOrDefault().ToString().Substring(2);
                    iterlst = (from d in detail where d.FlightNumber == fn select d).ToList();
                }

                WebRequest request = WebRequest.Create("http://online-corporate-traveller.amadeus.com/live/V17_2_0/webapi/api/SBTMobile/SubmitFlightRequest");
                request.Method      = "POST";
                request.ContentType = "application/json";
                Stream dataStream = request.GetRequestStream();

                // getJson(date, direct, type, quantity, origin, desti);
                // JObject abc = new SearchRequest().GetJson();
                x = new BookingJsons().GetSubmitBookRequest(iterlst, employee.FirstName, employee.OffId, employee.CustId, employee.TokenID, employee.DeviceId);
                byte[] byteArray = Encoding.UTF8.GetBytes(x);
                request.ContentLength = byteArray.Length;
                dataStream.Write(byteArray, 0, byteArray.Length);
                dataStream.Close();
                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                using (Stream receiveStream = Flight_Availability.GetStreamForResponse(response))
                {
                    StreamReader sr = new StreamReader(receiveStream);
                    string       responseFromServer = sr.ReadToEnd();

                    submitResponse = JsonConvert.DeserializeObject <SubmitResponse>(responseFromServer);

                    if (employee.Approval_mail == "FALSE")
                    {
                        Result = GetBookResult(employee, iterlst.FirstOrDefault(), submitResponse.TripID);
                    }
                    else
                    {
                        //SendDetail("TripId : " + submitResponse.TripID, employee.Email);
                        //return "Flight Details / Booking Details sent with tripid :"
                        Result = "Flight Details/Booking Details sent with tripid : " + submitResponse.TripID + " successfully on " + employee.Email;
                        //  await _myStorage.DeleteAsync(new string[] { (DeviceId + "employee"), (DeviceId + "pricedIteneraries") },cancellationToken);
                    }
                }
                dataStream.Close();
                response.Close();
            }
            catch (Exception ex)
            {
                // Result = ex.StackTrace + " " + x;
            }


            return(Result);
        }