All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.felix.webconsole.ConfigurationPrinter Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.felix.webconsole;

import java.io.PrintWriter;

import org.osgi.annotation.versioning.ConsumerType;

/**
 * The ConfigurationPrinter is a service interface to be used by
 * providers which want to hook into the display of the current configuration
 * of the OSGi framework.
 * A configuration printer is currently used in three modes: displayed in
 * a tab of the configuration web console plugin, included in a downloadable
 * zip of the configuration or a downloadable txt file.
 * With the {@link WebConsoleConstants#CONFIG_PRINTER_MODES} property this
 * service can specify when it should be included.
 * The default mode is {@link #MODE_ALWAYS}.
 *
 * @deprecated This has been deprecated. Use the org.apache.felix.inventory API instead.
 */
@Deprecated
@ConsumerType
public interface ConfigurationPrinter {

    /**
     * The service name under which services of this class must be registered
     * to be picked for inclusion in the configuration report.
     */
    String SERVICE = ConfigurationPrinter.class.getName();

    /**
     * The default mode - this printer is used in the web console and the zip.
     *
     * @since 3.0
     */
    String MODE_ALWAYS = "always";

    /**
     * The web mode - this printer is used in the web console.
     * 

* Output of the configuration printer is HTML-escaped unless the * {@link WebConsoleConstants#CONFIG_PRINTER_WEB_UNESCAPED} service * registration property is set to true. * * @since 3.0 */ String MODE_WEB = "web"; /** * The zip mode - this printer is used in the zip. * * @since 3.0 */ String MODE_ZIP = "zip"; /** * The txt mode - this printer is used in the txt. * * @since 3.0 */ String MODE_TXT = "txt"; /** * The optional service property specifying the modes of the printer. * If this property is missing or contains an unknown value, the default * {@link #MODE_ALWAYS} is used. * The value of this property is either a single string or an * array of strings. * * @since 3.0 * @deprecated Use {@link WebConsoleConstants#CONFIG_PRINTER_MODES} */ String PROPERTY_MODES = "modes"; /** * Returns a human readable title string to be placed in front of the configuration * report generated by the {@link #printConfiguration(PrintWriter)} method. * * @return the configuration title */ String getTitle(); /** * Prints the configuration report to the given printWriter. * Implementations are free to print whatever information they deem useful. * * @param printWriter where to write the configuration data. It might be flushed, * but must not be closed. */ void printConfiguration( PrintWriter printWriter ); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy