Search in sources :

Example 1 with ListenerDTO

use of org.osgi.service.http.runtime.dto.ListenerDTO in project felix by apache.

the class HttpServicePlugin method printConfiguration.

/**
 * @see org.apache.felix.webconsole.ConfigurationPrinter#printConfiguration(java.io.PrintWriter)
 */
public void printConfiguration(final PrintWriter pw) {
    final RuntimeDTO dto = this.runtime.getRuntimeDTO();
    pw.println("HTTP Service Details");
    pw.println("====================");
    pw.println();
    pw.println("Runtime Properties");
    pw.println("------------------");
    for (final Map.Entry<String, Object> prop : dto.serviceDTO.properties.entrySet()) {
        pw.print(prop.getKey());
        pw.print(" : ");
        pw.println(getValueAsString(prop.getValue()));
    }
    pw.println();
    for (final ServletContextDTO ctxDto : dto.servletContextDTOs) {
        pw.print("Servlet Context ");
        pw.println(ctxDto.name);
        pw.println("-----------------------------------------------");
        pw.print("Path : ");
        pw.println(getContextPath(ctxDto.contextPath));
        printServiceIdAndRanking(pw, this.getServiceReference(ctxDto.serviceId), ctxDto.serviceId);
        pw.println();
        if (ctxDto.servletDTOs.length > 0) {
            pw.println("Servlets");
            for (final ServletDTO servlet : ctxDto.servletDTOs) {
                pw.print("Patterns : ");
                pw.println(getValueAsString(servlet.patterns));
                pw.print("Name : ");
                pw.println(servlet.name);
                final ServiceReference<?> ref = this.getServiceReference(servlet.serviceId);
                printServiceIdAndRanking(pw, ref, servlet.serviceId);
                pw.print("async : ");
                pw.println(String.valueOf(servlet.asyncSupported));
                if (ref != null) {
                    pw.print("Bundle : ");
                    pw.print(ref.getBundle().getSymbolicName());
                    pw.print(" <");
                    pw.print(String.valueOf(ref.getBundle().getBundleId()));
                    pw.println(">");
                }
                pw.println();
            }
            pw.println();
        }
        if (ctxDto.filterDTOs.length > 0) {
            pw.println("Filters");
            for (final FilterDTO filter : ctxDto.filterDTOs) {
                final List<String> patterns = new ArrayList<>();
                patterns.addAll(Arrays.asList(filter.patterns));
                patterns.addAll(Arrays.asList(filter.regexs));
                for (final String name : filter.servletNames) {
                    patterns.add("Servlet : " + name);
                }
                Collections.sort(patterns);
                pw.print("Patterns : ");
                pw.println(patterns);
                pw.print("Name : ");
                pw.println(filter.name);
                final ServiceReference<?> ref = this.getServiceReference(filter.serviceId);
                printServiceIdAndRanking(pw, ref, filter.serviceId);
                pw.print("async : ");
                pw.println(String.valueOf(filter.asyncSupported));
                pw.print("dispatcher : ");
                pw.println(getValueAsString(filter.dispatcher));
                if (ref != null) {
                    pw.print("Bundle : ");
                    pw.print(ref.getBundle().getSymbolicName());
                    pw.print(" <");
                    pw.print(String.valueOf(ref.getBundle().getBundleId()));
                    pw.println(">");
                }
                pw.println();
            }
            pw.println();
        }
        if (ctxDto.resourceDTOs.length > 0) {
            pw.println("Resources");
            for (final ResourceDTO rsrc : ctxDto.resourceDTOs) {
                pw.print("Patterns : ");
                pw.println(getValueAsString(rsrc.patterns));
                pw.print("Prefix : ");
                pw.println(rsrc.prefix);
                final ServiceReference<?> ref = this.getServiceReference(rsrc.serviceId);
                printServiceIdAndRanking(pw, ref, rsrc.serviceId);
                if (ref != null) {
                    pw.print("Bundle : ");
                    pw.print(ref.getBundle().getSymbolicName());
                    pw.print(" <");
                    pw.print(String.valueOf(ref.getBundle().getBundleId()));
                    pw.println(">");
                }
                pw.println();
            }
            pw.println();
        }
        if (ctxDto.errorPageDTOs.length > 0) {
            pw.println("Error Pages");
            for (final ErrorPageDTO ep : ctxDto.errorPageDTOs) {
                final List<String> patterns = new ArrayList<>();
                for (final long p : ep.errorCodes) {
                    patterns.add(String.valueOf(p));
                }
                for (final String p : ep.exceptions) {
                    patterns.add(p);
                }
                pw.print("Patterns : ");
                pw.println(patterns);
                pw.print("Name : ");
                pw.println(ep.name);
                final ServiceReference<?> ref = this.getServiceReference(ep.serviceId);
                printServiceIdAndRanking(pw, ref, ep.serviceId);
                pw.print("async : ");
                pw.println(String.valueOf(ep.asyncSupported));
                if (ref != null) {
                    pw.print("Bundle : ");
                    pw.print(ref.getBundle().getSymbolicName());
                    pw.print(" <");
                    pw.print(String.valueOf(ref.getBundle().getBundleId()));
                    pw.println(">");
                }
                pw.println();
            }
            pw.println();
        }
        if (ctxDto.listenerDTOs.length > 0) {
            pw.println("Listeners");
            for (final ListenerDTO ep : ctxDto.listenerDTOs) {
                pw.print("Types : ");
                pw.println(getValueAsString(ep.types));
                final ServiceReference<?> ref = this.getServiceReference(ep.serviceId);
                printServiceIdAndRanking(pw, ref, ep.serviceId);
                if (ref != null) {
                    pw.print("Bundle : ");
                    pw.print(ref.getBundle().getSymbolicName());
                    pw.print(" <");
                    pw.print(String.valueOf(ref.getBundle().getBundleId()));
                    pw.println(">");
                }
                pw.println();
            }
            pw.println();
        }
        pw.println();
    }
    if (dto.failedServletContextDTOs.length > 0) {
        for (final FailedServletContextDTO ctxDto : dto.failedServletContextDTOs) {
            pw.print("Failed Servlet Context ");
            pw.println(ctxDto.name);
            pw.println("-----------------------------------------------");
            pw.print("Reason : ");
            pw.println(getErrorText(ctxDto.failureReason));
            pw.print("Path : ");
            pw.println(getContextPath(ctxDto.contextPath));
            printServiceIdAndRanking(pw, this.getServiceReference(ctxDto.serviceId), ctxDto.serviceId);
            pw.println();
        }
    }
    if (dto.failedServletDTOs.length > 0) {
        pw.println("Failed Servlets");
        for (final FailedServletDTO servlet : dto.failedServletDTOs) {
            pw.print("Patterns : ");
            pw.println(getValueAsString(servlet.patterns));
            pw.print("Reason : ");
            pw.println(getErrorText(servlet.failureReason));
            pw.print("Name : ");
            pw.println(servlet.name);
            final ServiceReference<?> ref = this.getServiceReference(servlet.serviceId);
            printServiceIdAndRanking(pw, ref, servlet.serviceId);
            pw.print("async : ");
            pw.println(String.valueOf(servlet.asyncSupported));
            if (ref != null) {
                pw.print("Bundle : ");
                pw.print(ref.getBundle().getSymbolicName());
                pw.print(" <");
                pw.print(String.valueOf(ref.getBundle().getBundleId()));
                pw.println(">");
            }
            pw.println();
        }
        pw.println();
    }
    if (dto.failedFilterDTOs.length > 0) {
        pw.println("Failed Filters");
        for (final FailedFilterDTO filter : dto.failedFilterDTOs) {
            final List<String> patterns = new ArrayList<>();
            patterns.addAll(Arrays.asList(filter.patterns));
            patterns.addAll(Arrays.asList(filter.regexs));
            for (final String name : filter.servletNames) {
                patterns.add("Servlet : " + name);
            }
            Collections.sort(patterns);
            pw.print("Patterns : ");
            pw.println(patterns);
            pw.print("Reason : ");
            pw.println(getErrorText(filter.failureReason));
            pw.print("Name : ");
            pw.println(filter.name);
            final ServiceReference<?> ref = this.getServiceReference(filter.serviceId);
            printServiceIdAndRanking(pw, ref, filter.serviceId);
            pw.print("async : ");
            pw.println(String.valueOf(filter.asyncSupported));
            pw.print("dispatcher : ");
            pw.println(getValueAsString(filter.dispatcher));
            if (ref != null) {
                pw.print("Bundle : ");
                pw.print(ref.getBundle().getSymbolicName());
                pw.print(" <");
                pw.print(String.valueOf(ref.getBundle().getBundleId()));
                pw.println(">");
            }
            pw.println();
        }
        pw.println();
    }
    if (dto.failedResourceDTOs.length > 0) {
        pw.println("Failed Resources");
        for (final FailedResourceDTO rsrc : dto.failedResourceDTOs) {
            pw.print("Patterns : ");
            pw.println(getValueAsString(rsrc.patterns));
            pw.print("Reason : ");
            pw.println(getErrorText(rsrc.failureReason));
            pw.print("Prefix : ");
            pw.println(rsrc.prefix);
            final ServiceReference<?> ref = this.getServiceReference(rsrc.serviceId);
            printServiceIdAndRanking(pw, ref, rsrc.serviceId);
            if (ref != null) {
                pw.print("Bundle : ");
                pw.print(ref.getBundle().getSymbolicName());
                pw.print(" <");
                pw.print(String.valueOf(ref.getBundle().getBundleId()));
                pw.println(">");
            }
            pw.println();
        }
        pw.println();
    }
    if (dto.failedErrorPageDTOs.length > 0) {
        pw.println("Failed Error Pages");
        for (final FailedErrorPageDTO ep : dto.failedErrorPageDTOs) {
            final List<String> patterns = new ArrayList<>();
            for (final long p : ep.errorCodes) {
                patterns.add(String.valueOf(p));
            }
            for (final String p : ep.exceptions) {
                patterns.add(p);
            }
            pw.print("Patterns : ");
            pw.println(patterns);
            pw.print("Reason : ");
            pw.println(getErrorText(ep.failureReason));
            pw.print("Name : ");
            pw.println(ep.name);
            final ServiceReference<?> ref = this.getServiceReference(ep.serviceId);
            printServiceIdAndRanking(pw, ref, ep.serviceId);
            pw.print("async : ");
            pw.println(String.valueOf(ep.asyncSupported));
            if (ref != null) {
                pw.print("Bundle : ");
                pw.print(ref.getBundle().getSymbolicName());
                pw.print(" <");
                pw.print(String.valueOf(ref.getBundle().getBundleId()));
                pw.println(">");
            }
            pw.println();
        }
        pw.println();
    }
    if (dto.failedListenerDTOs.length > 0) {
        pw.println("Listeners");
        for (final FailedListenerDTO ep : dto.failedListenerDTOs) {
            pw.print("Types : ");
            pw.println(getValueAsString(ep.types));
            pw.print("Reason : ");
            pw.println(getErrorText(ep.failureReason));
            final ServiceReference<?> ref = this.getServiceReference(ep.serviceId);
            printServiceIdAndRanking(pw, ref, ep.serviceId);
            if (ref != null) {
                pw.print("Bundle : ");
                pw.print(ref.getBundle().getSymbolicName());
                pw.print(" <");
                pw.print(String.valueOf(ref.getBundle().getBundleId()));
                pw.println(">");
            }
            pw.println();
        }
        pw.println();
    }
    pw.println();
}
Also used : FailedFilterDTO(org.osgi.service.http.runtime.dto.FailedFilterDTO) FailedServletDTO(org.osgi.service.http.runtime.dto.FailedServletDTO) FailedErrorPageDTO(org.osgi.service.http.runtime.dto.FailedErrorPageDTO) ServletContextDTO(org.osgi.service.http.runtime.dto.ServletContextDTO) FailedServletContextDTO(org.osgi.service.http.runtime.dto.FailedServletContextDTO) ArrayList(java.util.ArrayList) FailedResourceDTO(org.osgi.service.http.runtime.dto.FailedResourceDTO) FailedFilterDTO(org.osgi.service.http.runtime.dto.FailedFilterDTO) FilterDTO(org.osgi.service.http.runtime.dto.FilterDTO) ResourceDTO(org.osgi.service.http.runtime.dto.ResourceDTO) FailedResourceDTO(org.osgi.service.http.runtime.dto.FailedResourceDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO) ListenerDTO(org.osgi.service.http.runtime.dto.ListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO) ErrorPageDTO(org.osgi.service.http.runtime.dto.ErrorPageDTO) FailedErrorPageDTO(org.osgi.service.http.runtime.dto.FailedErrorPageDTO) RuntimeDTO(org.osgi.service.http.runtime.dto.RuntimeDTO) FailedServletContextDTO(org.osgi.service.http.runtime.dto.FailedServletContextDTO) Map(java.util.Map) FailedServletDTO(org.osgi.service.http.runtime.dto.FailedServletDTO) ServletDTO(org.osgi.service.http.runtime.dto.ServletDTO)

Example 2 with ListenerDTO

use of org.osgi.service.http.runtime.dto.ListenerDTO in project felix by apache.

the class ListenerMap method getRuntimeInfo.

public void getRuntimeInfo(final List<ListenerDTO> listenerDTOs, final List<FailedListenerDTO> failedListenerDTOs) {
    final int length = listenerDTOs.size();
    final int failedLength = failedListenerDTOs.size();
    final List<ListenerRegistrationStatus<T>> list = this.handlers;
    for (final ListenerRegistrationStatus<T> status : list) {
        // search for DTO with same service id and failureCode
        if (status.getResult() == -1) {
            int index = 0;
            boolean found = false;
            final Iterator<ListenerDTO> i = listenerDTOs.iterator();
            while (!found && index < length) {
                final ListenerDTO dto = i.next();
                if (dto.serviceId == status.getHandler().getListenerInfo().getServiceId()) {
                    found = true;
                }
                index++;
            }
            if (!found) {
                listenerDTOs.add(ListenerDTOBuilder.build(status.getHandler(), status.getResult()));
            }
        } else {
            int index = 0;
            boolean found = false;
            final Iterator<FailedListenerDTO> i = failedListenerDTOs.iterator();
            while (!found && index < failedLength) {
                final FailedListenerDTO dto = i.next();
                if (dto.serviceId == status.getHandler().getListenerInfo().getServiceId() && dto.failureReason == status.getResult()) {
                    found = true;
                }
                index++;
            }
            if (!found) {
                failedListenerDTOs.add((FailedListenerDTO) ListenerDTOBuilder.build(status.getHandler(), status.getResult()));
            }
        }
    }
}
Also used : ListenerDTO(org.osgi.service.http.runtime.dto.ListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO)

Example 3 with ListenerDTO

use of org.osgi.service.http.runtime.dto.ListenerDTO in project felix by apache.

the class ListenerDTOBuilder method build.

public static ListenerDTO build(final ListenerInfo info, final int reason) {
    final ListenerDTO dto = (reason == -1 ? new ListenerDTO() : new FailedListenerDTO());
    dto.serviceId = info.getServiceId();
    dto.types = Arrays.copyOf(info.getListenerTypes(), info.getListenerTypes().length);
    if (reason != -1) {
        ((FailedListenerDTO) dto).failureReason = reason;
    }
    return dto;
}
Also used : ListenerDTO(org.osgi.service.http.runtime.dto.ListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO)

Example 4 with ListenerDTO

use of org.osgi.service.http.runtime.dto.ListenerDTO in project felix by apache.

the class ListenerDTOBuilder method build.

public static ListenerDTO build(final ListenerHandler handler, final int reason) {
    final ListenerDTO dto = build(handler.getListenerInfo(), reason);
    dto.servletContextId = handler.getContextServiceId();
    return dto;
}
Also used : ListenerDTO(org.osgi.service.http.runtime.dto.ListenerDTO) FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO)

Example 5 with ListenerDTO

use of org.osgi.service.http.runtime.dto.ListenerDTO in project felix by apache.

the class HttpServicePlugin method printListenerDetails.

private void printListenerDetails(final PrintWriter pw, final ServletContextDTO dto) {
    if (dto.listenerDTOs.length == 0) {
        return;
    }
    pw.print("<p class=\"statline ui-state-highlight\">${Servlet Context} '");
    pw.print(escapeXml(dto.name));
    pw.println("' ${Registered Listeners}</p>");
    pw.println("<table class=\"nicetable\">");
    pw.println("<thead><tr>");
    pw.println("<th class=\"header\">${Type}</th>");
    pw.println("<th class=\"header\">${Info}</th>");
    pw.println("</tr></thead>");
    boolean odd = true;
    for (final ListenerDTO ep : dto.listenerDTOs) {
        final StringBuilder sb = new StringBuilder();
        final ServiceReference<?> ref = this.getServiceReference(ep.serviceId);
        sb.append("${service.id} : ").append(String.valueOf(ep.serviceId)).append("\n");
        appendServiceRanking(sb, ref);
        if (ref != null) {
            sb.append("${bundle} : ");
            sb.append("${#link:");
            sb.append(ref.getBundle().getBundleId());
            sb.append("}");
            sb.append(ref.getBundle().getSymbolicName());
            sb.append("${link#}\n");
        }
        final StringBuilder tsb = new StringBuilder();
        for (final String t : ep.types) {
            tsb.append(t).append('\n');
        }
        odd = printRow(pw, odd, tsb.toString(), sb.toString());
    }
    pw.println("</table>");
}
Also used : FailedListenerDTO(org.osgi.service.http.runtime.dto.FailedListenerDTO) ListenerDTO(org.osgi.service.http.runtime.dto.ListenerDTO)

Aggregations

FailedListenerDTO (org.osgi.service.http.runtime.dto.FailedListenerDTO)5 ListenerDTO (org.osgi.service.http.runtime.dto.ListenerDTO)5 ArrayList (java.util.ArrayList)1 Map (java.util.Map)1 ErrorPageDTO (org.osgi.service.http.runtime.dto.ErrorPageDTO)1 FailedErrorPageDTO (org.osgi.service.http.runtime.dto.FailedErrorPageDTO)1 FailedFilterDTO (org.osgi.service.http.runtime.dto.FailedFilterDTO)1 FailedResourceDTO (org.osgi.service.http.runtime.dto.FailedResourceDTO)1 FailedServletContextDTO (org.osgi.service.http.runtime.dto.FailedServletContextDTO)1 FailedServletDTO (org.osgi.service.http.runtime.dto.FailedServletDTO)1 FilterDTO (org.osgi.service.http.runtime.dto.FilterDTO)1 ResourceDTO (org.osgi.service.http.runtime.dto.ResourceDTO)1 RuntimeDTO (org.osgi.service.http.runtime.dto.RuntimeDTO)1 ServletContextDTO (org.osgi.service.http.runtime.dto.ServletContextDTO)1 ServletDTO (org.osgi.service.http.runtime.dto.ServletDTO)1