public ActionResult Create(CreateCreditModel credit) { if (ModelState.IsValid) { try { CreditService.Create(Mapper.Map <CreateCreditModel, CreditModel>(credit), credit.CreateCreditCard); return(RedirectToAction("Index")); } catch (Exception ex) { ModelState.AddModelError("", ex.Message); return(View(credit.ToCreateCreditModel(PlanOfCreditService, ClientService))); } } return(View(credit.ToCreateCreditModel(PlanOfCreditService, ClientService))); }
public IActionResult MovieResult(string imdbId) { WebRequest request; HttpWebResponse response; string result = null; string api = "api_key=8d8ebd7ef7cb1361e624639ac8fea328"; string finalResponse = ""; string getImdbIdUrl = String.Format("https://api.themoviedb.org/3/find/" + imdbId + "?" + api + "&external_source=imdb_id"); request = WebRequest.Create(getImdbIdUrl); request.Method = "GET"; response = (HttpWebResponse)request.GetResponse(); using (Stream streamImdb = response.GetResponseStream()) { StreamReader streamReaderImdb = new StreamReader(streamImdb); result = streamReaderImdb.ReadToEnd(); streamReaderImdb.Close(); } ImdbMovieResult imdbMovieResult = JsonConvert.DeserializeObject <ImdbMovieResult>(result); int tmdbId = imdbMovieResult.movie_results.FirstOrDefault().id; bool isThereAnyMovie = _movieService.IsItExistsByTmdbId(tmdbId); if (isThereAnyMovie) { finalResponse += "This movie already exists in the Database!"; } else { string getTmdbIdUrl = String.Format("https://api.themoviedb.org/3/movie/" + tmdbId + "?" + api + "&language=en-US"); request = WebRequest.Create(getTmdbIdUrl); response = (HttpWebResponse)request.GetResponse(); using (Stream streamTmdb = response.GetResponseStream()) { StreamReader streamReaderTmdb = new StreamReader(streamTmdb); result = streamReaderTmdb.ReadToEnd(); streamReaderTmdb.Close(); } TmdbMovieResult tmdbMovieResult = JsonConvert.DeserializeObject <TmdbMovieResult>(result); bool isMovieCreated = _movieService.Create(tmdbMovieResult); if (isMovieCreated) { finalResponse += "Movie were inserted into the Database!"; } else { finalResponse += "Some error!"; } } bool isThereAnyCredits = _creditService.IsItExistsByTmdbId(tmdbId); if (isThereAnyCredits) { finalResponse += "\nThese credits already exists in the Database!"; } else { string getCreditsIdUrl = String.Format("https://api.themoviedb.org/3/movie/" + tmdbId + "/credits?" + api); request = WebRequest.Create(getCreditsIdUrl); response = (HttpWebResponse)request.GetResponse(); using (Stream streamCredits = response.GetResponseStream()) { StreamReader streamReaderCredits = new StreamReader(streamCredits); result = streamReaderCredits.ReadToEnd(); streamReaderCredits.Close(); } MovieCredits movieCredits = JsonConvert.DeserializeObject <MovieCredits>(result); bool isCreditsCreated = _creditService.Create(movieCredits); if (isCreditsCreated) { finalResponse += "Credites were inserted into the Database!"; } else { finalResponse += "Some error!"; } //int counter = 0; //foreach (var cast in movieCredits.cast) //{ // bool isThereAnyPersonImegas = _personImagesService.IsItExistsByPersonId(cast.id); // if (isThereAnyPersonImegas) // continue; // else // counter++; // string getPersonImageIdUrl = String.Format("https://api.themoviedb.org/3/person/" + cast.id + "/images?" + api); // request = WebRequest.Create(getPersonImageIdUrl); // response = (HttpWebResponse)request.GetResponse(); // using (Stream streamPersonImages = response.GetResponseStream()) // { // StreamReader streamReaderPersonImages = new StreamReader(streamPersonImages); // result = streamReaderPersonImages.ReadToEnd(); // streamReaderPersonImages.Close(); // } // PersonImages personImages = JsonConvert.DeserializeObject<PersonImages>(result); // var orderedPersonImages = personImages.profiles.OrderByDescending(x => x.vote_average).ToList(); // personImages.profiles = orderedPersonImages; // personImages.id = cast.id; // bool isPersonImagesCreated = _personImagesService.Create(personImages); //} int personDetailsCounter = 0; foreach (var cast in movieCredits.cast) { bool isThereAnyPersonDetails = _personService.IsItExistsByPersonId(cast.id); if (isThereAnyPersonDetails) { continue; } else { personDetailsCounter++; } string getPersonDetailsIdUrl = String.Format("https://api.themoviedb.org/3/person/" + cast.id + "?" + api + "&language=en-US"); request = WebRequest.Create(getPersonDetailsIdUrl); response = (HttpWebResponse)request.GetResponse(); using (Stream streamPersonDetails = response.GetResponseStream()) { StreamReader streamReaderPersonDetails = new StreamReader(streamPersonDetails); result = streamReaderPersonDetails.ReadToEnd(); streamReaderPersonDetails.Close(); } PersonDetails personDetails = JsonConvert.DeserializeObject <PersonDetails>(result); bool isPersonImagesCreated = _personService.Create(personDetails); } finalResponse += "\n" + personDetailsCounter + " actor profiles were inserted into the Database!"; } return(Ok(JsonConvert.SerializeObject(finalResponse))); }
public ActionResult <Credit> Create(Credit credit) { _creditService.Create(credit); return(CreatedAtRoute("GetCredit", new { id = credit.Id.ToString() }, credit)); }