private void prepareConfigData(Packet result, String comp_name) throws ConfigurationException {
   if (comp_name.equals("--none--")) {
     newComponentCommand(result);
     return;
   } // end of if (comp_name.equals("--none--"))
   Command.setStatus(result, Command.Status.executing);
   Command.addAction(result, Command.Action.complete);
   // Let's try to sort them to make it easier to find options on
   // configuration page.
   Map<String, Object> allprop = new TreeMap<String, Object>(getAllProperties(comp_name));
   for (Map.Entry<String, Object> entry : allprop.entrySet()) {
     Command.addFieldValue(
         result,
         XMLUtils.escape(entry.getKey()),
         XMLUtils.escape(objectToString(entry.getValue())));
   } // end of for (Map.Entry entry: prop.entrySet())
   Command.addFieldValue(
       result,
       XMLUtils.escape("new-prop-name"),
       XMLUtils.escape(comp_name + "/"),
       "text-single",
       "New property name");
   Command.addFieldValue(
       result, XMLUtils.escape("new-prop-value"), "", "text-single", "New property value");
 }
예제 #2
0
  public Element getRosterElement() {
    Element elem =
        new Element(
            ELEM_NAME,
            new String[] {JID_ATT, SUBS_ATT, NAME_ATT, STRINGPREP_ATT},
            new String[] {
              jid.toString(), subscription.toString(), XMLUtils.escape(name), "" + stringpreped
            });

    if ((groups != null) && (groups.length > 0)) {
      String grps = "";

      for (String group : groups) {
        grps += XMLUtils.escape(group) + ",";
      }
      grps = grps.substring(0, grps.length() - 1);
      elem.setAttribute(GRP_ATT, grps);
    }
    if (otherData != null) {
      elem.setAttribute(OTHER_ATT, otherData);
    }
    elem.setAttribute(ACTIVITY_ATT, Double.toString(activity));
    elem.setAttribute(WEIGHT_ATT, Double.toString(weight));
    elem.setAttribute(LAST_SEEN_ATT, Long.toString(lastSeen));
    modified = false;

    return elem;
  }
예제 #3
0
 public final void setGroups(String[] groups) {
   if ((groups != null) && (groups.length > 0)) {
     this.groups = new String[groups.length];
     for (int i = 0; i < groups.length; i++) {
       this.groups[i] = XMLUtils.unescape(groups[i]);
     }
     modified = true;
   }
 }
 public Object setPropertyValue(String key, String val, Packet result_pack, boolean admin) {
   Object result = null;
   try {
     if (admin) {
       result = setValue(key, val, false, false, null);
     }
     if (result != null) {
       Command.addFieldValue(result_pack, XMLUtils.escape(key), XMLUtils.escape(val));
     } else {
       Command.addFieldValue(
           result_pack,
           "Note",
           "You can not set new properties yet, you can just modify existing ones.",
           "fixed");
     }
   } catch (Exception e) {
     Command.addFieldValue(result_pack, "Note", "Error setting property: " + e, "fixed");
   }
   return result;
 }
예제 #5
0
  public Element getRosterItem() {

    // This is actually not a good idea to cache the item element.
    // This causes a huge memory consumption and usually the item
    // is needed only once at the roster retrieving time.
    // if (item == null) {
    Element item = new Element("item");

    item.setAttribute("jid", jid.toString());
    item.addAttributes(subscription.getSubscriptionAttr());
    if (name != null) {
      item.setAttribute("name", XMLUtils.escape(name));
    }
    if (groups != null) {
      for (String gr : groups) {
        Element group = new Element("group");

        group.setCData(XMLUtils.escape(gr));
        item.addChild(group);
      } // end of for ()
    } // end of if-else
    return item;
  }
예제 #6
0
  public final void setName(String name) {
    String old_name = this.name;

    if (name == null) {
      this.name = this.jid.getLocalpart();
      if ((this.name == null) || this.name.trim().isEmpty()) {
        this.name = this.jid.getBareJID().toString();
      }
    } else {
      this.name = XMLUtils.unescape(name);
    }
    if (!this.name.equals(old_name)) {
      modified = true;
    }
  }
 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
 }
예제 #10
0
  @Override
  public void processPacket(final Packet packet, final Queue<Packet> results) {

    if (!packet.isCommand()) {
      return;
    }
    Iq iqc = (Iq) packet;

    if (iqc.getType() != null && iqc.getType() == StanzaType.error) {
      log.info("Ignoring error packet: " + iqc.toString());
      return;
    }

    String nick = iqc.getTo().getLocalpart();
    if (nick == null || !getName().equals(nick)) return;

    String msg =
        "Please be careful, you are service admin and all changes"
            + " you make are instantly applied to live system!";
    boolean admin = true;
    if (iqc.getPermissions() != Permissions.ADMIN) {
      if (demoMode) {
        admin = false;
        msg =
            "You are not admin. You can safely play with the settings as"
                + " you can not change anything.";
        if (iqc.getStrCommand() != null && iqc.getStrCommand().endsWith(DEF_SM_NAME)) {
          Packet result = iqc.commandResult(Command.DataType.result);
          Command.addFieldValue(result, "Note", msg, "fixed");
          Command.addFieldValue(
              result, "Note", "Restricted area, only admin can see these settings.", "fixed");
          results.offer(result);
          return;
        }
      } else {
        try {
          results.offer(
              Authorization.NOT_AUTHORIZED.getResponseMessage(
                  packet, "You are not authorized for this action.", true));
        } catch (PacketErrorTypeException e) {
          log.warning("Packet processing exception: " + e);
        }
        return;
      }
    }

    if (log.isLoggable(Level.FINEST)) {
      log.finest("Command received: " + iqc.toString());
    }

    Command.Action action = Command.getAction(iqc);
    if (action == Command.Action.cancel) {
      Packet result = iqc.commandResult(null);
      results.offer(result);
      return;
    }

    switch (iqc.getCommand()) {
      case OTHER:
        if (iqc.getStrCommand() != null) {
          if (iqc.getStrCommand().startsWith("config/list/")) {
            try {
              String[] spl = iqc.getStrCommand().split("/");
              Packet result = iqc.commandResult(Command.DataType.result);
              Command.addFieldValue(result, "Note", msg, "fixed");
              Map<String, Object> allprop = getAllProperties(spl[2]);
              for (Map.Entry<String, Object> entry : allprop.entrySet()) {
                Command.addFieldValue(
                    result,
                    XMLUtils.escape(entry.getKey()),
                    XMLUtils.escape(objectToString(entry.getValue())));
              } // end of for (Map.Entry entry: prop.entrySet())
              results.offer(result);
            } catch (ConfigurationException ex) {
              Logger.getLogger(ConfiguratorOld.class.getName()).log(Level.SEVERE, null, ex);
            }
          }
          if (iqc.getStrCommand().startsWith("config/set/")) {
            try {
              String[] spl = iqc.getStrCommand().split("/");
              Packet result = iqc.commandResult(Command.DataType.result);
              Command.addFieldValue(result, "Note", msg, "fixed");
              if (Command.getData(packet) == null) {
                prepareConfigData(result, spl[2]);
                results.offer(result);
              } else {
                updateConfigChanges(packet, result, spl[2], admin);
                results.offer(result);
              }
            } catch (ConfigurationException ex) {
              Logger.getLogger(ConfiguratorOld.class.getName()).log(Level.SEVERE, null, ex);
            }
          }
        }
        break;
      default:
        break;
    }
  }