001/* 002 * Copyright 2010 Anyware Services 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016package org.ametys.web.indexing.observation; 017 018import java.util.Map; 019 020import org.ametys.cms.content.indexing.solr.observation.ObserverHelper; 021import org.ametys.core.observation.Event; 022import org.ametys.core.observation.Observer; 023import org.ametys.web.ObservationConstants; 024import org.ametys.web.repository.page.Page; 025import org.ametys.web.repository.page.SitemapElement; 026import org.ametys.web.repository.page.ZoneItem; 027 028/** 029 * {@link Observer} for observing page creation or modification in order to 030 * synchronize Solr index associated. 031 */ 032public class SolrPageChangePart1Observer extends AbstractSolrObserver 033{ 034 @Override 035 public boolean supports(Event event) 036 { 037 String id = event.getId(); 038 return id.equals(ObservationConstants.EVENT_PAGE_CHANGED) 039 || id.equals(ObservationConstants.EVENT_ZONEITEM_ADDED) 040 || id.equals(ObservationConstants.EVENT_ZONEITEM_MOVED) 041 || id.equals(ObservationConstants.EVENT_ZONEITEM_DELETED) 042 || id.equals(ObservationConstants.EVENT_ZONEITEM_MODIFIED); 043 } 044 045 @Override 046 public int getPriority(Event event) 047 { 048 // Will be processed BEFORE live synchronization observers, since pages have to be present in live to be unindexed 049 return MAX_PRIORITY + 500; 050 } 051 052 @Override 053 public void observe(Event event, Map<String, Object> transientVars) throws Exception 054 { 055 if (ObserverHelper.isNotSuspendedObservationForIndexation()) 056 { 057 Page page = _getPage(event); 058 if (page != null) 059 { 060 _solrPageIndexer.unindexPage(page.getId(), true, false); 061 } 062 } 063 } 064 065 private Page _getPage(Event event) 066 { 067 Page page = (Page) event.getArguments().get(ObservationConstants.ARGS_PAGE); 068 SitemapElement sitemapElement = (SitemapElement) event.getArguments().get(ObservationConstants.ARGS_SITEMAP_ELEMENT); 069 ZoneItem zoneItem = (ZoneItem) event.getArguments().get(ObservationConstants.ARGS_ZONE_ITEM); 070 071 if (page != null) 072 { 073 return page; 074 } 075 else if (sitemapElement != null && sitemapElement instanceof Page sitemapPage) 076 { 077 return sitemapPage; 078 } 079 else if (zoneItem != null && zoneItem.getZone().getSitemapElement() instanceof Page zoneItemPage) 080 { 081 return zoneItemPage; 082 } 083 else 084 { 085 return null; 086 } 087 } 088}