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); }
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); }
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); }