Example #1
0
        /// <summary>
        /// Page의 ViewState 정보를 특정 저장소에 저장하고, 저장 토큰 값을 <see cref="AbstractServerPageStatePersister.StateValue"/>에 저장합니다.
        /// </summary>
        protected override void SaveToRepository()
        {
            if (IsDebugEnabled)
            {
                log.Debug("Page 상태정보를 저장합니다...");
            }

            RemoveExpires(Expiration);

            var pageState = new Pair(ViewState, ControlState);

            if (StateValue.IsWhiteSpace())
            {
                StateValue = Guid.NewGuid().ToString();
            }

            var stateEntity = (PageStateEntity)PageStateTool.CreateStateEntity(StateValue, pageState, Compressor, CompressThreshold);

            using (var repository = CreateRepository()) {
                var query   = Query.EQ(MongoTool.IdString, stateEntity.Id);
                var updated = Update.Set("Value", stateEntity.Value).Set("IsCompressed", stateEntity.IsCompressed).Set("CreatedDate",
                                                                                                                       stateEntity.
                                                                                                                       CreatedDate);

                // UPSERT
                var result = repository.FindAndModify(query, SortBy.Null, updated, true, true);

                if (IsDebugEnabled)
                {
                    log.Debug("캐시에 Page 상태정보를 저장했습니다!!! StateValue=[{0}], Expiration=[{1}] (min), Result=[{2}]", StateValue, Expiration,
                              result.Ok);
                }
            }
        }
Example #2
0
        /// <summary>
        /// ViewState 저장소로부터 저장된 ViewState 정보를 가져옵니다.
        /// </summary>
        protected override void LoadFromRepository()
        {
            if (IsDebugEnabled)
            {
                log.Debug("저장소에서 키에 해당하는 상태정보 로드를 시작합니다... StateValue=[{0}]", StateValue);
            }

            if (StateValue.IsWhiteSpace())
            {
                return;
            }

            RemoveExpires(Expiration);

            using (var repository = CreateRepository()) {
                var stateEntity = repository.FindOneByIdAs <PageStateEntity>(StateValue);

                if (stateEntity != null)
                {
                    object pageState;

                    if (PageStateTool.TryParseStateEntity(stateEntity, Compressor, out pageState))
                    {
                        ViewState    = ((Pair)pageState).First;
                        ControlState = ((Pair)pageState).Second;

                        if (IsDebugEnabled)
                        {
                            log.Debug("저장된 상태정보를 로드하여, Page의 ViewState, ControlState에 설정했습니다!!!");
                        }
                    }
                    else
                    {
                        throw new InvalidOperationException("저장된 정보를 로드하였지만, ViewState로 Parsing하는데 실패했습니다.");
                    }
                }
                else
                {
                    if (IsDebugEnabled)
                    {
                        log.Debug("상태정보를 조회하지 못했습니다. StateValue=[{0}]", StateValue);
                    }
                }
            }
        }