Ejemplo n.º 1
0
        public static SimpilyForumCacheItem GetForumInfo(this IPublishedContent item)
        {
            var cacheName = string.Format("simpilyforum_{0}", item.Id);
            var cache     = UmbracoContext.Current.Application.ApplicationCache;
            var forumInfo = cache.GetCacheItem <SimpilyForumCacheItem>(cacheName);

            if (forumInfo != null)
            {
                return(forumInfo);
            }

            Stopwatch sw = new Stopwatch();

            sw.Start();

            // not in the cache, we have to make it.
            forumInfo = new SimpilyForumCacheItem();

            var posts = item.DescendantsOrSelf().Where(x => x.IsVisible() && x.DocumentTypeAlias == "Simpilypost");

            forumInfo.Count = posts.Count();
            if (posts.Any())
            {
                var lastPost = posts.OrderByDescending(x => x.UpdateDate).FirstOrDefault();
                forumInfo.latestPost = lastPost.UpdateDate;
            }

            cache.InsertCacheItem <SimpilyForumCacheItem>(cacheName, CacheItemPriority.Default, () => forumInfo);

            sw.Stop();
            LogHelper.Info <SimpilyForumCacheHandler>("Updated Cache for {0} [{1}] found {2} items in {3}ms",
                                                      () => item.Name, () => item.Id, () => forumInfo.Count, () => sw.ElapsedMilliseconds);

            return(forumInfo);
        }
Ejemplo n.º 2
0
        /// <summary>
        ///  Get the Forum Info - using examine, because that can be faster when
        ///  there are lots and lots of posts - although i've yet to see it
        ///  really get faster than the traverse method (yet)
        /// </summary>
        /// <param name="useExamine">true to use examine</param>
        public static SimpilyForumCacheItem GetForumInfo(this IPublishedContent item, bool useExamine)
        {
            if (useExamine == false)
            {
                return(GetForumInfo(item));
            }

            var cacheName = string.Format("simpilyforum_{0}", item.Id);
            var cache     = UmbracoContext.Current.Application.ApplicationCache;
            var forumInfo = cache.GetCacheItem <SimpilyForumCacheItem>(cacheName);

            if (forumInfo != null)
            {
                return(forumInfo);
            }

            Stopwatch sw = new Stopwatch();

            sw.Start();

            forumInfo = new SimpilyForumCacheItem();


            // examine cache - because that's faster ?
            var searcher       = ExamineManager.Instance.SearchProviderCollection["InternalSearcher"];
            var searchCriteria = searcher.CreateSearchCriteria(UmbracoExamine.IndexTypes.Content);

            var query = new StringBuilder();

            query.AppendFormat("-{0}:1 ", "umbracoNaviHide");
            query.AppendFormat("+__NodeTypeAlias:simpilypost +path:\\-1*{0}*", item.Id);

            var filter  = searchCriteria.RawQuery(query.ToString());
            var results = searcher.Search(filter).OrderByDescending(x => x.Fields["updateDate"]);

            forumInfo.Count      = results.ToList().Count;
            forumInfo.latestPost = DateTime.MinValue;

            if (results.Any())
            {
                var update = DateTime.ParseExact(results.First().Fields["updateDate"], "yyyyMMddHHmmssfff", CultureInfo.CurrentCulture);
                if (update > DateTime.MinValue)
                {
                    forumInfo.latestPost = update;
                }

                foreach (var field in results.First().Fields)
                {
                    LogHelper.Info <SimpilyForumCacheHandler>("Field: {0} {1}", () => field.Key, () => field.Value);
                }
            }
            cache.InsertCacheItem <SimpilyForumCacheItem>(cacheName, CacheItemPriority.Default, () => forumInfo);

            sw.Stop();
            LogHelper.Info <SimpilyForumCacheHandler>("Updated Cache (using Examine) for {0} [{1}] found {2} items in {3}ms",
                                                      () => item.Name, () => item.Id, () => forumInfo.Count, () => sw.ElapsedMilliseconds);

            return(forumInfo);
        }
Ejemplo n.º 3
0
        public static SimpilyForumCacheItem GetForumInfo(this IPublishedContent item)
        {
            var cacheName = string.Format("simpilyforum_{0}", item.Id);
            var cache = UmbracoContext.Current.Application.ApplicationCache;
            var forumInfo = cache.GetCacheItem<SimpilyForumCacheItem>(cacheName);

            if (forumInfo != null)
                return forumInfo;

            Stopwatch sw = new Stopwatch();
            sw.Start();

            // not in the cache, we have to make it.
            forumInfo = new SimpilyForumCacheItem();

            var posts = item.DescendantsOrSelf().Where(x => x.IsVisible() && x.DocumentTypeAlias == "Simpilypost");

            forumInfo.Count = posts.Count();
            if (posts.Any())
            {
                var lastPost = posts.OrderByDescending(x => x.UpdateDate).FirstOrDefault();
                forumInfo.latestPost = lastPost.UpdateDate;
            }

            cache.InsertCacheItem<SimpilyForumCacheItem>(cacheName, CacheItemPriority.Default, () => forumInfo);

            sw.Stop();
            LogHelper.Info<SimpilyForumCacheHandler>("Updated Cache for {0} [{1}] found {2} items in {2}ms",
                () => item.Name, () => item.Id, ()=> forumInfo.Count, ()=> sw.ElapsedMilliseconds);

            return forumInfo;
        }