@Override
    public void responseReceived(Packet packet, Packet response) {
      String pb = Command.getFieldValue(packet, PRE_BIND_ATTR);
      boolean prebind = Boolean.valueOf(pb);

      String sessionId = Command.getFieldValue(packet, SESSION_ID_ATTR);
      String userID = Command.getFieldValue(packet, USER_ID_ATTR);

      if (prebind) {
        // we are doing pre-bind, send user-login command, bind resource
        Packet packetOut =
            Command.USER_STATUS.getPacket(
                packet.getFrom(), packet.getTo(), StanzaType.get, UUID.randomUUID().toString());

        //				Element presence = new Element( "presence" );
        Command.addFieldValue(packetOut, USER_ID_ATTR, userID);
        if (null != sessionId) {
          Command.addFieldValue(packetOut, SESSION_ID_ATTR, sessionId);
        }
        Command.addFieldValue(packetOut, PRE_BIND_ATTR, String.valueOf(prebind));

        addOutPacket(packetOut);
      } else {

        // We are now ready to ask for features....
        addOutPacket(
            Command.GETFEATURES.getPacket(
                packet.getFrom(),
                packet.getTo(),
                StanzaType.get,
                UUID.randomUUID().toString(),
                null));
      }
    }
 private void updateConfigChanges(Packet packet, Packet result, String comp_name, boolean admin)
     throws ConfigurationException {
   if (comp_name.equals("--none--")) {
     newComponentCommand(packet, result, admin);
     return;
   } // end of if (comp_name.equals("--none--"))
   Command.addNote(result, "You changed following settings:");
   Command.addFieldValue(result, "Note", "You changed following settings:", "fixed");
   Map<String, Object> allprop = getAllProperties(comp_name);
   boolean changed = false;
   for (Map.Entry<String, Object> entry : allprop.entrySet()) {
     String tmp_val = Command.getFieldValue(packet, XMLUtils.escape(entry.getKey()));
     String old_val = objectToString(entry.getValue());
     String new_val = old_val;
     if (tmp_val != null) {
       new_val = XMLUtils.unescape(tmp_val);
     }
     if (new_val != null && old_val != null && !new_val.equals(old_val)) {
       defConfigParams.put(
           entry.getKey(), setPropertyValue(entry.getKey(), new_val, result, admin));
       changed = true;
     }
   } // end of for (Map.Entry entry: prop.entrySet())
   String prop_value = Command.getFieldValue(packet, "new-prop-value");
   if (prop_value != null && prop_value.trim().length() > 0) {
     setPropertyValue(
         XMLUtils.unescape(Command.getFieldValue(packet, "new-prop-name")),
         XMLUtils.unescape(prop_value),
         result,
         admin);
     changed = true;
   }
   if (changed && admin) {
     setup(comp_name);
   }
 }
 private void newComponentCommand(Packet packet, Packet result, boolean admin) {
   String params_set = Command.getFieldValue(packet, "Params set");
   if (Command.getAction(packet) != null && Command.getAction(packet).equals("prev")) {
     newComponentCommand(result);
     return;
   } // end of if ()
   if (params_set != null) {
     createNewComponent(packet, result, admin);
     return;
   } // end of if (params_set != null)
   String new_comp_name = Command.getFieldValue(packet, "Component name");
   String new_comp_class = Command.getFieldValue(packet, "Component class");
   if (!checkComponentName(result, new_comp_name)) {
     return;
   } // end of if (!checkComponentName(new_comp_name))
   Command.setStatus(result, Command.Status.executing);
   Command.addFieldValue(result, "Component name", new_comp_name, "hidden");
   Command.addFieldValue(result, "Component class", new_comp_class, "hidden");
   Command.addFieldValue(result, "Info1", "Press:", "fixed");
   try {
     MessageReceiver mr = (MessageReceiver) Class.forName(new_comp_class).newInstance();
     Command.addFieldValue(
         result,
         "Info4",
         "Component name: " + new_comp_name + ", class: " + mr.getClass().getSimpleName(),
         "fixed");
     if (mr instanceof ConnectionManager) {
       String ports = Command.getFieldValue(packet, "TCP/IP ports");
       if (ports == null) {
         Command.addFieldValue(
             result, "Info2", "1. 'Next' to set more component parameters.", "fixed");
         Command.addFieldValue(
             result, "Info3", "2. 'Previous' to go back and select different component.", "fixed");
         Command.addAction(result, Command.Action.next);
         Command.addAction(result, Command.Action.prev);
         Command.addFieldValue(
             result,
             "Info4",
             "This component uses TCP/IP ports, please provide port numbers:",
             "fixed");
         Command.addFieldValue(result, "TCP/IP ports", "5557");
         return;
       } else {
         String[] ports_arr = ports.split(",");
         int[] ports_i = new int[ports_arr.length];
         try {
           for (int i = 0; i < ports_arr.length; i++) {
             ports_i[i] = Integer.decode(ports_arr[i].trim());
           } // end of for (int i = 0; i < ports_arr.length; i++)
           defConfigParams.put(new_comp_name + "/connections/ports", ports_i);
         } catch (Exception e) {
           Command.addFieldValue(
               result, "Info2", "1. 'Next' to set more component parameters.", "fixed");
           Command.addFieldValue(
               result,
               "Info3",
               "2. 'Previous' to go back and select different component.",
               "fixed");
           Command.addAction(result, Command.Action.next);
           Command.addAction(result, Command.Action.prev);
           Command.addFieldValue(
               result,
               "Info4",
               "Incorrect TCP/IP ports provided, please provide port numbers:",
               "fixed");
           Command.addFieldValue(result, "TCP/IP ports", ports);
           return;
         } // end of try-catch
       } // end of else
     }
     Command.addFieldValue(
         result, "Info2", "1. 'Finish' to create component with this parameters.", "fixed");
     Command.addFieldValue(
         result, "Info3", "2. 'Previous' to go back and select different component.", "fixed");
     Command.addAction(result, Command.Action.complete);
     Command.addAction(result, Command.Action.prev);
     mr.setName(new_comp_name);
     if (mr instanceof Configurable) {
       // Load defaults into sorted Map:
       Map<String, Object> comp_props =
           new TreeMap<String, Object>(((Configurable) mr).getDefaults(defConfigParams));
       for (Map.Entry<String, Object> entry : comp_props.entrySet()) {
         Command.addFieldValue(
             result,
             XMLUtils.escape(entry.getKey()),
             XMLUtils.escape(objectToString(entry.getValue())));
       } // end of for (Map.Entry entry: prop.entrySet())
     } else {
       Command.addFieldValue(
           result, "Info6", "Component is not configurable, do you want to create it?", "fixed");
     } // end of else
     Command.addFieldValue(result, "Params set", "true", "hidden");
   } catch (Exception e) {
     log.log(Level.SEVERE, "Problem instantiating component:", e);
     Command.addFieldValue(
         result,
         "Component class",
         "ERROR!! Problem instantiating component, " + "look in log file for details...",
         "text-single",
         "Component class");
   } // end of try-catch
 }
 private void createNewComponent(Packet packet, Packet result, boolean admin) {
   String new_comp_name = Command.getFieldValue(packet, "Component name");
   String new_comp_class = Command.getFieldValue(packet, "Component class");
   try {
     MessageReceiver mr = (MessageReceiver) Class.forName(new_comp_class).newInstance();
     mr.setName(new_comp_name);
     if (mr instanceof Configurable) {
       Map<String, Object> comp_props = ((Configurable) mr).getDefaults(defConfigParams);
       Map<String, Object> new_params = new LinkedHashMap<String, Object>(comp_props);
       // Convert String values to proper Objecy values
       for (Map.Entry<String, Object> entry : comp_props.entrySet()) {
         String val = Command.getFieldValue(packet, XMLUtils.escape(entry.getKey()));
         if (val == null) {
           val = "";
         }
         val = XMLUtils.unescape(val);
         log.info("New component value: " + entry.getKey() + "=" + val);
         setValue(entry.getKey(), val, false, false, new_params);
       } // end of for (Map.Entry entry: prop.entrySet())
       if (admin) {
         // Now we can save all properties to config repository:
         for (Map.Entry<String, Object> entry : new_params.entrySet()) {
           String key = entry.getKey();
           String subnode = null;
           int key_idx = entry.getKey().lastIndexOf('/');
           if (key_idx > 0) {
             key = entry.getKey().substring(key_idx + 1);
             subnode = entry.getKey().substring(0, key_idx);
           }
           log.info(
               "Saving property to repository: "
                   + "root="
                   + new_comp_name
                   + ", subnode="
                   + subnode
                   + ", key="
                   + key
                   + ", value="
                   + entry.getValue());
           repository.set(new_comp_name, subnode, key, entry.getValue());
         } // end of for (Map.Entry entry: prop.entrySet())
         // And load the component itself.....
         // Set class name for the component
         repository.set(
             routerCompName,
             "/components/msg-receivers",
             new_comp_name + ".class",
             new_comp_class);
         // Activate the component
         repository.set(
             routerCompName, "/components/msg-receivers", new_comp_name + ".active", true);
         // Add to the list of automaticaly loaded components
         setValue(
             routerCompName + "/components/msg-receivers/id-names",
             new_comp_name,
             true,
             false,
             null);
         // repository.sync();
         setup(routerCompName);
       } // end of if (admin)
     }
     Command.addNote(result, "New component created: " + new_comp_name);
     Command.addFieldValue(result, "Note", "New component created: " + new_comp_name, "fixed");
   } catch (Exception e) {
     log.log(Level.SEVERE, "Problem instantiating component:", e);
     Command.addFieldValue(
         result,
         "Component class",
         "ERROR!! Problem instantiating component, " + "look in log file for details...",
         "text-single",
         "Component class");
   } // end of try-catch
 }
  @Override
  protected void processCommand(Packet packet) {
    BoshSession session = getBoshSession(packet.getTo());

    switch (packet.getCommand()) {
      case USER_LOGIN:
        String jid = Command.getFieldValue(packet, "user-jid");

        if (jid != null) {
          if (session != null) {
            try {
              BareJID fromJID = BareJID.bareJIDInstance(jid);
              BareJID hostJid = getSeeOtherHostForJID(fromJID, Phase.LOGIN);

              if (hostJid != null) {
                Element streamErrorElement =
                    see_other_host_strategy.getStreamError(
                        "urn:ietf:params:xml:ns:xmpp-streams", hostJid);
                Packet redirectPacket = Packet.packetInstance(streamErrorElement);

                redirectPacket.setPacketTo(packet.getTo());
                writePacketToSocket(redirectPacket);
                session.sendWaitingPackets();
                session.close();
                if (log.isLoggable(Level.FINE)) {
                  log.log(
                      Level.FINE,
                      "{0} : {1} ({2})",
                      new Object[] {
                        BOSH_OPERATION_TYPE.REMOVE, session.getSid(), "See other host"
                      });
                }
                sessions.remove(session.getSid());
              } else {
                session.setUserJid(jid);
              }
            } catch (TigaseStringprepException ex) {
              log.log(Level.SEVERE, "user JID violates RFC6122 (XMPP:Address Format): ", ex);
            }
          } else {
            if (log.isLoggable(Level.FINE)) {
              log.log(Level.FINE, "Missing XMPPIOService for USER_LOGIN command: {0}", packet);
            }
          }
        } else {
          log.log(Level.WARNING, "Missing user-jid for USER_LOGIN command: {0}", packet);
        }

        break;

      case CLOSE:
        if (session != null) {
          if (log.isLoggable(Level.FINER)) {
            log.log(Level.FINER, "Closing session for command CLOSE: {0}", session.getSid());
          }
          try {
            List<Element> err_el = packet.getElement().getChildrenStaticStr(Iq.IQ_COMMAND_PATH);

            if ((err_el != null) && (err_el.size() > 0)) {
              Element error = new Element("stream:error");

              error.addChild(err_el.get(0));

              Packet condition = Packet.packetInstance(error);

              condition.setPacketTo(packet.getTo());
              writePacketToSocket(condition);
              session.sendWaitingPackets();
              bosh_session_close_delay = 100;
            }
          } catch (TigaseStringprepException ex) {
            Logger.getLogger(BoshConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
          }
          if (bosh_session_close_delay > 0) {
            try {
              Thread.sleep(bosh_session_close_delay);
            } catch (InterruptedException ex) {

              // Intentionally left blank
            }
          }
          session.close();
          if (log.isLoggable(Level.FINE)) {
            log.log(
                Level.FINE,
                "{0} : {1} ({2})",
                new Object[] {
                  BOSH_OPERATION_TYPE.REMOVE, session.getSid(), "Closing session for command CLOSE"
                });
          }
          sessions.remove(session.getSid());
        } else {
          if (log.isLoggable(Level.FINE)) {
            log.log(Level.FINE, "Session does not exist for packet: {0}", packet);
          }
        }

        break;

      case CHECK_USER_CONNECTION:
        if (session != null) {

          // It's ok, the session has been found, respond with OK.
          addOutPacket(packet.okResult((String) null, 0));
        } else {

          // Session is no longer active, respond with an error.
          try {
            addOutPacket(
                Authorization.ITEM_NOT_FOUND.getResponseMessage(packet, "Connection gone.", false));
          } catch (PacketErrorTypeException e) {

            // Hm, error already, ignoring...
            log.log(Level.INFO, "Error packet is not really expected here: {0}", packet);
          }
        }

        break;

      default:
        super.processCommand(packet);

        break;
    } // end of switch (pc.getCommand())
  }