worker-automate-hub 0.5.795__py3-none-any.whl → 0.5.797__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of worker-automate-hub might be problematic. Click here for more details.

@@ -59,124 +59,110 @@ Existem 3 subcomandos disponíveis para essa aplicação
59
59
  [green][b]worker[/][/] --version
60
60
 
61
61
  [b]Para gerar o arquivo de configuração[/]
62
- [green][b]worker[/][/] --configure
62
+ [green][b]worker[/][/] configure
63
63
 
64
64
  [b]Para informações detalhadas
65
65
  [blue][link=https://github.com/SIM-Rede/worker-automate-hub]Repo no GIT Argenta[/][/] | [blue][link=https://pypi.org/project/worker-automate-hub/]Publicação no PyPI[/][/]
66
66
  """
67
67
 
68
68
 
69
- def function_help(flag: bool):
70
- if flag:
69
+ @app.callback(invoke_without_command=True)
70
+ def main(
71
+ ctx: Context,
72
+ version: bool = Option(
73
+ False,
74
+ "--version",
75
+ help="Mostra a versão instalada",
76
+ is_flag=True,
77
+ ),
78
+ ):
79
+ """Comando principal"""
80
+ if ctx.invoked_subcommand:
81
+ return
82
+
83
+ if version:
71
84
  console.print(
72
85
  importlib.metadata.version("worker-automate-hub"),
73
86
  style="bold blue",
74
87
  )
75
88
  raise Exit(code=0)
76
89
 
90
+ console.print(HELP_MESSAGE)
77
91
 
78
- def function_configure(flag: bool):
79
-
80
- if flag:
81
- console.clear()
82
- environment_names = [
83
- "local",
84
- "qa",
85
- "main",
86
- ]
87
- q = [
88
- inquirer.Text("vault_token", "Por favor digite o token do Vault"),
89
- inquirer.List("env_list", "Selecione o ambiente", environment_names),
90
- ]
91
- r = inquirer.prompt(q, theme=GreenPassion())
92
-
93
- env_sel, credentials = load_environments(r["env_list"], r["vault_token"])
94
- write_env_config(env_sel, credentials)
95
- workers = asyncio.run(get_workers())
96
-
97
- if workers == None:
98
- console.print("\nNenhum worker encontrado.\n", style="yellow")
99
- raise Exit(code=0)
100
- else:
101
-
102
- nomes_workers = [worker["nomRobo"] for worker in workers]
103
- q2 = [
104
- inquirer.List(
105
- "worker_list", "Selecione um Worker", choices=nomes_workers
106
- )
107
- ]
108
- r2 = inquirer.prompt(q2, theme=GreenPassion())
109
- worker_sel = next(
110
- worker for worker in workers if worker["nomRobo"] == r2["worker_list"]
111
- )
112
- add_worker_config(worker_sel)
113
-
114
- q3 = [
115
- inquirer.Confirm(
116
- "reg_config",
117
- message="Adicionar configuração de inicialização aos registros do Windows?",
118
- )
119
- ]
120
- r3 = inquirer.prompt(q3, theme=GreenPassion())
121
-
122
- if r3["reg_config"]:
123
- add_start_on_boot_to_registry()
124
-
125
- q4 = [
126
- inquirer.Confirm(
127
- "assets_config",
128
- message="Atualizar a pasta assets?",
129
- )
130
- ]
131
- r4 = inquirer.prompt(q4, theme=GreenPassion())
132
-
133
- if r4["assets_config"]:
134
- update_assets_v2()
135
-
136
- q5 = [
137
- inquirer.Confirm(
138
- "worker_bat", message="Criar o arquivo worker-startup.bat?"
139
- )
140
- ]
141
- r5 = inquirer.prompt(q5, theme=GreenPassion())
142
-
143
- if r5["worker_bat"]:
144
- create_worker_bat()
145
-
146
- q6 = [
147
- inquirer.Confirm(
148
- "tesseract_install", message="Iniciar a instalação do Tesseract?"
149
- )
150
- ]
151
- r6 = inquirer.prompt(q6, theme=GreenPassion())
152
-
153
- if r6["tesseract_install"]:
154
- asyncio.run(download_tesseract())
155
-
156
- console.print(
157
- "\nConfiguração finalizada com sucesso!\n", style="bold green"
158
- )
159
-
160
- raise Exit(code=0)
161
92
 
93
+ @app.command()
94
+ def configure():
95
+ """Executa o processo interativo de configuração"""
96
+ console.clear()
97
+ environment_names = [
98
+ "local",
99
+ "qa",
100
+ "main",
101
+ ]
102
+ q = [
103
+ inquirer.Text("vault_token", "Por favor digite o token do Vault"),
104
+ inquirer.List("env_list", "Selecione o ambiente", environment_names),
105
+ ]
106
+ r = inquirer.prompt(q, theme=GreenPassion())
107
+
108
+ env_sel, credentials = load_environments(r["env_list"], r["vault_token"])
109
+ write_env_config(env_sel, credentials)
110
+ workers = asyncio.run(get_workers())
111
+
112
+ if workers is None:
113
+ console.print("\nNenhum worker encontrado.\n", style="yellow")
114
+ raise Exit(code=0)
162
115
 
163
- @app.callback(invoke_without_command=True)
164
- def main(
165
- ctx: Context,
166
- version: bool = Option(False, callback=function_help, is_flag=True),
167
- configure: bool = Option(False, callback=function_configure, is_flag=True),
168
- ):
169
- if ctx.invoked_subcommand:
170
- return
171
- console.print(HELP_MESSAGE)
116
+ nomes_workers = [worker["nomRobo"] for worker in workers]
117
+ q2 = [inquirer.List("worker_list", "Selecione um Worker", choices=nomes_workers)]
118
+ r2 = inquirer.prompt(q2, theme=GreenPassion())
119
+ worker_sel = next(
120
+ worker for worker in workers if worker["nomRobo"] == r2["worker_list"]
121
+ )
122
+ add_worker_config(worker_sel)
123
+
124
+ q3 = [
125
+ inquirer.Confirm(
126
+ "reg_config",
127
+ message="Adicionar configuração de inicialização aos registros do Windows?",
128
+ )
129
+ ]
130
+ r3 = inquirer.prompt(q3, theme=GreenPassion())
131
+ if r3["reg_config"]:
132
+ add_start_on_boot_to_registry()
133
+
134
+ q4 = [
135
+ inquirer.Confirm(
136
+ "assets_config",
137
+ message="Atualizar a pasta assets?",
138
+ )
139
+ ]
140
+ r4 = inquirer.prompt(q4, theme=GreenPassion())
141
+ if r4["assets_config"]:
142
+ update_assets_v2()
143
+
144
+ q5 = [inquirer.Confirm("worker_bat", message="Criar o arquivo worker-startup.bat?")]
145
+ r5 = inquirer.prompt(q5, theme=GreenPassion())
146
+ if r5["worker_bat"]:
147
+ create_worker_bat()
148
+
149
+ q6 = [
150
+ inquirer.Confirm(
151
+ "tesseract_install", message="Iniciar a instalação do Tesseract?"
152
+ )
153
+ ]
154
+ r6 = inquirer.prompt(q6, theme=GreenPassion())
155
+ if r6["tesseract_install"]:
156
+ asyncio.run(download_tesseract())
157
+
158
+ console.print("\nConfiguração finalizada com sucesso!\n", style="bold green")
159
+
160
+ raise Exit(code=0)
172
161
 
173
162
 
174
163
  def is_command_running(command):
175
164
  """
176
165
  Verifica se um comando CLI está sendo executado em outro terminal.
177
-
178
- :param command: O comando CLI a ser verificado (lista de strings).
179
- :return: True se o comando estiver sendo executado, False caso contrário.
180
166
  """
181
167
  command_str = " ".join(command)
182
168
  rep = 0
@@ -186,19 +172,11 @@ def is_command_running(command):
186
172
  if cmdline and isinstance(cmdline, list):
187
173
  cmdline_str = " ".join(cmdline)
188
174
  if command_str in cmdline_str:
189
- print(cmdline_str)
190
175
  rep += 1
191
-
192
176
  except (psutil.NoSuchProcess, psutil.AccessDenied, psutil.ZombieProcess):
193
177
  continue
194
178
 
195
- if rep > 1:
196
- return True
197
- else:
198
- return False
199
-
200
-
201
- from typer import Option
179
+ return rep > 1
202
180
 
203
181
 
204
182
  @app.command()
@@ -212,21 +190,23 @@ def run(
212
190
  False,
213
191
  "--assets",
214
192
  help="Executa o download da pasta assets atualizada.",
215
- )
193
+ ),
216
194
  ):
195
+ """Inicializa o worker"""
217
196
  if assets:
218
197
  update_assets_v2()
219
-
198
+
220
199
  command = ["worker", "run"]
221
200
  if not force and is_command_running(command):
222
201
  console.print(
223
202
  "\nO script já está em execução. Saindo...\n", style="bold yellow"
224
203
  )
225
- raise Exit(code=0)
226
- else:
227
- run_worker(stop_event)
204
+ raise Exit(code=0)
205
+
206
+ run_worker(stop_event)
228
207
 
229
208
 
230
209
  @app.command()
231
210
  def update():
211
+ """Força verificação/atualização do worker"""
232
212
  check_for_update(stop_event)
@@ -605,7 +605,7 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
605
605
  console.print(f"Tanque a ser distribuido: {info_distribuicao_obs}... \n")
606
606
  send_keys("^({HOME})")
607
607
  await worker_sleep(1)
608
- send_keys("{DOWN " + str(index_tanque) + "}", pause=0.1)
608
+ send_keys("{DOWN " + str(index_tanque) + "}", pause=0.5)
609
609
  await worker_sleep(1)
610
610
  #Copiar e extrai o Seq Item XML
611
611
  send_keys("^c")
@@ -617,7 +617,7 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
617
617
  item_executado = seq_item
618
618
  else:
619
619
  while seq_item == item_executado:
620
- send_keys("{DOWN}", pause=0.1)
620
+ send_keys("{DOWN}", pause=0.5)
621
621
  index_tanque += 1
622
622
  send_keys("^c")
623
623
  copiado = pyperclip.paste()
@@ -626,12 +626,11 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
626
626
  seq_item = colunas[0]
627
627
 
628
628
  send_keys("+{F10}")
629
- await worker_sleep(1)
629
+ await worker_sleep(2)
630
630
  send_keys("{DOWN 6}")
631
- await worker_sleep(1)
631
+ await worker_sleep(2)
632
632
  send_keys("{ENTER}")
633
633
  await worker_sleep(4)
634
-
635
634
 
636
635
  max_attempts = 5
637
636
  i = 0
@@ -640,7 +639,6 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
640
639
  if distribuir_item_window["IsOpened"] == True:
641
640
  app = Application().connect(title="Distribui Item Tanque")
642
641
  main_window = app["Distribui Item Tanque"]
643
-
644
642
  main_window.set_focus()
645
643
  break
646
644
  else:
@@ -665,11 +663,11 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
665
663
  center_y = (grid_rect.top + grid_rect.bottom) // 2
666
664
 
667
665
  pyautogui.click(center_x, center_y)
668
- await worker_sleep(3)
666
+ await worker_sleep(4)
669
667
  send_keys("^({HOME})")
670
- await worker_sleep(3)
668
+ await worker_sleep(4)
671
669
  send_keys("{LEFT 3}")
672
- await worker_sleep(3)
670
+ await worker_sleep(4)
673
671
 
674
672
  distribuiu_algo = False
675
673
  distribuicao_atual = []
@@ -714,11 +712,11 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
714
712
  quantidade_combustivel = re.findall(r'\((.*?)\)', second_info_distribuicao_obs)[0].replace('.', '')
715
713
 
716
714
  send_keys("{LEFT 3}")
717
- await worker_sleep(1)
715
+ await worker_sleep(2)
718
716
  send_keys("{RIGHT 3}")
719
717
 
720
718
  pyautogui.press('enter')
721
- await worker_sleep(1)
719
+ await worker_sleep(2)
722
720
  pyautogui.write(quantidade_combustivel)
723
721
  pyautogui.press('enter')
724
722
  list_tanques_distribuidos.append(second_info_distribuicao_obs)
@@ -1372,4 +1370,4 @@ async def entrada_de_notas_9(task: RpaProcessoEntradaDTO) -> RpaRetornoProcessoD
1372
1370
 
1373
1371
  finally:
1374
1372
  # Deleta o xml
1375
- await delete_xml(nota["nfe"])
1373
+ await delete_xml(nota["nfe"])
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: worker-automate-hub
3
- Version: 0.5.795
3
+ Version: 0.5.797
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
@@ -9,7 +9,7 @@ worker_automate_hub/api/rdp_service.py,sha256=L7orr60FkJr6zjETtA4me8tRYCW9m1g-i5
9
9
  worker_automate_hub/api/rpa_fila_service.py,sha256=Oa7w61NrCMgVxPZjNfJn4GYBl7aU2lRIoKpFmmajuvM,1955
10
10
  worker_automate_hub/api/rpa_historico_service.py,sha256=KuxcytNhlxjEe4R-LShmZGAFasLIVtpCHD5ykCmgf7E,10073
11
11
  worker_automate_hub/api/webhook_service.py,sha256=S1a8IIS5LYY16I5E2pPPczaUnUz-_CwmD9_1QBdQD2g,1879
12
- worker_automate_hub/cli.py,sha256=rsFq4ARo1vnHzFYpP6sWRH1YH3EOnE9hfgqWBGOuVNc,6861
12
+ worker_automate_hub/cli.py,sha256=W_nDVre9XQ3msWncivBahAMfzpgSOdhE9MOkXT1ETQ8,6077
13
13
  worker_automate_hub/config/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
14
14
  worker_automate_hub/config/settings.py,sha256=4BkIYV0C9C_tl68WNfw3aoywr1-_bRJsKysSnSRALT0,2450
15
15
  worker_automate_hub/config.py,sha256=IDGBsScaX6X4tSXEGj-6CJKJQwKeiFDVAQ8k_ajwUV4,204
@@ -66,7 +66,7 @@ worker_automate_hub/tasks/jobs/entrada_de_notas_500.py,sha256=WBsCRbH7ANiCjEn0aE
66
66
  worker_automate_hub/tasks/jobs/entrada_de_notas_503.py,sha256=bcNKy6X1aaVe6lxW-TMyUKJ_GXzHEK-8V6x9SOzOshw,48365
67
67
  worker_automate_hub/tasks/jobs/entrada_de_notas_505.py,sha256=xXeNipdXTSll8yAtAmN7v0sjN3oMlWU4THu30mKDddc,30339
68
68
  worker_automate_hub/tasks/jobs/entrada_de_notas_7139.py,sha256=7POfKc7nisc8-ysgqazrK8kT7kmFIq8irGwCMixPAE0,37948
69
- worker_automate_hub/tasks/jobs/entrada_de_notas_9.py,sha256=PrDoHwiwGb3JPSnpM54TjUuXz_-Ymusk5A_zS-ynQ6I,67509
69
+ worker_automate_hub/tasks/jobs/entrada_de_notas_9.py,sha256=tayKjzymLS96a46st3PTSGEUO7Tm3Et5zZB237apZBs,67507
70
70
  worker_automate_hub/tasks/jobs/entrada_de_notas_9000.py,sha256=0mOmS28tQKF5m7vMzInblDuWH48_qIgrohOU5UwYZ10,65498
71
71
  worker_automate_hub/tasks/jobs/exemplo_processo.py,sha256=nV0iLoip2FH2-FhLmhX3nPqsfl_MPufZ3E5Q5krJvdc,3544
72
72
  worker_automate_hub/tasks/jobs/extracao_fechamento_contabil.py,sha256=6Kr5DKjKLqtFvGzyiXtt7xrQsuU898l8pQXDq9C6AX8,19567
@@ -102,7 +102,7 @@ worker_automate_hub/utils/updater.py,sha256=en2FCGhI8aZ-JNP3LQm64NJDc4awCNW7UhbV
102
102
  worker_automate_hub/utils/util.py,sha256=noQRUSAjRnoDb1c4iMZ5eoyrNp59a8T9K78MHhalASw,210255
103
103
  worker_automate_hub/utils/utils_nfe_entrada.py,sha256=F7jk95LpDwl5WfaQXahCA5yDdnySnWdctDqczHXwGqE,38195
104
104
  worker_automate_hub/worker.py,sha256=zEnYUrm5kY2cHbbee15QJkwkx4euD2SB2zRvUIbjS90,6850
105
- worker_automate_hub-0.5.795.dist-info/entry_points.txt,sha256=sddyhjx57I08RY8X7UxcTpdoOsWULAWNKN9Xr6pp_Kw,54
106
- worker_automate_hub-0.5.795.dist-info/METADATA,sha256=FXi1Bx_1a-c_zHjP86o6kjkele7etVX-5H978rlltcI,3100
107
- worker_automate_hub-0.5.795.dist-info/WHEEL,sha256=M5asmiAlL6HEcOq52Yi5mmk9KmTVjY2RDPtO4p9DMrc,88
108
- worker_automate_hub-0.5.795.dist-info/RECORD,,
105
+ worker_automate_hub-0.5.797.dist-info/entry_points.txt,sha256=sddyhjx57I08RY8X7UxcTpdoOsWULAWNKN9Xr6pp_Kw,54
106
+ worker_automate_hub-0.5.797.dist-info/METADATA,sha256=mwva3heYW17g5LZ8SpQoXNQl9Y5AUhQ4IRx3cpfcCXM,3100
107
+ worker_automate_hub-0.5.797.dist-info/WHEEL,sha256=zp0Cn7JsFoX2ATtOhtaFYIiE2rmFAD4OcMhtUki8W3U,88
108
+ worker_automate_hub-0.5.797.dist-info/RECORD,,
@@ -1,4 +1,4 @@
1
1
  Wheel-Version: 1.0
2
- Generator: poetry-core 2.2.0
2
+ Generator: poetry-core 2.2.1
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any