EpsoniPrintSharedActivity.java 19 KB

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