コード例 #1
0
 public FbPostManager(IWebDriver driver, SfxConfiguration sfx)
 {
     _driver = driver;
     _sfx    = sfx;
 }
コード例 #2
0
        public static void Main()
        {
            _logger.Info(" ============== FACEGROUP ==============");
            PrintConfiguration();

            var options = new ChromeOptions();

            options.AddArgument("--disable-notifications");
            string sfxPath = Directory.GetCurrentDirectory() + @"\social-fixer-for-facebook";

            //options.AddArgument(@"--load-extension="+sfxPath);
            options.AddExtensions();
            var driver = new ChromeDriver("selenium", options);
            var sfx    = new SfxConfiguration(ConfigurationManager.AppSettings["SfxConfigurationFile"]);

            bool reverseGroupOrder = ConfigurationManager.AppSettings["ReverseGroupOrder"].ToUpper() == "ON" ? true : false;

            AdminLogin(driver);
            FacebookLogin(driver);

            var groupManager = new FbGroupManager(driver);
            var postManager  = new FbPostManager(driver, sfx);

            IEnumerable <FbGroup> unreadGroups = groupManager.GetUnreadGroups();

            if (reverseGroupOrder)
            {
                _logger.Info($"Обработка на {unreadGroups.Count()} групи с непрочетени публикации в ОБРАТЕН ред");
                foreach (var fbGroup in unreadGroups)
                {
                    _logger.Info($"------------------- Обработка на група: {fbGroup.ToString()} -----------------------");
                    try
                    {
                        IEnumerable <IWebElement> postsEl = groupManager.GetPosts(fbGroup);
                        _logger.Info($"{postsEl.Count()} поста за обработка в група {fbGroup.ToString()}");
                        int countPostsInGroupSuccess = 0;
                        int countPostsInGroupFail    = 0;
                        foreach (var postEl in postsEl)
                        {
                            var fbPost = new FbPost(postEl);
                            _logger.Info($"Обработка на пост: {fbPost.ToString()}");
                            try
                            {
                                postManager.ProcessPostElement(postEl);
                                countPostsInGroupSuccess++;
                            }
                            catch (Exception postEx)
                            {
                                _logger.Error(postEx, $"Грешка при обработка на пост: {fbPost}");
                                countPostsInGroupFail++;
                            }
                        }
                        _logger.Info($"Общо за групата: {countPostsInGroupSuccess} успешно обработени и {countPostsInGroupFail} неуспешни");
                    }
                    catch (Exception ex)
                    {
                        _logger.Error(ex, $"Грешка при обработка на група '{fbGroup.GroupName}' - {fbGroup.GroupUrl}");
                        continue;
                    }
                } // end foreach group
            }
            else
            {
                _logger.Info($"Обработка на {unreadGroups.Count()} групи с непрочетени публикации в НОРМАЛЕН ред");
                foreach (var fbGroup in unreadGroups)
                {
                    _logger.Info($"------------------- Обработка на група: {fbGroup.ToString()} -----------------------");
                    try
                    {
                        IEnumerable <IWebElement> postsEl = groupManager.GetPosts(fbGroup);
                        _logger.Info($"{postsEl.Count()} поста за обработка в група {fbGroup.ToString()}");
                        int countPostsInGroupSuccess = 0;
                        int countPostsInGroupFail    = 0;
                        foreach (var postEl in postsEl)
                        {
                            var fbPost = new FbPost(postEl);
                            _logger.Info($"Обработка на пост: {fbPost.ToString()}");
                            try
                            {
                                postManager.ProcessPostElement(postEl);
                                countPostsInGroupSuccess++;
                            }
                            catch (Exception postEx)
                            {
                                _logger.Error(postEx, $"Грешка при обработка на пост: {fbPost}");
                                countPostsInGroupFail++;
                            }
                        }
                        _logger.Info($"Общо за групата: {countPostsInGroupSuccess} успешно обработени и {countPostsInGroupFail} неуспешни");
                    }
                    catch (Exception ex)
                    {
                        _logger.Error(ex, $"Грешка при обработка на група '{fbGroup.GroupName}' - {fbGroup.GroupUrl}");
                        continue;
                    }
                } // end foreach group
            }
        }