use of com.enonic.xp.site.processor.ResponseProcessorDescriptors in project xp by enonic.
the class PostProcessingRenderer method executeResponseProcessors.
private PortalResponse executeResponseProcessors(final PortalRequest portalRequest, final PortalResponse portalResponse) {
final ResponseProcessorDescriptors filters = this.processorChainResolver.resolve(portalRequest);
if (!portalResponse.applyFilters() || filters.isEmpty()) {
return portalResponse;
}
PortalResponse filterResponse = portalResponse;
for (ResponseProcessorDescriptor filter : filters) {
final PortalResponse filterPortalResponse = filterResponse;
final Trace trace = Tracer.newTrace("renderFilter");
if (trace == null) {
filterResponse = processorExecutor.execute(filter, portalRequest, filterPortalResponse);
} else {
trace.put("app", filter.getApplication().toString());
trace.put("name", filter.getName());
trace.put("type", "filter");
filterResponse = Tracer.trace(trace, () -> processorExecutor.execute(filter, portalRequest, filterPortalResponse));
}
if (!filterResponse.applyFilters()) {
break;
}
}
return filterResponse;
}
use of com.enonic.xp.site.processor.ResponseProcessorDescriptors in project xp by enonic.
the class ProcessorChainResolverTest method testFilterChainResolver.
@Test
public void testFilterChainResolver() {
ApplicationKey ak1 = ApplicationKey.from("ak1");
SiteConfig sc1 = SiteConfig.create().application(ak1).config(new PropertyTree()).build();
ApplicationKey ak2 = ApplicationKey.from("ak2");
SiteConfig sc2 = SiteConfig.create().application(ak2).config(new PropertyTree()).build();
ApplicationKey ak3 = ApplicationKey.from("ak3");
SiteConfig sc3 = SiteConfig.create().application(ak3).config(new PropertyTree()).build();
portalRequest.setSite(Site.create().siteConfigs(SiteConfigs.from(sc1, sc2, sc3)).name("Site").path("/site").parentPath(ContentPath.ROOT).build());
ResponseProcessorDescriptor fd12 = ResponseProcessorDescriptor.create().application(ak1).name("ak1-2").order(2).build();
ResponseProcessorDescriptor fd13 = ResponseProcessorDescriptor.create().application(ak1).name("ak1-3").order(3).build();
ResponseProcessorDescriptor fd15 = ResponseProcessorDescriptor.create().application(ak1).name("ak1-5").order(5).build();
SiteDescriptor sd1 = SiteDescriptor.create().responseProcessors(ResponseProcessorDescriptors.from(fd13, fd15, fd12)).build();
Mockito.when(siteService.getDescriptor(Mockito.eq(ak1))).thenReturn(sd1);
ResponseProcessorDescriptor fd21 = ResponseProcessorDescriptor.create().application(ak2).name("ak2-1").order(1).build();
ResponseProcessorDescriptor fd22 = ResponseProcessorDescriptor.create().application(ak2).name("ak1-2").order(2).build();
ResponseProcessorDescriptor fd23 = ResponseProcessorDescriptor.create().application(ak2).name("ak2-3").order(3).build();
SiteDescriptor sd2 = SiteDescriptor.create().responseProcessors(ResponseProcessorDescriptors.from(fd22, fd23, fd21)).build();
Mockito.when(siteService.getDescriptor(Mockito.eq(ak2))).thenReturn(sd2);
ResponseProcessorDescriptor fd32 = ResponseProcessorDescriptor.create().application(ak3).name("ak3-2").order(2).build();
SiteDescriptor sd3 = SiteDescriptor.create().responseProcessors(ResponseProcessorDescriptors.from(fd32)).build();
Mockito.when(siteService.getDescriptor(Mockito.eq(ak3))).thenReturn(sd3);
ResponseProcessorDescriptors filters = resolver.resolve(portalRequest);
assertEquals(7, filters.getSize());
ResponseProcessorDescriptor fd = filters.get(0);
assertEquals(1, fd.getOrder());
assertEquals(ak2, fd.getApplication());
fd = filters.get(1);
assertEquals(2, fd.getOrder());
assertEquals(ak1, fd.getApplication());
fd = filters.get(2);
assertEquals(2, fd.getOrder());
assertEquals(ak2, fd.getApplication());
fd = filters.get(3);
assertEquals(2, fd.getOrder());
assertEquals(ak3, fd.getApplication());
fd = filters.get(4);
assertEquals(3, fd.getOrder());
assertEquals(ak1, fd.getApplication());
fd = filters.get(5);
assertEquals(3, fd.getOrder());
assertEquals(ak2, fd.getApplication());
fd = filters.get(6);
assertEquals(5, fd.getOrder());
assertEquals(ak1, fd.getApplication());
}
Aggregations