Example #1
0
        static void Main(string[] args)
        {
            DB = DataBase.GetInstance();

            while (true)
            {
                foreach (var f in DB.Feeds.Where(i => i.LastChecked.AddMinutes(15) < DateTime.Now).AsParallel())
                {
                    try
                    {
                        foreach (var fi in FeedParser.Parse(new Uri(f.Url)))
                        {
                            try
                            {
                                FeedReader.Models.FeedItem nFeedItem = new FeedReader.Models.FeedItem
                                {
                                    FeedID = f.ID,
                                    Created = fi.PublicationDate,
                                    Description = PrepareString(fi.Description),
                                    Title = PrepareString(fi.Title),
                                    Url = fi.Link.ToString()
                                };

                                if (!DB.FeedItems.Any(i => i.Url == nFeedItem.Url && i.FeedID == f.ID))
                                {
                                    DB.FeedItems.InsertOnSubmit(nFeedItem);
                                    Console.WriteLine("{0}: {1}", f.Title, nFeedItem.Title);
                                }
                            }
                            catch (Exception e)
                            {
                                Console.WriteLine("Error occurred inserting {0}.", fi.Title.TrimEnd('.'));
                                Console.WriteLine(e);
                            }
                        }

                        f.LastChecked = DateTime.Now;
                    }
                    catch (Exception e)
                    {
                        Console.WriteLine("Failed to download or parse {0}.", f.Title);
                        Console.WriteLine(e);
                    }
                }

                try
                {
                    DB.SubmitChanges();
                    Thread.Sleep(30 * 1000);
                }
                catch (Exception e)
                {
                    Console.WriteLine("Error inserting feeds:");
                    Console.WriteLine(e.Message);
                    Thread.Sleep(10 * 1000);
                }

                DB.ClearInternalCache();
            }
        }
Example #2
0
        public ActionResult RegisterSubmit(string email, string password, string passwordAgain)
        {
            List<string> errors;
            if (Validator.IsValidUser(email, password, passwordAgain, out errors))
            {
                DB = DataBase.GetInstance();
                DB.Users.InsertOnSubmit(new Models.User { Email = email, PasswordHash = Classes.UserInfo.HashPassword(password), Registered = DateTime.Now });
                DB.SubmitChanges();
                UserInfo.LogIn(email, password);
            }

            return RedirectToAction("Index", "Home");
        }