-
- public signal void status_changed(string message);
-
- public GSMActivator()
- {
- device = null;
- network = null;
- sim = null;
- }
-
- public async void start()
- {
- if (device == null)
- {
- device = (FSO_GSM_Device)zavai.registry.sbus.get_object(
- "org.freesmartphone.ogsmd",
- "/org/freesmartphone/GSM/Device",
- "org.freesmartphone.GSM.Device");
- network = (FSO_GSM_Network)zavai.registry.sbus.get_object(
- "org.freesmartphone.ogsmd",
- "/org/freesmartphone/GSM/Device",
- "org.freesmartphone.GSM.Network");
- sim = (FSO_GSM_SIM)zavai.registry.sbus.get_object(
- "org.freesmartphone.ogsmd",
- "/org/freesmartphone/GSM/Device",
- "org.freesmartphone.GSM.SIM");
- }
-
- status_changed("Turning on antenna");
- while (true)
- {
- try {
- yield device.set_antenna_power(true);
- break;
- } catch (Error e) {
- zavai.log.warning("SetAntennaPower: " + e.message);
- if (e.message.str("current status is 'enabling'") != null
- || e.message.str("current status is 'unknown'") != null)
- {
- status_changed("Waiting for ogsmd to settle");
- zavai.log.info("trying again after 2 seconds");
- Timeout.add(2 * 1000, () => {
- start.callback();
- return false;
- });
- yield;
- } else {
- status_changed("Checking if PIN is required");
- string status = yield sim.get_auth_status();
- zavai.log.info("on_auth_status: " + status);
- if (status == "READY")
- status_changed("PIN ok");
- else if (status == "SIM PIN")
- {
- status_changed("Sending PIN");
- yield sim.send_auth_code(zavai.config.sim_pin);
- status_changed("PIN OK");
- }
- else
- zavai.log.debug("Unknown status: " + status);
- }
- }
- }
- zavai.log.warning("on_antenna_power ok");
- status_changed("Registering with network");
- yield network.register_();
- status_changed("Registered with network");
- }
-}
-
-public class GSM: zavai.ScriptMonitorService
-{
- protected dynamic DBus.Object dbus;