worker-automate-hub 0.4.361__tar.gz → 0.4.363__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (72) hide show
  1. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/PKG-INFO +1 -1
  2. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/pyproject.toml +1 -1
  3. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/sped_fiscal.py +33 -75
  4. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/task_executor.py +15 -2
  5. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/README.md +0 -0
  6. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/__init__.py +0 -0
  7. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/__init__.py +0 -0
  8. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/ahead_service.py +0 -0
  9. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/client.py +0 -0
  10. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/helpers/__init__.py +0 -0
  11. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/helpers/api_helpers.py +0 -0
  12. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/api/rpa_historico_service.py +0 -0
  13. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/cli.py +0 -0
  14. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/config/__init__.py +0 -0
  15. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/config/settings.py +0 -0
  16. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/config.py +0 -0
  17. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/core/so_manipulation.py +0 -0
  18. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/__init__.py +0 -0
  19. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/deprecation.py +0 -0
  20. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/rate_limit.py +0 -0
  21. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/repeat.py +0 -0
  22. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/retry.py +0 -0
  23. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/singleton.py +0 -0
  24. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/decorators/timeit.py +0 -0
  25. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/__init__.py +0 -0
  26. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dao/__init__.py +0 -0
  27. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dao/rpa_configuracao.py +0 -0
  28. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dao/rpa_historico.py +0 -0
  29. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dao/rpa_processo.py +0 -0
  30. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dto/__init__.py +0 -0
  31. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dto/rpa_historico_request_dto.py +0 -0
  32. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dto/rpa_processo_entrada_dto.py +0 -0
  33. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/models/dto/rpa_sistema_dto.py +0 -0
  34. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/__init__.py +0 -0
  35. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/__init__.py +0 -0
  36. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/coleta_dje_process.py +0 -0
  37. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/conexao_rdp.py +0 -0
  38. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/descartes.py +0 -0
  39. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_estadual_go.py +0 -0
  40. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_estadual_main.py +0 -0
  41. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_estadual_mt.py +0 -0
  42. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_estadual_sc.py +0 -0
  43. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_estadual_sp.py +0 -0
  44. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/ecac_federal.py +0 -0
  45. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_15.py +0 -0
  46. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_16.py +0 -0
  47. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_207.py +0 -0
  48. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_32.py +0 -0
  49. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_33.py +0 -0
  50. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_34.py +0 -0
  51. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_36.py +0 -0
  52. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_39.py +0 -0
  53. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_500.py +0 -0
  54. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_505.py +0 -0
  55. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_7139.py +0 -0
  56. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/entrada_de_notas_9.py +0 -0
  57. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/exemplo_processo.py +0 -0
  58. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/fidc_gerar_nosso_numero.py +0 -0
  59. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/fidc_remessa_cobranca_cnab240.py +0 -0
  60. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/login_emsys.py +0 -0
  61. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/playground.py +0 -0
  62. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/jobs/transferencias.py +0 -0
  63. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/tasks/task_definitions.py +0 -0
  64. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/__init__.py +0 -0
  65. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/env.py +0 -0
  66. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/get_creds_gworkspace.py +0 -0
  67. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/logger.py +0 -0
  68. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/toast.py +0 -0
  69. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/updater.py +0 -0
  70. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/util.py +0 -0
  71. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/utils/utils_nfe_entrada.py +0 -0
  72. {worker_automate_hub-0.4.361 → worker_automate_hub-0.4.363}/worker_automate_hub/worker.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: worker-automate-hub
3
- Version: 0.4.361
3
+ Version: 0.4.363
4
4
  Summary: Worker Automate HUB é uma aplicação para automatizar rotinas de RPA nos ambientes Argenta.
5
5
  Author: Joel Paim
6
6
  Requires-Python: >=3.12,<4.0
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "worker-automate-hub"
3
- version = "0.4.361"
3
+ version = "0.4.363"
4
4
  description = "Worker Automate HUB é uma aplicação para automatizar rotinas de RPA nos ambientes Argenta."
5
5
  authors = ["Joel Paim"]
6
6
  readme = "README.md"
@@ -2,7 +2,7 @@ import getpass
2
2
  import warnings
3
3
  import os
4
4
  import uuid
5
- import datetime
5
+ from datetime import datetime
6
6
 
7
7
  import pyautogui
8
8
  import pytesseract
@@ -393,91 +393,49 @@ async def sped_fiscal(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoDTO:
393
393
  status=RpaHistoricoStatusEnum.Falha,
394
394
  )
395
395
 
396
- app = Application().connect(class_name="TMsgBox")
397
- main_window = app["Informação"]
398
-
399
- main_window.set_focus()
400
-
401
- console.print(f"Obtendo texto do Informação...\n")
402
- console.print(f"Tirando print da janela do Information para realização do OCR...\n")
403
-
404
- window_rect = main_window.rectangle()
405
- screenshot = pyautogui.screenshot(
406
- region=(
407
- window_rect.left,
408
- window_rect.top,
409
- window_rect.width(),
410
- window_rect.height(),
411
- )
412
- )
413
- username = getpass.getuser()
414
- path_to_png = f"C:\\Users\\{username}\\Downloads\\information_popup_{short_uuid}_{filial_cod}.png"
415
- screenshot.save(path_to_png)
416
- console.print(f"Print salvo em {path_to_png}...\n")
417
-
418
- console.print(
419
- f"Preparando a imagem para maior resolução e assertividade no OCR...\n"
420
- )
421
- image = Image.open(path_to_png)
422
- image = image.convert("L")
423
- enhancer = ImageEnhance.Contrast(image)
424
- image = enhancer.enhance(2.0)
425
- image.save(path_to_png)
426
- console.print(f"Imagem preparada com sucesso...\n")
427
- console.print(f"Realizando OCR...\n")
428
- captured_text = pytesseract.image_to_string(Image.open(path_to_png))
429
- console.print(
430
- f"Texto Full capturado {captured_text}...\n"
431
- )
432
- os.remove(path_to_png)
433
- if 'arquivo do sped ger' in captured_text.lower():
434
- console.print("\nArquivo do SPED gerado com sucesso...", style="bold green")
435
- await worker_sleep(6)
436
-
437
- console.log("Realizando o envio para o Backoffice...\n")
438
- file_bytes = ""
439
- with open(temp_path_to_txt, 'rb') as file:
440
- file_bytes = file.read()
441
-
442
-
443
- get_historico = get_historico_by_processo_identificador(filial_cod, task.nomProcesso)
444
- if get_historico["sucesso"] == True:
445
- data = get_historico["retorno"]
446
- id_historico = data[0]['uuidHistorico']
447
- timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
448
- desArquivo = f"ArquivoSped_{filial_cod}_{timestamp}.txt"
449
- try:
450
- send_file(id_historico, desArquivo, "text", file_bytes, file_extension="txt")
451
- result = "Arquivo do SPED gerado com sucesso e arquivo salvo no Backoffice !"
452
- os.remove(temp_path_to_txt)
453
- return RpaRetornoProcessoDTO(
454
- sucesso=True,
455
- retorno=result,
456
- status=RpaHistoricoStatusEnum.Sucesso,
457
- )
458
- except Exception as e:
459
- result = f"Arquivo do SPED gerado com sucesso, porém gerou erro ao realizar o envio para o backoffice {e} - Arquivo ainda salvo na dispositivo utilizado no diretório {temp_path_to_txt} !"
460
- console.print(result, style="bold red")
461
-
462
- return RpaRetornoProcessoDTO(
463
- sucesso=False,
464
- retorno=result,
465
- status=RpaHistoricoStatusEnum.Falha,
466
- )
467
- else:
468
- result = f"Arquivo do SPED gerado com sucesso, porém não foi possivel obter o id do historico para envio do arquivo, retorno {get_historico["retorno"]} - Arquivo ainda salvo na dispositivo utilizado no diretório {temp_path_to_txt}"
396
+
397
+ console.print("\nArquivo do SPED gerado com sucesso...", style="bold green")
398
+ console.log("Realizando o envio para o Backoffice...\n")
399
+ file_bytes = ""
400
+ with open(temp_path_to_txt, 'rb') as file:
401
+ file_bytes = file.read()
402
+ await worker_sleep(6)
403
+
404
+ console.print(f"Codigo da filial a ser utilizada como identificador: {filial_cod}...\n")
405
+ console.print(f"Nome do processo a ser utilizada como identificador: {task.nomProcesso}\n")
406
+ get_historico = await get_historico_by_processo_identificador(filial_cod, task.nomProcesso)
407
+ if get_historico["sucesso"] == True:
408
+ data = get_historico["retorno"]
409
+ id_historico = data[0]['uuidHistorico']
410
+ timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
411
+ desArquivo = f"ArquivoSped_{filial_cod}_{timestamp}.txt"
412
+ try:
413
+ send_file(id_historico, desArquivo, "text", file_bytes, file_extension="txt")
414
+ result = "Arquivo do SPED gerado com sucesso e arquivo salvo no Backoffice !"
415
+ os.remove(temp_path_to_txt)
416
+ return RpaRetornoProcessoDTO(
417
+ sucesso=True,
418
+ retorno=result,
419
+ status=RpaHistoricoStatusEnum.Sucesso,
420
+ )
421
+ except Exception as e:
422
+ result = f"Arquivo do SPED gerado com sucesso, porém gerou erro ao realizar o envio para o backoffice {e} - Arquivo ainda salvo na dispositivo utilizado no diretório {temp_path_to_txt} !"
469
423
  console.print(result, style="bold red")
424
+
470
425
  return RpaRetornoProcessoDTO(
471
426
  sucesso=False,
472
427
  retorno=result,
473
428
  status=RpaHistoricoStatusEnum.Falha,
474
429
  )
475
430
  else:
431
+ result = f"Arquivo do SPED gerado com sucesso, porém não foi possivel obter o id do historico para envio do arquivo, retorno {get_historico["retorno"]} - Arquivo ainda salvo na dispositivo utilizado no diretório {temp_path_to_txt}"
432
+ console.print(result, style="bold red")
476
433
  return RpaRetornoProcessoDTO(
477
434
  sucesso=False,
478
- retorno=f"Pop_up Informação não mapeado para andamento do robô, mensagem {captured_text}",
435
+ retorno=result,
479
436
  status=RpaHistoricoStatusEnum.Falha,
480
437
  )
438
+
481
439
  except Exception as e:
482
440
  console.print(f"Erro ao conectar à janela Informação: {e}\n")
483
441
  return RpaRetornoProcessoDTO(
@@ -135,6 +135,13 @@ async def _store_historico(
135
135
  tz = timezone("America/Sao_Paulo")
136
136
  start_time = datetime.now(tz).isoformat()
137
137
 
138
+ identificador_processo = (
139
+ task.configEntrada.get("nfe") or
140
+ task.configEntrada.get("empresa") or
141
+ ""
142
+ )
143
+
144
+
138
145
  # Armazenar início da operação no histórico
139
146
  start_data = RpaHistoricoRequestDTO(
140
147
  uuidProcesso=task.uuidProcesso,
@@ -144,7 +151,7 @@ async def _store_historico(
144
151
  configEntrada=task.configEntrada,
145
152
  datInicioExecucao=start_time,
146
153
  datEntradaFila=task.datEntradaFila,
147
- identificador=task.configEntrada.get("nfe", ""),
154
+ identificador=identificador_processo,
148
155
  )
149
156
 
150
157
  store_response: RpaHistorico = await store(start_data)
@@ -193,6 +200,12 @@ async def _update_historico(
193
200
  des_status: RpaHistoricoStatusEnum = retorno_processo.status
194
201
  end_time = datetime.now(tz).isoformat()
195
202
 
203
+ identificador_processo = (
204
+ task.configEntrada.get("nfe") or
205
+ task.configEntrada.get("empresa") or
206
+ ""
207
+ )
208
+
196
209
  # Armazenar fim da operação no histórico
197
210
  end_data = RpaHistoricoRequestDTO(
198
211
  uuidHistorico=historico_uuid,
@@ -203,7 +216,7 @@ async def _update_historico(
203
216
  configEntrada=task.configEntrada,
204
217
  retorno=retorno_processo,
205
218
  datFimExecucao=end_time,
206
- identificador=task.configEntrada.get("nfe", ""),
219
+ identificador=identificador_processo,
207
220
  )
208
221
 
209
222
  update_response: RpaHistorico = await update(end_data)