package com.fourtails.usuariolecturista.jobs; import com.appspot.ocr_backend.backend.Backend; import com.appspot.ocr_backend.backend.model.MessagesCreateMeter; import com.appspot.ocr_backend.backend.model.MessagesCreateMeterResponse; import com.fourtails.usuariolecturista.MeterRegistrationActivity; import com.fourtails.usuariolecturista.ottoEvents.RegisterMeterBackendEvent; import com.google.api.client.extensions.android.http.AndroidHttp; import com.google.api.client.extensions.android.json.AndroidJsonFactory; import com.orhanobut.logger.Logger; import com.path.android.jobqueue.Job; import com.path.android.jobqueue.Params; import static com.fourtails.usuariolecturista.ottoEvents.RegisterMeterBackendEvent.Type; /** * RegisterMeterBackendJob async job */ public class RegisterMeterBackendJob extends Job { boolean responseOk = false; boolean retry = true; String mAccountNumber; public RegisterMeterBackendJob(String mAccountNumber) { super(new Params(Priority.MID).requireNetwork().groupBy("register-meter-backend")); this.mAccountNumber = mAccountNumber; } @Override public void onAdded() { Logger.d("RegisterMeterBackendJob initiated"); } @Override public void onRun() throws Throwable { // Use a builder to help formulate the API request. Backend.Builder builder = new Backend.Builder( AndroidHttp.newCompatibleTransport(), new AndroidJsonFactory(), null); Backend service = builder.build(); MessagesCreateMeter messagesCreateMeter = new MessagesCreateMeter(); messagesCreateMeter.setAccountNumber(mAccountNumber); MessagesCreateMeterResponse response = service.meter().create(messagesCreateMeter).execute(); if (response.getOk()) { Logger.json(response.toPrettyString()); MeterRegistrationActivity.bus.post(new RegisterMeterBackendEvent(Type.COMPLETED, 1)); } else if (response.getError().contains("Meter account number already in platform")) { MeterRegistrationActivity.bus.post(new RegisterMeterBackendEvent(Type.COMPLETED, 2)); Logger.e(response.getError()); } else { Logger.e(response.getError()); } } @Override protected void onCancel() { Logger.d("RegisterMeterBackendJob canceled"); MeterRegistrationActivity.bus.post(new RegisterMeterBackendEvent(Type.COMPLETED, 99)); responseOk = false; } @Override protected boolean shouldReRunOnThrowable(Throwable throwable) { return retry; } }