6 changed files with 75 additions and 14 deletions
@ -0,0 +1,22 @@ |
|||||||
|
package de.srsoftware.web4rail.actions; |
||||||
|
|
||||||
|
import java.io.IOException; |
||||||
|
|
||||||
|
import de.srsoftware.web4rail.BaseClass; |
||||||
|
|
||||||
|
public class SavePlan extends Action{ |
||||||
|
|
||||||
|
public SavePlan(BaseClass parent) { |
||||||
|
super(parent); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public boolean fire(Context context) { |
||||||
|
try { |
||||||
|
plan.save(); |
||||||
|
} catch (IOException e) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
return true; |
||||||
|
} |
||||||
|
} |
@ -1,68 +1,96 @@ |
|||||||
package de.srsoftware.web4rail.actions; |
package de.srsoftware.web4rail.actions; |
||||||
|
|
||||||
|
import java.io.IOException; |
||||||
import java.util.HashMap; |
import java.util.HashMap; |
||||||
import java.util.List; |
import java.util.List; |
||||||
|
|
||||||
import org.json.JSONObject; |
import org.json.JSONObject; |
||||||
|
|
||||||
|
import de.srsoftware.tools.Tag; |
||||||
import de.srsoftware.web4rail.BaseClass; |
import de.srsoftware.web4rail.BaseClass; |
||||||
import de.srsoftware.web4rail.Command; |
import de.srsoftware.web4rail.Command; |
||||||
import de.srsoftware.web4rail.Window; |
import de.srsoftware.web4rail.Window; |
||||||
import de.srsoftware.web4rail.tags.Fieldset; |
import de.srsoftware.web4rail.tags.Fieldset; |
||||||
import de.srsoftware.web4rail.tags.Input; |
import de.srsoftware.web4rail.tags.Input; |
||||||
|
import de.srsoftware.web4rail.tags.Radio; |
||||||
|
|
||||||
public class SendCommand extends Action{ |
public class SendCommand extends Action{ |
||||||
|
|
||||||
|
enum Target{ |
||||||
|
SYSTEM, SRCP |
||||||
|
} |
||||||
|
|
||||||
public SendCommand(BaseClass parent) { |
public SendCommand(BaseClass parent) { |
||||||
super(parent); |
super(parent); |
||||||
} |
} |
||||||
|
|
||||||
public static final String COMMAND = "command"; |
public static final String COMMAND = "command"; |
||||||
|
private static final String TARGET = "target"; |
||||||
private String command = "SET 1 POWER OFF"; |
private String command = "SET 1 POWER OFF"; |
||||||
|
private Target target = Target.SRCP; |
||||||
|
|
||||||
@Override |
@Override |
||||||
public boolean fire(Context context) { |
public boolean fire(Context context) { |
||||||
plan.queue(new Command(command) { |
switch (target) { |
||||||
|
case SRCP: |
||||||
|
plan.queue(new Command(command) { |
||||||
|
|
||||||
@Override |
@Override |
||||||
public void onResponse(Reply reply) { |
public void onResponse(Reply reply) { |
||||||
super.onResponse(reply); |
super.onResponse(reply); |
||||||
plan.stream(reply.message()); |
plan.stream(reply.message()); |
||||||
} |
} |
||||||
}); |
}); |
||||||
|
|
||||||
return true; |
return true; |
||||||
|
case SYSTEM: |
||||||
|
try { |
||||||
|
Runtime.getRuntime().exec(command); |
||||||
|
return true; |
||||||
|
} catch (IOException e) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
} |
||||||
|
return false; |
||||||
} |
} |
||||||
|
|
||||||
@Override |
@Override |
||||||
public JSONObject json() { |
public JSONObject json() { |
||||||
JSONObject json = super.json(); |
JSONObject json = super.json(); |
||||||
json.put(COMMAND, command); |
json.put(COMMAND, command); |
||||||
|
json.put(TARGET, target.toString()); |
||||||
return json; |
return json; |
||||||
} |
} |
||||||
|
|
||||||
@Override |
@Override |
||||||
public Action load(JSONObject json) { |
public Action load(JSONObject json) { |
||||||
super.load(json); |
super.load(json); |
||||||
command = json.getString(COMMAND); |
if (json.has(COMMAND)) command = json.getString(COMMAND); |
||||||
|
if (json.has(TARGET)) target = Target.valueOf(json.getString(TARGET)); |
||||||
return this; |
return this; |
||||||
} |
} |
||||||
|
|
||||||
@Override |
@Override |
||||||
protected Window properties(List<Fieldset> preForm, FormInput formInputs, List<Fieldset> postForm) { |
protected Window properties(List<Fieldset> preForm, FormInput formInputs, List<Fieldset> postForm) { |
||||||
formInputs.add(t("Command to send to control unit"),new Input(COMMAND, command)); |
formInputs.add(t("Command to send"),new Input(COMMAND, command)); |
||||||
|
Tag div = new Tag("div"); |
||||||
|
new Radio(TARGET, Target.SYSTEM, t("Operating System"), target == Target.SYSTEM).addTo(div); |
||||||
|
new Radio(TARGET, Target.SRCP, t("SRCP daemon"), target == Target.SRCP).addTo(div); |
||||||
|
formInputs.add(t("Send command to"),div); |
||||||
return super.properties(preForm, formInputs, postForm); |
return super.properties(preForm, formInputs, postForm); |
||||||
} |
} |
||||||
|
|
||||||
@Override |
@Override |
||||||
public String toString() { |
public String toString() { |
||||||
return t("Send command \"{}\" to control unit",command); |
return t("Send command \"{}\" to {}",command,t(target.toString())); |
||||||
} |
} |
||||||
|
|
||||||
@Override |
@Override |
||||||
protected Object update(HashMap<String, String> params) { |
protected Object update(HashMap<String, String> params) { |
||||||
LOG.debug("update: {}",params); |
LOG.debug("update: {}",params); |
||||||
command = params.get(COMMAND); |
command = params.get(COMMAND); |
||||||
|
String t = params.get(TARGET); |
||||||
|
if (isSet(t)) target = Target.valueOf(t); |
||||||
return properties(); |
return properties(); |
||||||
} |
} |
||||||
} |
} |
||||||
|
Loading…
Reference in new issue