![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Ver si proceso en ejecución en máquina remota
Buenas a todos!
En mi empresa tenemos múltiples sistemas de facturación ya que programamos a medida para nuestros clientes. Es por ello que la adaptación a Veri*Factu la haremos haciendo uso de un subprograma que mostrará el registro de facturación asociado a una factura, gestionará los envíos y respuestas, las firmas, los registros de eventos, etc. Como la mayoría de nuestras instalaciones son de tipo cliente-servidor, el subprograma en cuestión se ejecutará en el servidor y estará siempre disponible, y se mantendrá a la escucha para enviar los registros cada 60 segundos. Lo que pasa es que este subprograma, por razones diversas, podría ocurrir que de repente se cuelgue y deje de estar disponible para el envío de las facturas. Por tanto, cada uno de nuestros SIF debería detectar antes o después de generar el registro de una factura si dicho subprograma está en ejecución en la máquina remota para, en caso contrario, ejecutarlo o que nos avise por mail de que no está ejecutándose, pues de lo contrario no se podrían remitir los registros de facturación a la AEAT. ¿Alguno de ustedes sabe cómo puede consultarse desde un equipo si en otro equipo de la red existe un proceso en ejecución? Tras algunas consultas a Google y otras a Copilot, he estado probando la api de WMI pero hasta ahora no consigo que funcione. Mi código es el siguiente: Código:
var SWbemLocator: OLEVariant; SWbemServices: OLEVariant; SWbemObjectSet: OLEVariant; SWbemObject: OLEVariant; Enum: IEnumVariant; Value: Cardinal; begin Result := False; SWERROR := 0; try CoInitialize(nil); try SWbemLocator := CreateOleObject('WbemScripting.SWbemLocator'); If CBCredenciales.Checked Then // Si la máquina remota tiene autenticación SWbemServices := SWbemLocator.ConnectServer(RemoteMachine, 'root\CIMV2', Usuario.Text, Password.Text) Else SWbemServices := SWbemLocator.ConnectServer(RemoteMachine, 'root\CIMV2', '', ''); SWbemObjectSet := SWbemServices.ExecQuery(Format('SELECT * FROM Win32_Process WHERE Name = "%s"', [ProcessName])); Enum := IUnknown(SWbemObjectSet._NewEnum) as IEnumVariant; while Enum.Next(1, SWbemObject, Value) = S_OK do begin Result := True; SWbemObject := Unassigned; end; finally CoUninitialize; end; except on E: EOleException do begin SWERROR := 1; Memo1.Lines.Add(Format('Error %d : ($%x) Mensaje : %s', [E.ErrorCode, E.ErrorCode, E.Message])); end; on E: Exception do begin SWERROR := 1; Memo1.Lines.Add('Error ' + E.Classname + ': ' + E.Message); end; end; end; |
#2
|
|||
|
|||
Cita:
Última edición por ermendalenda fecha: 09-12-2024 a las 12:25:45. |
#3
|
||||
|
||||
Cita:
Yo creo que sería lo adecuado para este escenario. Para consultar si un servicio está en marcha, se podría utilizar WMI.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#4
|
|||
|
|||
Cita:
Pero si ese programa remoto fuera ejecutado como un servicio, creo que mucho mejor. ¿Podrías orientarnos un poco el como hacer un programa que funcione como un servicio? |
#5
|
||||
|
||||
Cita:
Si es posible, lo más sencillo (creo yo) es que tantos los programas cliente (ERP) como el servicio (o la app. que habías pensado) estén conectados a la Base de Datos. Los ERP van colocando ficheros en la cola (es una o varias tablas dependiendo del diseño) y el servicio los va procesando y en la misma Base de Datos va generando las respuestas. La lógica de envío sólo está en el servicio. Cita:
Nosotros diseñamos el servicio en 2 piezas (EXE + DLL). En realidad para facilitar debug y pruebas, se diseña un servicio y una aplicación. Para no "repetir" código, toda la lógica se encuentra en la DLL y esa DLL se llama desde una APP y desde un SERVICIO. Como he dicho la APP y el SERVICIO sólo tienen una llamada al método de "procesar" de la DLL (que tiene toda la lógica). ¿Porqué se hace esto? Porque los servicios no pueden tener parte visual y los LOGs para debug se envían al registro de eventos de Windows, en el caso de la APP sí puede tener parte visual y los LOGs para debug se envían a un fichero. Para todo el proceso de desarrollo se usa la APP+DLL y para el cliente final SERVICIO+DLL. Si buscas por los foros encontrarás muchos hilos al respecto y posiblemente en el FTP encontrarás algún ejemplo: https://www.clubdelphi.com/foros/showthread.php?t=89341 https://www.clubdelphi.com/foros/showthread.php?t=48843 https://www.clubdelphi.com/foros/showthread.php?t=12776 https://www.clubdelphi.com/foros/showthread.php?t=20913 https://www.intitec.com/varios/delph...io_windows.pdf
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#6
|
|||
|
|||
Cita:
|
#7
|
|||
|
|||
Cita:
Los servicios se atienden a quien los pide, no se entremezclan y además puedes mandarles parámetros para identificar desde donde lo envías para que se registre. Última edición por ermendalenda fecha: 11-12-2024 a las 21:33:24. |
#8
|
|||
|
|||
Cita:
|
#9
|
||||
|
||||
Cita:
Es cuestión de buscar soluciones a los problemas. En nuestro caso hay un único Servidor de Base de Datos, pero puede haber varias Bases de Datos dentro de ese servidor. Cada base de datos es una empresa/obligado diferente (no se si es también tu caso); El servicio hace y una rueda y se va conectando a las diferentes Bases de Datos para enviar los datos de esa empresa. Una vez acabado se apunta en tiempo de espera (o el tiempo hasta el siguiente envío) para esa empresa. Es decir, en nuestro caso, un único servicio se encarga de todos los envíos de las diferentes empresas/obligados tributarios. Por ahora en el Thread principal, porque no contemplamos que la "rueda de envío" pueda tardar más de 60 sg. Actualmente se hace muy rápido. Si en su día esa "rueda de envíos" empezara a tardar mucho, nos planteamos crear Threads (ya lo tenemos pensado).
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#10
|
|||
|
|||
Cita:
También estamos considerando hacer threads independientes para cada empresa (obligado tributario) para que se vayan enviando en paralelo las facturas de cada OT. Pero como es un proceso que se va ejecutando repetidamente, si hacemos threads asíncronos, el proceso volverá a iniciarse y podría ser que el anterior no hubiera terminado y dos procesos estuviesen intentando enviar las mismas facturas. No tengo claro como hacerlo, porque si espero a que termine un envío (proceso síncrono) ya no tengo procesos en paralelo... le tendremos que dar una vuelta. Saludos |
#11
|
||||
|
||||
De momento nosotros lo estamos controlando en desarrollo con un campo en la base de datos, cada vez que comienza un envío, se marca ese campo, y no se desmarca hasta que el propio proceso de envío lo desmarca al final, así si se intenta realizar un nuevo envío estando el campo marcado, no se permite.
El único problema que le veo a esto, que estoy pensando cómo solucionarlo, es que el proceso se interrumpa por cualquier motivo (un pantallazo azul de la muerte, por ejemplo) y no se desmarque el campo, y se queden las facturas sin enviar porque el proceso no arranca de nuevo. |
#12
|
|||
|
|||
Ojo con eso para no verifactu
Las bases de datos y datos tienen que estar claramente separadas para distintos obligados tributariosm Y según cono tengas el sif también para verifactu. |
#13
|
|||
|
|||
Cita:
![]() nosotros en principio solo haremos modo Veri*Factu. En cada tabla hay un campo que indica de que obligado tributario es esa información... eso sirve para lo que dices ermendalenda? |
#14
|
|||
|
|||
¿Puedes indicar en qué artículo del reglamento pone que esto es así?
|
#15
|
||||
|
||||
Cita:
No se que quiere decir eso. En un ERP con multiempresa puedes una Base de Datos con diferentes obligados tributarios. Creo que es lo habitual si piensas en empresas con varias sucursales, por ejemplo; o en un despacho/gestoría que gestiona N clientes.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#16
|
|||
|
|||
Pues claro. Es que de lo contrario puedes tener centenares o miles de bases de datos y gestionar eso no veas...
|
#17
|
|||
|
|||
He podido mal interpretarlo o no, no explica muy bien si. Pueden estar en el mismo conjunto pero respetando la separación de obligados tributarios y respetando el artículo
Ya que habla de "respetar la gestión" mas bien puede que sea eso y que permita la misma bd. 8. Lo veis claro? Artículo 2(a) Cita:
|
#18
|
|||
|
|||
Cita:
P: Muchos de nuestros SIF multiempresa tienen una única base de datos para todos los obligados tributarios. ¿Obliga el reglamento a que los datos de cada obligado estén en bases de datos distintas? R: No hay inconvenientes o restricciones en el uso de las BBDD internas, por lo que pueden organizarlas de la forma que mejor convenga. |
#19
|
||||
|
||||
Yo creo que cuando habla de "Deberá realizar de forma separada la gestión de los registros de facturación y, en su caso, de evento de cada obligado tributario...", se refiere justo a eso, a la gestión, no a cómo estén organizados físicamente esos registros.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#20
|
|||
|
|||
A la pregunta "El SIF que actúa en modo VERI*FACTU, ¿puede guardar los XML generados en una carpeta en disco hasta su envío, u obligatoriamente deben guardarse en base de datos para cumplir con los principios de integridad e inalterabilidad?" me han respondido lo siguiente:
La remisión a la AEAT de los registros en este tipo de sistemas es prácticamente inmediata. Durante el intervalo de segundos entre su generación y la remisión pueden almacenarlos de la forma interna que como desarrolladores ustedes decidan. |
![]() |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Capturar id de maquina remota | mediaplanet | API de Windows | 3 | 18-05-2010 10:46:09 |
Instalar un proceso de forma remota | fide_32 | API de Windows | 1 | 26-09-2008 10:08:42 |
Ejecutar programa desde una maquina remota | rjsitruiz | Varios | 0 | 12-01-2005 16:55:19 |
abrir un documento en una maquina remota | CarlosHernandez | API de Windows | 2 | 10-03-2004 21:47:14 |
Nuevo Contacto en máquina remota | Igna | Servers | 1 | 21-01-2004 18:47:24 |
![]() |
|