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.
- worker_automate_hub/cli.py +92 -112
- worker_automate_hub/tasks/jobs/entrada_de_notas_9.py +10 -12
- {worker_automate_hub-0.5.795.dist-info → worker_automate_hub-0.5.797.dist-info}/METADATA +1 -1
- {worker_automate_hub-0.5.795.dist-info → worker_automate_hub-0.5.797.dist-info}/RECORD +6 -6
- {worker_automate_hub-0.5.795.dist-info → worker_automate_hub-0.5.797.dist-info}/WHEEL +1 -1
- {worker_automate_hub-0.5.795.dist-info → worker_automate_hub-0.5.797.dist-info}/entry_points.txt +0 -0
worker_automate_hub/cli.py
CHANGED
|
@@ -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[/][/]
|
|
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
|
-
|
|
70
|
-
|
|
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
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
)
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
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
|
-
|
|
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
|
-
|
|
227
|
-
|
|
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.
|
|
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.
|
|
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(
|
|
629
|
+
await worker_sleep(2)
|
|
630
630
|
send_keys("{DOWN 6}")
|
|
631
|
-
await worker_sleep(
|
|
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(
|
|
666
|
+
await worker_sleep(4)
|
|
669
667
|
send_keys("^({HOME})")
|
|
670
|
-
await worker_sleep(
|
|
668
|
+
await worker_sleep(4)
|
|
671
669
|
send_keys("{LEFT 3}")
|
|
672
|
-
await worker_sleep(
|
|
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(
|
|
715
|
+
await worker_sleep(2)
|
|
718
716
|
send_keys("{RIGHT 3}")
|
|
719
717
|
|
|
720
718
|
pyautogui.press('enter')
|
|
721
|
-
await worker_sleep(
|
|
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"])
|
|
@@ -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=
|
|
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=
|
|
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.
|
|
106
|
-
worker_automate_hub-0.5.
|
|
107
|
-
worker_automate_hub-0.5.
|
|
108
|
-
worker_automate_hub-0.5.
|
|
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,,
|
{worker_automate_hub-0.5.795.dist-info → worker_automate_hub-0.5.797.dist-info}/entry_points.txt
RENAMED
|
File without changes
|