Ejemplo n.º 1
0
        public static void Start()
        {
            Words = new Models.WordsList();
            JObject dd = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Vulgar.json")));

            Words.Vulgar = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("vulgar").ToString());

            dd         = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Ugly.json")));
            Words.Ugly = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("ugly").ToString());

            dd             = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Positive.json")));
            Words.Positive = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("positive").ToString());

            dd = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Offensive.json")));
            Words.Offensive = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("offensive").ToString());

            dd             = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Negative.json")));
            Words.Negative = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("negative").ToString());

            dd           = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Insult.json")));
            Words.Insult = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("insult").ToString());

            dd          = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Harsh.json")));
            Words.Harsh = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("harsh").ToString());

            dd = JsonConvert.DeserializeObject <JObject>(File.ReadAllText(Path.Combine(pPath, "Apologizing.json")));
            Words.Apologize = JsonConvert.DeserializeObject <List <string> >(dd.GetValue("apologize").ToString());

            Rank          = JsonConvert.DeserializeObject <Models.Ranking>(File.ReadAllText(Path.Combine(System.Web.Hosting.HostingEnvironment.MapPath("~/App_Data"), "config.json")));
            Rank.TextRank = Rank.TextRank.OrderBy(t => t.WordPercentage).Select(t => t).ToList();
        }
Ejemplo n.º 2
0
        /// <summary>
        /// Returns a paginated collection of ranking objects order by rank descending
        /// </summary>
        /// <param name="pageIndex">The offset to begin returning result from</param>
        /// <param name="pageCount">The total number of results to return</param>
        /// <returns>Collection of Models.Ranking objects</returns>
        public Models.RequestResult <IEnumerable <Models.Ranking> > Get(int pageIndex, int pageCount)
        {
            try
            {
                //we get the latest ranking list by the last ranking job that was completed
                var latestJob = Context.RankingJobs.Where(j => j.State == Data.RankingJobStates.Finished)
                                .OrderByDescending(j => j.FinishedOn).FirstOrDefault();

                if (latestJob == null)
                {
                    //no ranking jobs have yet been run, return empty list
                    return(Models.RequestResult <IEnumerable <Models.Ranking> > .GetSuccess(StatusCodes.Status204NoContent, null));
                }

                var totalPages = (int)Math.Ceiling(decimal.Divide(Context.Rankings.Where(r => r.RankingJobId == latestJob.Id).Count(), pageCount));
                var results    = Context.Rankings.Where(r => r.RankingJobId == latestJob.Id)
                                 .OrderBy(r => r.Rank)
                                 .Skip(pageIndex * pageCount).Take(pageCount)
                                 .Include(r => r.Player)
                                 .ToList();

                var rankings = new List <Models.Ranking>();

                foreach (var result in results)
                {
                    var ranking = new Models.Ranking();
                    ranking.Player   = result.Player.GetName();
                    ranking.PlayerId = result.PlayerId;
                    ranking.Rank     = result.Rank;

                    rankings.Add(ranking);
                }

                return(Models.RequestResult <IEnumerable <Models.Ranking> > .GetSuccess(rankings, totalPages));
            }
            catch (Exception)
            {
                return(Models.RequestResult <IEnumerable <Models.Ranking> > .GetFail(StatusCodes.Status500InternalServerError, null));
            }
        }