EpsoniPrintSharedActivity.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  1. package com.epson.iprint.shared;
  2. import android.app.Activity;
  3. import android.arch.lifecycle.Observer;
  4. import android.arch.lifecycle.ViewModelProviders;
  5. import android.content.Context;
  6. import android.content.Intent;
  7. import android.os.Bundle;
  8. import android.os.Handler;
  9. import android.os.Message;
  10. import androidx.appcompat.app.AppCompatActivity;
  11. import androidx.fragment.app.FragmentActivity;
  12. import com.epson.iprint.prtlogger.CommonLog;
  13. import com.epson.iprint.prtlogger.NewLoggerController;
  14. import com.epson.iprint.prtlogger.PrintLog;
  15. import com.epson.mobilephone.common.license.LicenseTopActivity;
  16. import epson.common.Constants;
  17. import epson.common.DialogProgress;
  18. import epson.common.DialogProgressViewModel;
  19. import epson.common.ExternalFileUtils;
  20. import epson.common.IprintLicenseInfo;
  21. import epson.common.IprintUserSurveyInfo;
  22. import epson.common.Utils;
  23. import epson.print.ActivityRequestPermissions;
  24. import epson.print.ActivityViewImageSelect;
  25. import epson.print.R;
  26. import epson.print.EPImageUtil;
  27. import epson.print.MyPrinter;
  28. import epson.print.Util.EPLog;
  29. import epson.print.WebviewActivity;
  30. import epson.scan.activity.ScanActivity;
  31. import java.io.File;
  32. import java.io.IOException;
  33. import java.util.ArrayList;
  34. import java.util.Deque;
  35. public class EpsoniPrintSharedActivity extends AppCompatActivity implements Runnable {
  36. public static final String ACTION_CONFIRM_PRINTER_SCANNER_SELECTION = "com.epson.iprint.isSetDevice";
  37. public static final String ACTION_PHOTO_PRINT = "com.epson.iprint.photo";
  38. public static final String ACTION_SCAN = "com.epson.iprint.scan";
  39. public static final String ACTION_WEB_PRINT = "com.epson.iprint.web";
  40. public static final String ACTIVITY_GET_PRINTER_INFORMATION = "epson.maintain.activity.GetPrinterReplyData";
  41. private static final int ACTIVITY_INTENT_PARAMETER_ERROR_ = 1;
  42. public static final String ACTIVITY_SCAN = "epson.scan.activity.ScanActivity";
  43. public static final String DIALOG_WAIT = "dialog_wait";
  44. public static final String GET_PRINTER_INFORMATION = "com.epson.iprint.status";
  45. public static final int INK_STATUS_ERROR = -1;
  46. public static final int INK_STATUS_INK_END = 2;
  47. public static final int INK_STATUS_INK_LOW = 1;
  48. public static final int INK_STATUS_NORMAL = 0;
  49. private static final int ISSETDEVICE_DEVICE_NOT_SET = 0;
  50. private static final int ISSETDEVICE_LOCAL_DEVICE_SET = -1;
  51. private static final int ISSETDEVICE_REMOTE_DEVICE_SET = -2;
  52. private static final String LOG_TAG = "iPrintSharedActivity";
  53. public static final String PACKAGE_PANASONIC_FAX = "com.panasonic.psn.fax";
  54. public static final String PARAM_KEY_CALLER_PACKAGE_NAME = "PACKAGE_NAME";
  55. private static final int REQUEST_CODE_LICENSE_CHECK = 101;
  56. private static final int REQUEST_PHOTO_CUSTOM = 10;
  57. private static final int REQUEST_RUNTIMEPERMMISSION = 100;
  58. private static final int REQUEST_SCAN_CUSTOM = 20;
  59. private static final int REQUEST_STATUS_CUSTOM = 99;
  60. private static final int REQUEST_WEB_CUSTOM = 30;
  61. public static final int RESULT_NO_SD_ERROR = 1;
  62. public static final int RESULT_PARAM_ERROR = 0;
  63. Handler mHandler = new Handler() {
  64. public void handleMessage(Message message) {
  65. if (message.what != 0) {
  66. EPLog.m318w(EpsoniPrintSharedActivity.LOG_TAG, "handleMessage::default");
  67. EpsoniPrintSharedActivity.this.CleanUp();
  68. return;
  69. }
  70. EPLog.m313i(EpsoniPrintSharedActivity.LOG_TAG, "handleMessage::0");
  71. EpsoniPrintSharedActivity.this.setWait();
  72. }
  73. };
  74. private DialogProgressViewModel mModelDialog;
  75. private Thread thread;
  76. /* access modifiers changed from: protected */
  77. public void onCreate(Bundle bundle) {
  78. EPLog.m313i(LOG_TAG, "onCreate");
  79. super.onCreate(bundle);
  80. this.mModelDialog = (DialogProgressViewModel) ViewModelProviders.m2of((FragmentActivity) this).get(DialogProgressViewModel.class);
  81. this.mModelDialog.getDialogJob().observe(this, new Observer() {
  82. public final void onChanged(Object obj) {
  83. EpsoniPrintSharedActivity.lambda$onCreate$0(EpsoniPrintSharedActivity.this, (Deque) obj);
  84. }
  85. });
  86. NewLoggerController.stopLoggerIfNotAgreed(this);
  87. if (bundle == null) {
  88. startLicenseCheckActivity();
  89. } else if (!IprintLicenseInfo.isAgreedCurrentVersion(this)) {
  90. finish();
  91. } else {
  92. nextOnCreate();
  93. }
  94. }
  95. public static /* synthetic */ void lambda$onCreate$0(EpsoniPrintSharedActivity epsoniPrintSharedActivity, Deque deque) {
  96. String[] checkQueue = epsoniPrintSharedActivity.mModelDialog.checkQueue();
  97. if (checkQueue != null) {
  98. String str = checkQueue[0];
  99. String str2 = checkQueue[1];
  100. if (str2.equals("do_show")) {
  101. epsoniPrintSharedActivity.showDialog(str);
  102. }
  103. if (str2.equals("do_dismiss")) {
  104. epsoniPrintSharedActivity.dismissDialog(str);
  105. }
  106. }
  107. }
  108. private void startLicenseCheckActivity() {
  109. IprintLicenseInfo.beforeLicenseCheck(getApplicationContext());
  110. startActivityForResult(LicenseTopActivity.getStartIntent(getApplicationContext(), new IprintLicenseInfo(), new IprintUserSurveyInfo()), 101);
  111. }
  112. private void nextOnCreate() {
  113. Intent intent = getIntent();
  114. intent.getAction();
  115. if (intent.getExtras() != null) {
  116. try {
  117. InitTempFolder();
  118. CheckAction(intent.getAction());
  119. ManagePreferences managePreferences = new ManagePreferences();
  120. managePreferences.resetSavedFlag(getApplicationContext(), "PrintSetting");
  121. managePreferences.pushPreferrences(getApplicationContext());
  122. String action = intent.getAction();
  123. if (action.equals(GET_PRINTER_INFORMATION)) {
  124. Intent intent2 = new Intent();
  125. intent2.setClassName(getPackageName(), ACTIVITY_GET_PRINTER_INFORMATION);
  126. startActivityForResult(intent2, 99);
  127. } else if (action.equals(ACTION_CONFIRM_PRINTER_SCANNER_SELECTION)) {
  128. setPrinterScannerSelectionInfo();
  129. } else {
  130. if (!IprintLicenseInfo.isAgreedCurrentVersion(this)) {
  131. finish();
  132. }
  133. this.mHandler.sendEmptyMessage(0);
  134. }
  135. } catch (SharedDataException e) {
  136. e.printStackTrace();
  137. setResult(1);
  138. finish();
  139. } catch (IOException e2) {
  140. e2.printStackTrace();
  141. setResult(2);
  142. finish();
  143. }
  144. } else {
  145. throw new SharedDataException("bundle null error");
  146. }
  147. }
  148. private boolean CheckAction(String str) throws SharedDataException {
  149. if (str.equals(ACTION_PHOTO_PRINT) || str.equals(ACTION_SCAN) || str.equals(ACTION_WEB_PRINT) || str.equals(GET_PRINTER_INFORMATION) || str.equals(ACTION_CONFIRM_PRINTER_SCANNER_SELECTION)) {
  150. return true;
  151. }
  152. throw new SharedDataException("action error");
  153. }
  154. public void run() {
  155. EPLog.m313i(LOG_TAG, "run");
  156. try {
  157. Thread.sleep(100);
  158. } catch (InterruptedException unused) {
  159. }
  160. EPLog.m313i(LOG_TAG, "run::1");
  161. this.mHandler.sendEmptyMessage(1);
  162. }
  163. /* access modifiers changed from: private */
  164. public void setWait() {
  165. this.mModelDialog.doShow(DIALOG_WAIT);
  166. this.thread = new Thread(new Runnable() {
  167. public void run() {
  168. EpsoniPrintSharedActivity.this.backgroundJob();
  169. }
  170. });
  171. try {
  172. if (ActivityRequestPermissions.isRuntimePermissionSupported() && getIntent().getAction().equals(ACTION_PHOTO_PRINT) && 4 == getIntent().getExtras().getInt("FILE_TYPE", 2)) {
  173. String[] strArr = {"android.permission.WRITE_EXTERNAL_STORAGE"};
  174. ActivityRequestPermissions.Permission permission = new ActivityRequestPermissions.Permission(strArr[0], new String[]{getString(R.string.permission_dialog_title), getString(R.string.permission_dialog_title)}, new String[]{ActivityRequestPermissions.DialogParameter.setMessage2((Context) this, getString(R.string.permission_dialog_message_storage)), ActivityRequestPermissions.DialogParameter.setMessage3A((Context) this, getString(R.string.permission_dialog_message_storage), getString(R.string.permission_function_storage))});
  175. if (!ActivityRequestPermissions.checkPermission(this, strArr)) {
  176. ActivityRequestPermissions.requestPermission((Activity) this, permission, 100);
  177. return;
  178. }
  179. }
  180. } catch (Exception e) {
  181. e.printStackTrace();
  182. }
  183. this.thread.start();
  184. }
  185. /* access modifiers changed from: private */
  186. public void backgroundJob() {
  187. int i;
  188. EPLog.m313i(LOG_TAG, "backgroundJob");
  189. Intent intent = getIntent();
  190. if (intent == null) {
  191. setResult(1);
  192. finish();
  193. return;
  194. }
  195. Intent intent2 = new Intent();
  196. Bundle extras = intent.getExtras();
  197. if (extras == null) {
  198. setResult(1);
  199. finish();
  200. return;
  201. }
  202. try {
  203. if (intent.getAction().equals(ACTION_PHOTO_PRINT)) {
  204. SharedParamPhoto sharedParamPhoto = new SharedParamPhoto();
  205. sharedParamPhoto.setParam(extras);
  206. if (sharedParamPhoto.getPackage_name().indexOf(PACKAGE_PANASONIC_FAX) != -1) {
  207. new ManagePreferences().setPreferences(PACKAGE_PANASONIC_FAX, getApplicationContext());
  208. } else {
  209. new ManagePreferences().setPreferences(sharedParamPhoto.getMedia_type(), sharedParamPhoto.getMedia_size(), sharedParamPhoto.getColor_mode(), sharedParamPhoto.getLayout_type(), getApplicationContext());
  210. }
  211. if (sharedParamPhoto.isTIFF()) {
  212. convertTiff(sharedParamPhoto);
  213. }
  214. intent2.setClass(this, ActivityViewImageSelect.class);
  215. intent2.setAction(intent.getAction());
  216. intent2.putExtra("extParam", sharedParamPhoto);
  217. intent2.putExtra("print_log", getPhotoPrintLog(sharedParamPhoto.getPackage_name(), 4097));
  218. i = 10;
  219. } else if (intent.getAction().equals(ACTION_SCAN)) {
  220. SharedParamScan sharedParamScan = new SharedParamScan();
  221. sharedParamScan.setParam(extras);
  222. if (sharedParamScan.getPixel_main() <= 0 || sharedParamScan.getPixel_sub() <= 0 || sharedParamScan.getRes_main() <= 0 || sharedParamScan.getRes_sub() <= 0) {
  223. throw new SharedDataException("resolution or pixel error.");
  224. }
  225. intent2.setClass(this, ScanActivity.class);
  226. intent2.setAction(intent.getAction());
  227. intent2.putExtra("extParam", sharedParamScan);
  228. intent2.putExtra(ScanActivity.PARAM_KEY_SCAN_LOG, getScanLog(getCallerPackage(intent2)));
  229. i = 20;
  230. } else if (intent.getAction().equals(ACTION_WEB_PRINT)) {
  231. String charSequence = extras.getCharSequence("URL").toString();
  232. if (charSequence.length() > 0) {
  233. intent2.setClass(this, WebviewActivity.class);
  234. intent2.setAction(intent.getAction());
  235. intent2.putExtra("android.intent.extra.TEXT", charSequence);
  236. intent2.putExtra("print_log", getPhotoPrintLog(extras.getString(PARAM_KEY_CALLER_PACKAGE_NAME), PrintLog.PRINT_SOURCE_EXTERNAL_APP_WEB));
  237. i = 30;
  238. } else {
  239. throw new SharedDataException("URL error");
  240. }
  241. } else {
  242. setResult(1);
  243. finish();
  244. return;
  245. }
  246. startActivityForResult(intent2, i);
  247. this.mHandler.sendEmptyMessageDelayed(1, 500);
  248. } catch (SharedDataException e) {
  249. e.printStackTrace();
  250. setResult(1);
  251. finish();
  252. } catch (NullPointerException e2) {
  253. e2.printStackTrace();
  254. setResult(1);
  255. finish();
  256. }
  257. }
  258. private String getCallerPackage(Intent intent) {
  259. String stringExtra;
  260. if (intent == null || (stringExtra = intent.getStringExtra(PARAM_KEY_CALLER_PACKAGE_NAME)) == null) {
  261. return getCallingPackage();
  262. }
  263. return stringExtra;
  264. }
  265. private CommonLog getScanLog(String str) {
  266. CommonLog commonLog = new CommonLog();
  267. commonLog.action = PrintLog.ACTION_EXTERNAL_APP_SCAN;
  268. commonLog.callerPackage = str;
  269. return commonLog;
  270. }
  271. private PrintLog getPhotoPrintLog(String str, int i) {
  272. PrintLog printLog = new PrintLog();
  273. printLog.uiRoute = i;
  274. printLog.callerPackage = str;
  275. if (printLog.callerPackage == null) {
  276. printLog.callerPackage = getCallingPackage();
  277. }
  278. return printLog;
  279. }
  280. private int checkPrinterSelection() {
  281. if (getSharedPreferences("PrintSetting", 0).getString(Constants.PRINTER_NAME, "").length() <= 0) {
  282. return 0;
  283. }
  284. return MyPrinter.isRemotePrinter(this) ? -2 : -1;
  285. }
  286. private int checkScannerSelection() {
  287. String prefString = Utils.getPrefString(getApplicationContext(), Constants.SCAN_REFS_USED_SCANNER_PATH, Constants.SCAN_REFS_SCANNER_MODEL);
  288. return (prefString.equals(getString(R.string.str_lbl_title_scan)) || prefString.equals("")) ? 0 : -1;
  289. }
  290. private void setPrinterScannerSelectionInfo() {
  291. int i;
  292. switch (getIntent().getIntExtra("DEVICE_TYPE", -1)) {
  293. case 0:
  294. i = checkPrinterSelection();
  295. break;
  296. case 1:
  297. i = checkScannerSelection();
  298. break;
  299. default:
  300. i = 1;
  301. break;
  302. }
  303. setResult(i);
  304. finish();
  305. }
  306. private void convertTiff(SharedParamPhoto sharedParamPhoto) {
  307. EPImageUtil ePImageUtil = new EPImageUtil();
  308. ArrayList<String> arrayFileFullPath = sharedParamPhoto.getArrayFileFullPath();
  309. ArrayList<String> arrayFilePath = sharedParamPhoto.getArrayFilePath();
  310. for (int i = 0; i < arrayFilePath.size(); i++) {
  311. String tempSharedDir = ExternalFileUtils.getInstance(this).getTempSharedDir();
  312. ePImageUtil.tiff2bmp(arrayFileFullPath.get(i), new File(tempSharedDir, Utils.getPreffix(arrayFilePath.get(i)) + ".bmp").getPath());
  313. String tempSharedDir2 = ExternalFileUtils.getInstance(this).getTempSharedDir();
  314. sharedParamPhoto.setArrayFileFullPath(i, new File(tempSharedDir2, Utils.getPreffix(arrayFilePath.get(i)) + ".bmp").getPath());
  315. }
  316. }
  317. private void showDialog(String str) {
  318. DialogProgress dialogProgress;
  319. if (((str.hashCode() == 23812620 && str.equals(DIALOG_WAIT)) ? (char) 0 : 65535) != 0) {
  320. dialogProgress = null;
  321. } else {
  322. dialogProgress = DialogProgress.newInstance(str, 0, getString(R.string.str_wait));
  323. }
  324. if (dialogProgress != null) {
  325. dialogProgress.setCancelable(true);
  326. dialogProgress.show(getSupportFragmentManager(), str);
  327. }
  328. }
  329. private void dismissDialog(String str) {
  330. DialogFragment dialogFragment = (DialogFragment) getSupportFragmentManager().findFragmentByTag(str);
  331. if (dialogFragment != null) {
  332. dialogFragment.dismiss();
  333. }
  334. }
  335. /* access modifiers changed from: protected */
  336. public void onActivityResult(int i, int i2, Intent intent) {
  337. super.onActivityResult(i, i2, intent);
  338. EPLog.m313i(LOG_TAG, "onActivityResult::requestCode = " + i + "/requestCode = " + i2);
  339. if (i == 10) {
  340. setResult(i2);
  341. } else if (i == 20) {
  342. Intent intent2 = new Intent();
  343. if (intent != null) {
  344. intent2.putExtra("FILE_NAME", ScanActivity.getScanFileListFromReturnIntent(intent));
  345. }
  346. setResult(i2, intent2);
  347. } else if (i != 30) {
  348. switch (i) {
  349. case 99:
  350. Intent intent3 = new Intent();
  351. if (intent == null) {
  352. setResult(i2);
  353. break;
  354. } else {
  355. SharedParamStatus sharedParamStatus = (SharedParamStatus) intent.getSerializableExtra("extStatus");
  356. if (sharedParamStatus == null) {
  357. setResult(i2);
  358. break;
  359. } else {
  360. intent3.putExtra(Constants.PRINTER_NAME, sharedParamStatus.getPrinter_name());
  361. intent3.putExtra("INK_NAME", sharedParamStatus.getArrayOutInkName());
  362. intent3.putExtra("INK_REMAIN", sharedParamStatus.getArrayOutInkRemain());
  363. intent3.putExtra("STATUS_VALUE", sharedParamStatus.getPrinter_status());
  364. intent3.putExtra("DEVICE_ID", sharedParamStatus.getPrinter_name());
  365. intent3.putExtra("INK_STATUS", sharedParamStatus.getExternInkStatus());
  366. setResult(i2, intent3);
  367. break;
  368. }
  369. }
  370. case 100:
  371. if (i2 == -1) {
  372. this.thread.start();
  373. break;
  374. } else {
  375. setResult(0);
  376. finish();
  377. break;
  378. }
  379. case 101:
  380. if (i2 != -1) {
  381. finish();
  382. return;
  383. } else {
  384. nextOnCreate();
  385. return;
  386. }
  387. }
  388. } else {
  389. setResult(i2);
  390. }
  391. finish();
  392. }
  393. /* access modifiers changed from: protected */
  394. public void onDestroy() {
  395. super.onDestroy();
  396. ManagePreferences managePreferences = new ManagePreferences();
  397. if (managePreferences.getSavedFlag(getApplicationContext(), "PrintSetting") == 0) {
  398. EPLog.m313i(LOG_TAG, "Preference 戻す");
  399. managePreferences.popPreferrences(getApplicationContext());
  400. }
  401. CleanUp();
  402. try {
  403. InitTempFolder();
  404. } catch (IOException unused) {
  405. }
  406. }
  407. /* access modifiers changed from: private */
  408. public void CleanUp() {
  409. Thread thread2 = this.thread;
  410. if (thread2 != null && thread2.isAlive()) {
  411. this.thread.interrupt();
  412. this.thread = null;
  413. }
  414. this.mModelDialog.doDismiss(DIALOG_WAIT);
  415. }
  416. private void InitTempFolder() throws IOException {
  417. ExternalFileUtils.getInstance(this).initTempSharedDir();
  418. }
  419. }