Entradas

Mostrando las entradas de septiembre, 2023

Configurar IIS para ejecutar aplicaciones .NET Core

Imagen
Tenía una aplicación GeneXus funcionando correctamente con el server Kestrel.  Cuando cambié la propiedad para ejecutar con el IIS (Internet Information Server) me empezó a dar el error Server Error in Application "application name" HTTP Error 500.19 – Internal Server Error HRESULT: 0x8007000d Description of HRESULT The requested page cannot be accessed because the related configuration data for the page is invalid. Este error me habia pasado antes en aplicaciones .NET Framework (con el generador viejo) y siempre eran por temas de web.config mal formados o por problemas en la configuración del IIS (por ejemplo, quedaba mal el ApplicationHost.config ). En este caso, no parecía ser este el problema y necesité ayuda para encontrarlo. No deja pistas en el Event Viewer ni en los logs mas típicos. Busque por el lado de los componentes de Windows del IIS y no encontré nada. Me faltaba instalar ASP.NET Core Hosting Bundle que se baja y se instala en forma independiente del IIS. Lu

Kestrel y https

Imagen
  Cuando se desarrolla con GeneXus y .NET, el server por default es Kestrel.  Es practico de usar, porque consume poco, y es fácil de configurar.  En caso de necesitar utilizar https en el ambiente de desarrollo (cosa que todos deberíamos usar) la forma mas facil de configurarlo que encontré fue Generar un certificado autofirmado para el ambiente de desarrollo.  dotnet dev-certs https -ep rutaAlCertificado\aspnetapp.pfx -p tuContraseñaAqui dotnet dev-certs https --trust Luego instalarlo en el repositorio de windows certutil -p tuContraseñaAqui -importpfx rutaAlCertificado\aspnetapp.pfx para ver con que nombre quedó certutil -store My Luego crear el archivo ' appsettings.Development.json' y ponerle el contenido (ver el nombre del certificado autofirmado, en mi caso es locahost. { "Kestrel": { "Certificates": { "Default": { "Subject": " localhost ", "Store": "My", "Location":

Haciendo una KB GeneXus mas mantenible: Mantener aislado el código externo.

Imagen
Con GeneXus se pueden hacer aplicaciones multiplatafoma de manera eficiente en diferentes lenguajes. Sin embargo en algunas ocasiones especificas hay que recurrir a programar en codigo C# o Java. La que sigue, es una recomendación sencilla, que me hubiese gustado que alguien me la diera hace unos cuantos años, pues simplifica mucho el mantenimiento futuro.    Para hacer que la KB GeneXus sea mantenible en el tiempo y fácil de migrar, es indispensable mantener dicho código en su mínima expresión y lo más aislado posible.  En particular, existe la posibilidad de incluir código C# o Java dentro de los objetos Genexus, con los comandos CSHARP JAVA SQL EXEC Mi recomendación, para hacer facilitar la migraciones futuras, no tener estos comandos mezclados con el resto del código Genexus. En particular, conviene poner en procedimientos estos comandos, de forma que cuando cambie de sistema operativo (EXEC), de base de datos (SQL) o de lenguaje de programación (CSHARP, JAVA) tenga que revisar sol

Haciendo una KB Genexus más mantenible: Evita depender de objetos que cambien fuera de tu control

Imagen
En el mundo digital, la velocidad con la que se actualizan y cambian las herramientas y tecnologías es asombrosa. Y mientras que estar al día con las últimas novedades puede ser emocionante, también puede representar un desafío significativo en cuanto a mantenimiento y compatibilidad. Si estás trabajando con Genexus y quieres construir una Knowledge Base (KB) robusta y fácil de mantener, te hago algunas recomendaciones.  GeneXus garantiza la actualización tecnológica; sin embargo, es esencial estar preparados para abordar estos cambios. A pesar de que he presenciado numerosas charlas sobre el tema, noto una falta de énfasis en cómo prepararnos adecuadamente para las transiciones entre versiones. Por ello, he decidido elaborar una serie de publicaciones que se centrarán precisamente en este aspecto crucial. El problema con las herramientas de terceros Si bien las herramientas y recursos de terceros, pueden acelerarte muchisimo el desarrollo y la puesta en produccion, traen como consecue

Tercera prueba de GeneXus Next

Imagen
Seguí trabajando con el mismo prompt que use ayer para hacer la prueba y ahora si generó correctamente la aplicación. No se bien que cabión tras bambalinas, pero ahora me funcionó bien.  Me resulta mágico, que solo poniendo una descripción de lo que quiero pueda deducir un modelo de datos, crear la base de datos, cargarle datos de prueba y hacer un deploy en la nube para que lo pueda probar.  Adicionalmente, me publica una API para todos las tablas de datos básicos y hechos del sistema.  Es indudable que ahorra una cantidad impresionante de trabajo manual y repetitivo que hasta el momento no había podido ser automatizado.  Genere el modelo con WorkWithPlus y ya tiene además la posibilidad de consultar con lenguaje natural , por ejemplo, si ponemos en el filtro de arriba a la derecha:  "Tickets with Status Name = In Progress" me lleva a la pantalla de trabajar con Tickets, con el filtro de Status filtrando por In Progress.  Le agrega una nueva forma de navegar al sistema, que

Segunda Prueba de GeneXus Next

Imagen
 Hice una segunda prueba de GeneXus Next y lamentablemente el resultado no fue muy satisfactorio.            Probe con el prompt Necesito hacer un sistema para el seguimiento de tickets de desarrollo para aplicaciones, donde se puedan registrar errores, oportunidades de mejoras, sugerencias. Se necesita hacer seguimiento del estado de los tickets, saber quien lo tiene asignado, poder poner comentarios y notificar a los involucrados. Los clientes deben poder ingresar los tickets online y tambien consultarlos. Considerar al menos las siguientes entidades Clientes, Tickets, Sistemas, Personas, Estado de Tickets, Comentarios de Tickets No me parecia algo muy complejo, pero da un error y no me muestra cual es por lo que no puedo saber que es lo que esta pasando.  Me recomienda empezar desde el principio de nuevo, cosa que hice, pero no tuve mucha suerte. Lo reporte hace un tiempo a la gente de GeneXus, pero ya paso un buen tiempo y sigue sin resolverse. Tal vez sea una bobada, pero no lo

Cómo encontrar objetos en una KB GeneXus que utilizan dos tablas

Imagen
GeneXus es una herramienta poderosa que facilita la creación y mantenimiento de aplicaciones. Sin embargo, en ocasiones podemos encontrar la necesidad de identificar qué objetos hacen referencia a dos tablas específicas en nuestra Knowledge Base (KB).  Vamos a hacerlo paso a paso. Paso 1: Listar objetos que usan la TABLA1 1. En tu KB GeneXus, localiza la TABLA1. 2. Una vez que estés en la tabla, ve a las referencias de los objetos que la utilizan. 3. Selecciona todos los objetos que hacen referencia a esta tabla. 4. Accede al menú LSIExtensions (*)  y selecciona Edit . 5. Luego, elige Copy Info Objects as Table . 6. Abre tu editor de texto preferido y pega el contenido del portapapeles. Yo uso Notepad++ Paso 2: Ordenar y guardar el archivo 1. Ordena el contenido alfabéticamente. Lo ordeno en el Notepad++ con Edit / Line Operation / Sort Lines 2. Guarda el archivo con el nombre TABLA1.txt. Paso 3: Listar objetos que usan la TABLA2 1. Vuelve a tu KB GeneXus y repite el proceso del Paso 1