EpsoniPrintSharedActivity.java 19 KB

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