/* * 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.karaf.shell.util; import static org.apache.karaf.shell.commands.ansi.SimpleAnsi.COLOR_DEFAULT; import static org.apache.karaf.shell.commands.ansi.SimpleAnsi.COLOR_RED; import static org.apache.karaf.shell.commands.ansi.SimpleAnsi.INTENSITY_BOLD; import static org.apache.karaf.shell.commands.ansi.SimpleAnsi.INTENSITY_NORMAL; import java.security.AccessControlContext; import java.security.AccessController; import java.util.Arrays; import javax.security.auth.Subject; import org.apache.felix.service.command.CommandSession; import org.apache.karaf.jaas.boot.principal.UserPrincipal; import org.apache.karaf.shell.commands.CommandException; import org.apache.karaf.shell.console.CloseShellException; import org.apache.karaf.shell.console.SessionProperties; import org.osgi.framework.Bundle; import org.osgi.framework.BundleContext; import org.osgi.framework.Constants; import org.osgi.framework.startlevel.BundleStartLevel; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @Deprecated public class ShellUtil { private static final Logger LOGGER = LoggerFactory.getLogger(ShellUtil.class); public static String getBundleName(Bundle bundle) { if (bundle != null) { String name = (String) bundle.getHeaders().get(Constants.BUNDLE_NAME); return (name == null) ? "Bundle " + Long.toString(bundle.getBundleId()) : name + " (" + Long.toString(bundle.getBundleId()) + ")"; } return "[STALE BUNDLE]"; } public static String getUnderlineString(String s) { StringBuilder sb = new StringBuilder(s.length()); for (int i = 0; i < s.length(); i++) { sb.append('-'); } return sb.toString(); } public static String getValueString(Object obj) { if (obj == null) { return "null"; } else if (obj instanceof boolean[]) { return Arrays.toString((boolean[]) obj); } else if (obj instanceof byte[]) { return Arrays.toString((byte[]) obj); } else if (obj instanceof char[]) { return Arrays.toString((char[]) obj); } else if (obj instanceof double[]) { return Arrays.toString((double[]) obj); } else if (obj instanceof float[]) { return Arrays.toString((float[]) obj); } else if (obj instanceof int[]) { return Arrays.toString((int[]) obj); } else if (obj instanceof long[]) { return Arrays.toString((long[]) obj); } else if (obj instanceof short[]) { return Arrays.toString((short[]) obj); } else if (obj.getClass().isArray()) { Object[] array = (Object[]) obj; StringBuilder sb = new StringBuilder(); sb.append("["); for (int i = 0; i < array.length; i++) { if (i != 0) { sb.append(", "); } sb.append(getValueString(array[i])); } sb.append("]"); return sb.toString(); } else { return obj.toString(); } } /** * Check if a bundle is a system bundle (start level minor than 50) * * @param bundleContext The bundle context. * @param bundle The bundle to check. * @return True if the bundle has start level minor than 50, false else. */ public static boolean isASystemBundle(BundleContext bundleContext, Bundle bundle) { int level = bundle.adapt(BundleStartLevel.class).getStartLevel(); int sbsl = 49; final String sbslProp = bundleContext.getProperty("karaf.systemBundlesStartLevel"); if (sbslProp != null) { try { sbsl = Integer.valueOf(sbslProp); } catch (Exception ignore) { // ignore } } return level <= sbsl; } public static boolean getBoolean(CommandSession session, String name) { Object s = session.get(name); if (s == null) { s = System.getProperty(name); } if (s == null) { return false; } if (s instanceof Boolean) { return (Boolean) s; } return Boolean.parseBoolean(s.toString()); } public static void logException(CommandSession session, Throwable t) { try { boolean isCommandNotFound = "org.apache.felix.gogo.runtime.CommandNotFoundException".equals(t.getClass().getName()); if (isCommandNotFound) { LOGGER.debug("Unknown command entered", t); } else if (t instanceof CommandException) { LOGGER.debug("Command exception (Undefined option, ...)", t); } else if (!(t instanceof CloseShellException)) { LOGGER.error("Exception caught while executing command", t); } session.put(SessionProperties.LAST_EXCEPTION, t); if (t instanceof CommandException) { session.getConsole().println(((CommandException) t).getNiceHelp()); } else if (isCommandNotFound) { String str = COLOR_RED + "Command not found: " + INTENSITY_BOLD + t.getClass().getMethod("getCommand").invoke(t) + INTENSITY_NORMAL + COLOR_DEFAULT; session.getConsole().println(str); } if (getBoolean(session, SessionProperties.PRINT_STACK_TRACES)) { session.getConsole().print(COLOR_RED); t.printStackTrace(session.getConsole()); session.getConsole().print(COLOR_DEFAULT); } else if (!(t instanceof CloseShellException) && !(t instanceof CommandException) && !isCommandNotFound) { session.getConsole().print(COLOR_RED); session.getConsole().println("Error executing command: " + (t.getMessage() != null ? t.getMessage() : t.getClass().getName())); session.getConsole().print(COLOR_DEFAULT); } } catch (Exception ignore) { // ignore } } public static String getCurrentUserName() { AccessControlContext acc = AccessController.getContext(); final Subject subject = Subject.getSubject(acc); if (subject != null && subject.getPrincipals(UserPrincipal.class).iterator().hasNext()) { return subject.getPrincipals(UserPrincipal.class).iterator().next().getName(); } else { return null; } } }