Search in sources :

Example 1 with ResponseProcessorDescriptors

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;
}
Also used : Trace(com.enonic.xp.trace.Trace) PortalResponse(com.enonic.xp.portal.PortalResponse) ResponseProcessorDescriptor(com.enonic.xp.site.processor.ResponseProcessorDescriptor) ResponseProcessorDescriptors(com.enonic.xp.site.processor.ResponseProcessorDescriptors)

Example 2 with ResponseProcessorDescriptors

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());
}
Also used : SiteDescriptor(com.enonic.xp.site.SiteDescriptor) ApplicationKey(com.enonic.xp.app.ApplicationKey) ResponseProcessorDescriptor(com.enonic.xp.site.processor.ResponseProcessorDescriptor) PropertyTree(com.enonic.xp.data.PropertyTree) SiteConfig(com.enonic.xp.site.SiteConfig) ResponseProcessorDescriptors(com.enonic.xp.site.processor.ResponseProcessorDescriptors) Test(org.junit.jupiter.api.Test)

Aggregations

ResponseProcessorDescriptor (com.enonic.xp.site.processor.ResponseProcessorDescriptor)2 ResponseProcessorDescriptors (com.enonic.xp.site.processor.ResponseProcessorDescriptors)2 ApplicationKey (com.enonic.xp.app.ApplicationKey)1 PropertyTree (com.enonic.xp.data.PropertyTree)1 PortalResponse (com.enonic.xp.portal.PortalResponse)1 SiteConfig (com.enonic.xp.site.SiteConfig)1 SiteDescriptor (com.enonic.xp.site.SiteDescriptor)1 Trace (com.enonic.xp.trace.Trace)1 Test (org.junit.jupiter.api.Test)1