En la década de los setenta, con el desarrollo de la tecnología de sistemas fueron creados una serie de programas que tenían como finalidad la gestión de los datos de las empresas; al comienzo se necesitó un potencial alto de conocimiento y grandes equipos para poder interactuar con estas aplicaciones, pero con el tiempo, los mismos desarrolladores han mejorado estas técnicas de creación, a fin de simplificar y popularizar la utilización de este tipo de software (Monnier, 2016).
Los sistemas de información desempeñan un papel importante en la sociedad y en el entorno en que habitamos, son herramientas poderosas y alternas de apoyo a los gerentes para la toma de decisiones. De hecho, los sistemas de información ayudan a la alta dirección a monitorear el rendimiento y funcionamiento de la empresa, identificando si se están presentando problemas de carácter estratégico, para tener oportunidades de mejora, con el propósito de crecer acertadamente, de esta manera pueden ofrecer mejores servicios a sus clientes y pueden posicionarse en un mundo tan competitivo (Hamidian & Ospino, 2015).
La Policía Nacional de Colombia en su estructura orgánica cuenta con la Oficina de Telemática (OFITE), encargada a nivel nacional de direccionar y gestionar todo lo relacionado con las tecnologías de la información; uno de sus grupos de trabajo es el de Administración de Recursos Tecnológicos, que es responsable de custodiar, dar soporte y mantenimiento a todos los sistemas de información que se encuentran asignados a esta dependencia, entre ellos el Sistema para la Administración del Talento Humano (SIATH) desde el cual se gestiona toda la carga administrativa de la Policía y sus bases de datos constituyen un insumo para otras aplicaciones, dado que en estas se almacenan datos personales y laborales de todos los empleados activos y retirados de la institución, al igual que la de sus familiares (Colombia, 2015).
Teniendo en cuenta lo anterior, esta investigación realiza una revisión sistemática de la migración de los sistemas de información, para conocer las metodologías y arquitecturas de desarrollo utilizadas por diferentes autores, con el objetivo de obtener el discernimiento necesario para proponer una metodología de desarrollo que se ajuste mejor a la institución, considerando las nuevas tecnologías y las capacidades del capital humano con el que cuenta la Policía.
El SIATH fue desarrollado por OFITE en el año 2002 en lenguaje Oracle Forms and Reports; este sistema de información es implementado vía web únicamente a través del navegador de Internet Explorer, debido a que necesita la ejecución de un plugin de Java. De igual manera, es importante mencionar que desde el 12 de enero de 2016 Microsoft no proporciona actualizaciones de seguridad ni soporte técnico a este navegador y, en cualquier momento, puede ser inhabilitado, causando la indisponibilidad del sistema y paralizando administrativamente a la institución (Pang et al., 2016).
Por consiguiente, se realizó la revisión de trabajos de investigación y artículos científicos en revistas indexadas en la plataforma Scimago, en los cuales se evidencian, mediante diferentes estudios, cuáles son las mejores prácticas para el proceso de rediseño de un sistema de información; algunas de estas prácticas serán tomadas como referente para adquirir el conocimiento y tener la capacidad de tomar decisiones sobre la migración o re-implementación de este sistema heredado. Además, se proponen metodologías y plataformas de desarrollo que son necesarias para entender el código o lenguaje de programación heredado y obtener los cimientos requeridos, para escoger la nueva herramienta tecnológica en que se va a rediseñar el SIATH de la Policía Nacional de Colombia. Por último, se describe el método de recolección y validación de datos utilizado en la investigación, seguido de los resultados y de las conclusiones.
Esta investigación hace una revisión sistemática de literatura científica mediante tres categorías de análisis, previamente seleccionadas y que se relacionan directamente con el título del artículo, así: metodologías de desarrollo, planes de gestión y migración de sistemas (Gonzalo Muñoz et al., 2017).
Los sistemas de información son desarrollados e imple-mentados para mejorar el trabajo realizado en las empresas, optimizando tiempos y recursos, así como también, minimizando los errores humanos que, con frecuencia, se pueden cometer. Las grandes empresas y entidades del Estado que llevan mucho tiempo en el mercado pueden tener dentro de su infraestructura software heredado (Medina et al., 2019).
El software heredado es un sistema con tecnología antigua o desactualizada que, por su robustez, complejidad u otras variables críticas, sigue vigente dentro de una organización; igualmente, estos sistemas no cuentan con soporte técnico ni mantenimiento, pero tampoco se pueden reemplazar fácilmente (Torres et al., 2018).
Según Yarza et al. (2021) el periodo de obsolescencia de los sistemas compuestos se está reduciendo y paralelamente se crea la necesidad de migrar e integrar los sistemas heredados. Con los avances de la tecnología, se propone utilizar dos traductores binarios adaptables a la máquina, uno de ellos con características dinámicas y el otro totalmente estático, para ser usado en la propiedad de tiempo real. Igualmente, se debe hacer la recompilación de código, con la premisa de tenerlo disponible y con un nivel suficientemente alto que lo categorice como independiente o al menos casi independiente de la plataforma en que se ejecuta.
Las cuatro áreas de investigación propuestas son: la traducción binaria, que forma una subárea de investigación por parte de las soluciones adaptables por máquina; el software heredado en tiempo real; la aplicación de la sincronización con soluciones de retargetable como un subgrupo; y la validación de los tiempos en la migración (Salazar et al., 2014).
Es necesario definir el modelo de sistema heredado en tiempo real, que ejecuta un conjunto de tareas periódicas alineadas con la política de programación estática predefinida; las siguientes secciones hacen referencia a los principales elementos de modelado del sistema heredado (Hamman et al., 2018), así:
Modelo de aplicación: define la relación del primer software heredado, compuesto por un conjunto de tareas periódicas representadas a través de una tupla, donde las variables a intervenir son el periodo de la tarea por un límite superior del tiempo en ejecución (Guamán et al., 2018).
Modelo de ejecución: radica en un hiperperiodo que determina el tiempo después del cual el patrón de ejecución de la tarea se pueda repetir, y esta compuesto a su vez por un conjunto de marcos (Flore & Marx Gómez, 2020).
Aplicación de ejemplo: es un código de bloque secuencial que inicia leyendo los datos de entrada en su estado interno y termina calculando los resultados y actualizando sus estados. El comportamiento de la aplicación consiste en una secuencia lógica de alternancia de bits, alternando un bit específico en una variable de salida (Senn, 2017).
Un lenguaje de especificación de tiempo MULTIC es aplicable a los sistemas heredados, pues se basa en patrones de especificaciones y declaraciones parecidas al lenguaje natural, a través de trazas de tiempo que cumplen un patrón. MULTIC Time Specification Language (MTSL), siendo un lenguaje de especificación de tiempo definido, asume que los nuevos sistemas se construirán a partir de componentes, que interactúan con otros elementos por medio de un conjunto de puertos, vinculados con conectores (Oliver et al., 2018).
Dando continuidad al proceso de revisión documental, Li et al. (2019) presentaron una nueva metodología para el diseño de sistemas en el procesamiento de señales, usando interfaces para la programación de aplicaciones ligeras y de flujo de datos en diferentes capas de abstracción, con un conjunto integrado de herramientas y bibliotecas desarrolladas para cerrar cualquier brecha generada en el diseño.
En la figura 1 se observan las opciones de migración que se puede escoger en el momento de tomar la decisión respecto a la migración de un software heredado.
La metodología propuesta se enfoca en la implementación de un co-diseño de software con hardware con el mapeo de aplicaciones optimizado, para facilitar el desarrollo y la aplicación de los módulos a crear; para esto, se proponen plataformas y lenguajes de programación heterogéneos con una metodología de diseño y un conjunto integrado de herramientas y bibliotecas que se desarrollan para conseguir los objetivos, aplicando la metodología STMC o STMCM, para las cuales es usual llevar el nombre de las diferentes instituciones que las desarrollan, por ejemplo: Sassari, Tampere, Marylan o Cagliari. Estas permiten la experimentación con diferentes niveles de abstracción durante el proceso del diseño, para no delimitar el talento humano vinculado al proceso, y permiten de manera productiva la iteración de modelos de flujos de datos, plataformas de destino heterogéneas e integración con otros lenguajes y arquitecturas de desarrollo.
La Arquitectura Orientada a Servicios (SOA) es el nexo que une las metas de negocio con el sistema de software; su misión es otorgar flexibilidad y automatización de los procesos tecnológicos con reducción de los costos de operación (Castro-León, 2020). En este artículo, se presenta un modelo de decisión para reingeniería que combina factores estratégicos y técnicos con análisis de costo-beneficio, en decisiones de integración versus migración; la arquitectura SOA proporciona un marco conceptual, basado en estándares para sistemas empresariales flexibles y adaptables. Esta noción es relativa a esta investigación, para evaluar las alternativas estratégicas en función de validar el costo beneficio del rediseño propuesto (Hustad & Olsen, 2021).
Sin embargo, existe un modelo de soporte de decisiones así: 1) análisis estratégico, 2) análisis de arquitectura y desarrollo de soluciones en especificaciones detalladas del sistema y 3) análisis de costo-beneficio tangible de proyectos de reingeniería (Peralta-Ascue & Merma-Aroni, 2017).
Asimismo, Canfora et al. (2008) señalan como una buena opción la modernización de los sistemas heredados a plataformas con arquitectura orientada a servicios, y argumentan que el problema de rediseñar la capa de usuario original del sistema en los requerimientos se soluciona a través de un contenedor, el cual puede interactuar con el sistema en nombre del usuario.
En el proceso de migración propuesto, la técnica de envoltura presentada se puede manejar con el objetivo de reutilizar las funcionalidades de los usuarios, que ya estaban implementadas en el software heredado, se mencionan cuatro fases: seleccionar los servicios candidatos, hacer el envolvimiento de los casos de uso seleccionados, implementación y validación del caso de uso envuelto (Salazar et al., 2014).
Continuando con la revisión sistemática, Sneed y Verhoef (2019) proponen la reimplementación para la migración de un sistema heredado, junto a la conversión, el empaquetado y la remodelación, estando estos términos y condiciones alineados a la finalidad de la migración del SIATH, para lo cual es necesario revisar la arquitectura técnica y reemplazar el código. Pero la arquitectura funcional y los casos de uso deben permanecer como están, ya que la conversión total del sistema no es factible y la remodelación puede ser demasiado costosa o puede representar un riesgo para la gestión de los procesos, teniendo en cuenta la complejidad de los objetos almacenados y la dinámica institucional.
El proceso de reimplementación propuesto comienza con la medición del código fuente actual y finaliza con la integración del componente reimplementado; en el mundo de las TI de hoy, el mercado ofrece varios tipos de lenguaje para elegir, por ejemplo: UML, BPML, HTML, XML, y lenguajes específicos de dominio (Trubiani et al., 2018).
Si el lenguaje de destino está orientado a objetos, los ingenieros deben utilizar diagramas UML, es decir, diagramas de clases, diagramas de secuencia y diagramas de transición de estado, que pueden aplicarse a cualquier organización que tenga en funcionamiento una aplicación o sistema de información con software heredado, para el cual es obligatoria la reimplementación a una arquitectura actual, con la cual pueda innovar y explotar nuevos resultados (Torres et al., 2018).
Los Lenguajes de Descripción de Arquitectura (ADL) actúan como una entidad consistente en cuatro "Cs", que por su abreviatura hace alusión a los componentes, conectores, configuraciones y restricciones; los ADL, en su creación, se basaron en los lenguajes de interconexión de módulos (MIL) de los años 70 (Woods & Bashroush, 2015).
Estos lenguajes se focalizan en la estructura de alto nivel de la aplicación antes que en los detalles de implementación de los módulos concretos, se describe la experiencia obtenida a partir de la creación de una descripción arquitectónica grande para un sistema de información complicado, muy similar al sistema SIATH de la Policía Nacional de Colombia que se quiere reimplementar. Los lenguajes ADL aplican un enfoque simple, de poca ceremonia y altamente prescriptivo, para minimizar la posibilidad de que los equipos produzcan inconsistencias y la necesidad de ser reelaborados posteriormente (Fernández García, 2011). Se propone el ADL como alternativa de modelado de un sistema de información a gran escala, utilizando el uso de una notación de descripción de arquitectura simple y específica de dominio en un contexto industrial (Harris & Harris, 2022).
Siguiendo la línea de métodos para la migración de software Kargar et al. (2019) encontraron que un modo de comprender un código de software es a través de la modularización. Existen sistemas de información complejos, robustos e importantes para la organización; estas son características que encajan en los conceptos de software heredado. Al ser sistemas robustos que necesitan comprender y entender un código para su migración, es importante optar por técnicas que conlleven a una correcta lectura y comprensión del código. Es en este punto que interviene la modularización, técnica que permite extraer la estructura del sistema, y con la que se lo puede clasificar por funcionalidades y métodos, logrando la comprensión de subsistemas que cooperan entre sí. Además, implica la conversión del sistema en módulos, para primero comprender el funcionamiento y luego migrar la aplicación por pasos, de acuerdo a las funciones del mismo (Vidal Silva et al., 2018).
Si bien la técnica de la modularización parece una herramienta práctica e intuitiva, el autor plantea que esta técnica solo funciona cuando el programa está desarrollado en un único lenguaje de programación, esto dificulta la aplicación para los sistemas de información actuales y para la propuesta específica de migración del SIATH, ya que la arquitectura de desarrollo está orientada a las aplicaciones web que se caracterizan por estar escritas o compuestas de varios lenguajes de programación como JavaScript, HTML; para las funciones y métodos se utiliza Java, C++, C-Sharp, entre otros, y las bases de datos que actualmente utiliza la Policía Nacional de Colombia son de Oracle (Raffino, 2018).
Ante la dificultad de que la modularización solo pueda aplicarse a software escrito en un único lenguaje, se ha propuesto un método que se compone de dos grafos: grafo de dependencia semántica y grafo de similitud nominal, técnicas que se pueden aplicar independientemente de la sintaxis de la aplicación (Yandrapally et al., 2015).
La migración de sistemas de información sea o no heredados tiene un grado de complejidad, su motivación requiere de una necesidad justificada, que soporte asumir los riesgos y gastos que la migración conlleva. Generalmente, cuando se habla de migración de sistemas de información, se hace referencia a la migración del código fuente a otra tecnología, arquitectura o framework, así como la migración de los datos; sin embargo, la sola migración de datos puede ser compleja y requiere por si sola un tratamiento diferencial. Dentro de la propuesta para la migración del SIATH no se ha contemplado la migración de datos, puesto que estos están bien apoyados en una tecnología con amplio soporte y desarrollo.
Pérez (2017) encontró una propuesta metodológica para la migración de datos que apunta de manera general a los hitos para tener en cuenta en dicho proceso. Dentro de la revisión de documentos y trabajos realizada por el autor, este propone que todo plan de migración debe: primero, definir la metodología de migración y el plan de trabajo; segundo, establecer métricas para supervisar la calidad del dato en la migración de bases de datos o la calidad del código para la migración de software; tercero, plantear un escenario y entorno de pruebas; cuarto, precisar la fuente y responsabilidad de los datos o del código según corresponda; quinto, prever posibles contingencias, por ello un plan de recuperación necesita de copias de respaldo completas; sexto, para la migración de datos es indispensable considerar ingreso y migración manual de datos. Por lo tanto, la construcción de un plan de migración debe recoger todas las recomendaciones posibles y prever todos los escenarios que se puedan desplegar. Aunque la metodología del autor parece estática y vertical, tiene componentes importantes que se deben tener en cuenta para el diseño de la propuesta en la migración del SIATH (Tsuji et al., 2021).
Adicionalmente, para este trabajo se consideró de gran importancia buscar artículos de investigación de las fuerzas militares de otros países, entre las que se encuentra la propuesta de Stacey Raza (2015), quien aplica una metodología moderna con procesos y procedimientos optimizados, para dar un mejor aprovechamiento de los recursos materiales, financieros y humanos a la problemática existente en la Armada del Ecuador, mediante la implementación de un SAP para la gestión del talento humano. La solución a esta problemática se hace mediante el modelo tradicional de migración de datos, que consiste en extraer, transformar y cargar los datos del sistema. Asimismo, se deben desarrollar actividades relacionadas con el sistema integrado de gestión institucional con una dinámica propia, planeando los objetivos administrativos y operativos, las tareas y metas a corto y largo plazo; así como la ejecución de los recursos, que incluyen los ajustes del plan operativo (García Cifuentes, 2016).
Igualmente, en las Fuerzas Armadas de Malasia (MAF), Arifin y Tajudeen (2020) estudiaron el impacto de los sistemas de información de recursos humanos en el entorno militar. El uso de las tecnologías de la información y las comunicaciones es usual en el sector público de Malasia, y han sido implementadas por el Plan Estratégico de TIC, como canal de comunicación, y para cumplir con la gestión administrativa. Para lograr el objetivo del estudio realizado, aplicaron un enfoque cualitativo que abarcó dos DGF y entrevistas personales, como herramientas idóneas para explorar los sentimientos personales y el comportamiento tomado por parte del equipo humano que conforma la MAF. Se tuvieron en cuenta las variables de calidad del sistema, de la información, del servicio, la infraestructura de TIC, la seguridad, el soporte del comandante y la formación para medir el impacto en el uso de estos sistemas, y los beneficios personales conseguidos fueron clasificados en tres categorías: desempeño laboral, productividad y toma de decisiones (Balalaie et al., 2018).
La usabilidad en los sistemas de información es una propiedad que las empresas deben controlar a través de su personal de tecnología; por esta razón, se programan planes de revisión para identificar qué tanto del software está en funcionamiento, y más al detalle, si todos los formularios y reportes son utilizados. Así, Chávez (2018) describió cuál es la realidad actual de las empresas y qué deben hacer para mejorar su nivel de productividad gracias a las aplicaciones; además, valoró el esfuerzo realizado por estas para aplicar técnicas y métodos en la ingeniería de usabilidad al proceso de desarrollo.
Por otra parte, se hace necesario la reimplementación del SIATH, puesto que, con el estudio realizado para levantar los requerimientos, se observó que la interfaz no es amigable y clara con el usuario. En ocasiones el sistema arroja errores que no son comprensibles y, en lugar de ayudar al usuario a identificar el inconveniente, hace más tediosa su labor, lo cual redunda en un gasto de tiempo adicional; por estar desarrollado en un lenguaje de código heredado, la escalabilidad del sistema para la creación de nuevos formularios es compleja y demorada, en este sentido, es muy poco dinámico para llevar a cabo los procesos que maneja la institución (Yu et al., 2021).
Las empresas que se deciden por una transformación digital de fondo necesariamente deben incluir, implementar y desarrollar metodologías ágiles con el propósito de hacer entrega de servicios y productos con calidad, costos reducidos, tiempos mínimos y optimización de recursos. En la ciudad de Cali, Colombia, Navarro et al. (2013) compararon de manera objetiva las diferencias fundamentales de las metodologías tradicionales y las ágiles con el propósito de disminuir el trámite que implica la aplicación de las metodologías tradicionales en los proyectos de mediana y pequeña escala. La figura 2 presenta algunas de las metodologías ágiles de desarrollo más utilizadas en la actualidad.
Esta investigación fue importante porque permitió encontrar una metodología que se adapte al proceso de desarrollo de sistemas de radio-software, empleando plataformas y software abierto, compararlas y decidiendo por la metodología más adecuada en este tipo de proyectos (Gechman, 2019).
La selección de una metodología simple da como resultado la posibilidad de elegir alguna de las siguientes en su orden de jerarquía: Scrum, Extreme Programming (XP), Dynamic System Development, Method (DSDM), Crystal, Adaptative Software Development (ASD) y Feature-Driven Development (FDD), que pueden ser integradas en cualquier empresa que tenga contemplado utilizar metodologías ágiles para el desarrollo de aplicaciones (Nuottila et al., 2016).
Con relación a este concepto Ribeiro y Domingues (2018) manifiestan que las metodologías de desarrollo de software han ido creciendo y sufriendo una maduración durante los últimos años con un resultado favorable en el sector privado, por el contrario, en el sector público esa evolución no ha sido tan clara. Sin embargo, para este estudio se obtuvo una buena aceptación por parte del personal de la institución, a pesar de que se identificaron algunas resistencias y desacuerdos con respecto a esta metodología ágil.
Por otro lado, Zumba (2018) presenta una revisión bibliográfica que demuestra cómo ha sido el proceso evolutivo de las metodologías y modelos de software dividiéndolo en dos grupos: las clásicas o iniciales y las metodologías ágiles. Las ágiles surgieron por la necesidad y demanda de los mercados con la expansión de los sistemas de información y el impulso que dio internet; los proyectos de software requerían ser muy dinámicos, de desarrollo acelerado y con la interacción recurrente del usuario dentro del proceso de construcción, este concepto se puede aplicar mejor para el sector privado, donde la satisfacción del cliente y la obtención de recursos son los principales ejes de motivación (Borja López, 2013). Por el contrario, las metodologías clásicas se caracterizan por tener un enfoque en secuencias, definido y rígido. Es importante mencionar que la Policía Nacional de Colombia cuenta con un procedimiento estandarizado para el desarrollo de software que, una vez comparado con las metodologías de desarrollo existentes, se asemeja al modelo en cascada (Montero Molina et al., 2018).
Dando alcance al objetivo de este artículo, se quiere dar a conocer la necesidad que existe de reimplementar o modernizar el código heredado que tiene una empresa, en relación con las cajas blancas, que son un tipo de pruebas que se le hacen al software sobre las funciones internas de los módulos. Garcés et al. (2018) señalan que las necesidades de modernizar el software heredado en las organizaciones implican grandes retos y proponen un enfoque de transformación de caja blanca para modificar la arquitectura de la aplicación, sin que esta pierda valor; el modelo propuesto facilita la configuración de la arquitectura antes de realizar la transformación real de la aplicación, además, presenta un enfoque en técnicas de ingeniería basado en modelos (MDE), y fue aplicado a un plan piloto de desarrollo de la empresa colombiana Asesoftware. Como conclusión de esa investigación, se presenta un proceso genérico de caja blanca para reimplementar software heredado en tecnologías modernas, en la empresa Asesoftware, que cuenta con muchos años de experiencia en la migración manual de aplicaciones desarrolladas en lenguaje Oracle Forms y que son actualizadas en Java y .Net; el enfoque se puede adecuar para tener en cuenta la escalabilidad y viabilidad del proceso, ya que el metamodelo agnóstico de la tecnología sirve como pivote que facilita la transformación.
La búsqueda a profundidad de textos científicos, relacionados con el tema de investigación muestra, según Trías et al. (2015), que los Sistemas de Gestión de Contenidos (CMS) son plataformas robustas que sirven para almacenar gran contenido digital, gestionado desde las aplicaciones web. Además, proponen el uso de transformaciones automatizadas para generar el rediseño de sistemas de información a partir de los ya conocidos sistemas heredados, siguiendo una herradura de proceso que tiene como base tres procesos básicos: análisis de un sistema existente, transformación lógica y desarrollo de un nuevo sistema. El primer proceso se ubica en el extremo izquierdo de la herradura; el segundo, atraviesa la parte superior y el tercer proceso baja por el extremo derecho de la herradura.
La investigación presentada se centra en la etapa de ingeniería inversa del método propuesto, para migrar una aplicación web tradicional a una web basada en CMS; como primera parte, es preciso utilizar un lenguaje de modelado que permita definir los modelos específicos de la plataforma, que representan la sintaxis del código fuente en PHP, en la segunda parte, se define e implementa un conjunto de transformaciones M2M automatizadas, que permiten la generación de modelos independientes de plataforma.
Al hacer la comparación de metodologías de desarrollo Molina y Pedreira (2020) mencionan el auge que tiene el desarrollo de aplicaciones web, como consecuencia del avance de la tecnología; además de la dependencia de las empresas y de las personas del internet en un mundo globalizado. La aparición de nuevas metodologías de desarrollo se presenta, en parte, por las inquietudes de quienes interactúan con código y desarrollan aplicaciones. En este artículo se destaca la iteración que se tiene con las metodologías ágiles, debido a su facilidad para solucionar los errores y advertencias generadas durante el proceso, el cambio en los requerimientos por parte de los clientes, los inconvenientes de seguridad y ciberseguridad, así como las dificultades en el diseño e implementación del sistema (Maida & Pacienzia, 2015).
Algunas de las metodologías estudiadas son: hipermedia, orientada a objetos; metodología de gestión de relaciones (RMM); metodología de diseño de hipermedia; lenguaje de modelado web (WebML); modelo de diseño de hipermedia orientado a objetos (OOHDM); ingeniería web basada en Uml (UWE) y Hera.
Gholami et al. (2017) plantean los desafíos en la migración de sistemas heredados a la nube; ellos establecen diferentes puntos de vista y enfoques que deben ser tenidos en cuenta para la elaboración de un plan de migración de software. Adicionalmente, señalan algunos de los múltiples beneficios que tiene la arquitectura de servicios en la nube, tales como: minimizan los costos de infraestructura y mantenimiento, cuentan con servicio especializado y soporte, presentan un uso eficiente de los recursos, entre otros.
No solamente basta mencionar estas ventajas de la arquitectura en la nube, un mecanismo importante para que las empresas y organizaciones den el paso hacia la migración consiste en que las mismas empresas realicen sus propias investigaciones, descubran los desafíos y retos, evalúen los riegos, para tener claridad a la hora de tomar decisiones (De Fuentes-Martínez & Hernández-López, 2020).
Asimismo, se deben mencionar las diferentes definiciones que algunos autores le han atribuido al software heredado, pues el hecho de que algunos sistemas de información estén desarrollados para entornos web y estén alojados en servidores dedicados con arquitectura basada en la nube, no implica que sea un software heredado, una de las principales características para determinar el uso del software que soporte y aplique la tecnología para la nube es la elasticidad (Abdellatif et al., 2021).
Los sistemas heredados, por lo general, son antiguos, y fueron creados y diseñados antes de tener el concepto de arquitectura en la nube; la elasticidad de estos sistemas está definida y limitada por los recursos proporcionados por el servidor; por el contrario, la arquitectura de la nube cuenta con recursos de tendencia ilimitada, que se ajustan en escala vertical, de acuerdo a la demanda del servicio. El factor elasticidad es el más complejo de implementar en la nueva arquitectura, a la hora de migrar información (Punnoose & De, 2021).
La migración de sistemas de información se debe realizar de acuerdo a las capas del software; en general, cada sistema de información se compone de una capa de usuario, una capa de lógica del negocio y una capa de enlace de datos; de acuerdo a estas capas, existen diferentes opciones de migración a la nube que se denominan variantes de migración y se clasifican en cinco grupos. La primera variante consiste en migrar la capa de negocio, pues esta es compatible con los servicios de nube IaaS Infraestructure as a Service, este modelo sugiere mantener los datos en la organización. La segunda opción propone realizar reingeniería a través de un servicio en la nube SaaS, Software as a Service, para la capa de aplicación. En la tercera opción, se sugiere implementar la base de datos en un proveedor de almacenamiento a través del modelo IaaS, manteniendo la capa de lógica del negocio en la organización y los datos en la nube. En la cuarta opción se realiza un trabajo más complejo, pues implica no solo migrar el esquema de la DB, sino también los datos en un proveedor de almacenamiento y, finalmente, se propone migrar en un servicio IaaS mediante un esquema de prestación de servicios tanto para la capa de aplicación como para la capa de enlace de datos (Silva-López et al., 2015).
Por último, Berón et al. (2020) mencionan que, tanto el mantenimiento como la migración de sistemas de información son procesos cruciales en las organizaciones, dado el impacto que hoy en día tienen los sistemas y los datos en el Core del negocio, aunque muchas veces las motivaciones para migrar los sistemas de información heredados pasan por aspectos técnicos de arquitectura y obsolescencia tecnológica, los cuales son válidos. Poco se encuentra sobre la migración de un sistema heredado por causa de la calidad y la seguridad, ya que estos aspectos se pueden ajustar dentro de la arquitectura actual sin tener que desplegar procesos de migración.
Método
Se efectuó una revisión exploratoria sistemática, siguiendo el procedimiento indicado por el modelo PRISMA, a partir de las siguientes categorías de análisis: planes de gestión para el rediseño de un sistema, migración de sistemas y metodologías de desarrollo, para esto, se utilizaron operadores booleanos que optimizaron las consultas realizadas en las bases de datos seleccionadas (Moher et al., 2009).
El análisis de los trabajos se realizó mediante la búsqueda sistemática de literatura en las bases de datos seleccionadas, con palabras clave, ecuaciones de búsqueda en inglés y en revistas de investigación reconocidas por la comunidad científica, con el propósito de obtener información sobre estudios de alto nivel, nuevos conceptos que permitan abrir la brecha del conocimiento actual y a su vez, observar otras opciones para el rediseño de un sistema de información con código heredado.
En la figura 3, se exteriorizan las bases de datos que se consultaron en la búsqueda de información relevante para la investigación.
Asimismo, se realizó una búsqueda a profundidad en revistas de investigación, de las cuales se extrajeron artículos relacionados con migración, rediseño y reimplementación de sistemas heredados; en estos documentos se exponen arquitecturas y metodologías de desarrollo que deben ser estudiadas a profundidad, para tener la capacidad de escoger y proponer la más acertada para la investigación.
En las figuras 4 y 5 se especifica la categoría de las revistas consultadas, según su respectivo cuartil en la plataforma de Scimago, así como los años y la cantidad de publicaciones consultadas para artículos y tesis.
En la figura 6 se describe el flujo de información, donde se muestran las fases en que se hizo la revisión sistémica, filtrando los documentos encontrados por los criterios de inclusión y exclusión, basados en la declaración PRISMA.
Fase 1: los documentos identificados se seleccionaron por medio de los métodos de búsqueda relacionados anteriormente, se aplicaron ecuaciones de búsqueda junto con las categorías de análisis escogidas y se eligieron los artículos que aplican a la investigación propuesta. Después, se creó una matriz en la herramienta Excel con los siguientes atributos: (a) nombre del artículo, (b) autores, (c) tipo de documento, (d) resumen, (e) metodología, (f) categoría, (g) cuartil de la revista, (h) año de publicación, (i) país, (j) variable 1 arquitectura, (k) variable 2 área de aplicación.
Fase 2: se seleccionaron los estudios que describen aspectos generales de rediseño, reimplementación o migración de sistemas, con impacto favorable o desfavorable en la migración y, preferiblemente, de artículos que estuviesen en revistas indexadas.
Fase 3: los documentos elegidos fueron evaluados con base en el tema de investigación, se filtraron los estudios de reimplementación, rediseño y migración de sistemas de información, arquitecturas de desarrollo y metodologías de implementación.
Fase 4: se seleccionaron 20 artículos para hacer el análisis, según el problema planteado para esta investigación y así generar como resultado una propuesta argumentativa con la mejor opción para la migración del SIATH. Lo anterior, con el propósito de mitigar el riesgo de disponibilidad de la información para la Policía Nacional de Colombia; los datos obtenidos hacen parte de la revisión realizada a los documentos citados, y cumpliendo estrictamente con las fases nombradas anteriormente (Hernández et al., 1991).
Resultados
La Policía Nacional de Colombia identificó gracias a la Oficina de Control Interno, mediante una auditoría, la amenaza que existe en la disponibilidad de información gestionada desde el SIATH y con esta investigación se fundamentó la reimplementación del sistema. La revisión sistemática planteada para este análisis, analizó en profundidad 20 documentos de investigación (9 de ellos de Holanda), que aclararon dudas con respecto al tema de la migración o reimplementación de sistemas heredados. Asimismo, el estudio señala que las metodologías ágiles de desarrollo también son muy acogidas en la actualidad, ya que presentan un procedimiento más flexible para los desarrolladores, en el momento que necesiten hacer cambios a profundidad o ajustes al requerimiento inicial.
En el área de aplicación propuesta como segunda variable, se puede percibir que los autores, cuando proponen la reimplementación o migración de un sistema heredado, que es bastante complejo y robusto, recomiendan ir trabajando paralelamente la migración con el sistema en producción; igualmente dejan claro, que en el sector privado se hacen estos procesos con más frecuencia; pero a través de otro estudio, las personas también están dispuestas a aceptar la migración de su software heredado.
En la tabla 1 se describen algunas características de los documentos revisados, que se utilizaron en la matriz de investigación para realizar el análisis sistemático de la literatura.
Para referir el enfoque y diseño del documento analizado, se elaboró la tabla 2, en la cual se relacionaron directamente las categorías de análisis seleccionadas en la investigación.
Los resultados muestran una inclinación por las metodologías ágiles de desarrollo debido a la optimización de recursos materiales y talento humano; se pueden mencionar las siguientes metodologías como opcionales al momento de migrar o reimplementar un sistema heredado: Scrum, Extreme Programming [XP], Dynamic System Development Method [DSDM], Crystal, Adaptative Software Development [ASD], Feature-Driven Development [FDD]. Al tener clara la metodología, se debe escoger el proceso a realizar, que puede ser: convertir, reimplementar, redesarrollar, envolver, reemplazar o migrar; todo depende del estudio previo realizado por la empresa al software y a las necesidades presentadas.
Por último, es necesario reimplementar el SIATH, evitando al máximo la materialización de la amenaza en torno a la disponibilidad de la información. Se recomienda la utilización de una metodología moderna, a través de una arquitectura de desarrollo actualizada, amigable al usuario y funcional, que garantice la gestión efectiva de la información en este sistema de información.
Discusión
La presente revisión sistemática tenía como objeto conocer las metodologías y arquitecturas de desarrollo utilizadas por diferentes autores de artículos de investigación, a fin de emplear las más apropiadas para realizar la migración de información del SIATH de la Policía Nacional. De acuerdo con la búsqueda realizada en las diferentes bases de datos de artículos científicos y el análisis de los mismos, los resultados señalaron que, preferiblemente, debe emplearse una metodología de desarrollo moderna, con procesos y procedimientos optimizados. De aquí la importancia de extraer, transformar y cargar los datos al sistema, para planear dinámicamente la ejecución de los objetivos administrativos y operativos de la institución, contribuyendo a brindar una solución a la problemática existente en la Policía Nacional de Colombia, para la gestión del talento humano a través del SIATH.
De acuerdo a los aspectos descriptivos, se observó que, en su gran mayoría el enfoque utilizado en la literatura científica analizada es el experimental/descriptivo, se dio mediante estudios cualitativos (diecinueve) y uno mixto; estos clasificados en tres categorías de análisis (planes de gestión para el rediseño de un sistema, metodologías de desarrollo y migración de sistemas). Estas características metodológicas fueron primordiales para la recolección de información que permitiera seleccionar el proceso de migración más factible para el SIATH. En este sentido, la migración de un sistema de información se hace necesaria teniendo clara la metodología de desarrollo viable para aplicar, debido a la existencia de metodologías tradicionales, modernas y ágiles; estas últimas, son utilizadas con mayor frecuencia, en virtud del corto tiempo para obtener buenos resultados; pero también es conveniente puntualizar que, para la reimplementación del sistema SIATH, no es viable una metodología ágil de desarrollo debido a la robustez y complejidad de esta aplicación.
En general, el análisis realizado a la literatura científica indica que tanto el mantenimiento como la migración de sistemas de información son procedimientos trascendentales en las organizaciones, dado el efecto que tienen los sistemas y los datos en el Core de la organización (Berón et al., 2020). Por ello, en un sistema con más de veinte años, desarrollado en un lenguaje con limitaciones para su ejecución como el SIATH, es vital contar con referentes donde los autores puedan dar fe de los resultados obtenidos y de las prácticas de desarrollo llevadas a cabo, para evitar traumatismos en la migración de la aplicación, y permitiendo un mejor aprovechamiento de los recursos humanos, materiales y financieros con los que cuenta la Policía Nacional de Colombia.
Conclusiones
De los artículos revisados, se tomó como referente el escrito por Yarza et al. (2021), el cual describe la migración de software heredado basado en entornos de ejecución y aplicación a través de modelos; este método aplica para la reimplementación del SIATH, para lo cual es necesario realizar un consolidado de los formularios que existen actualmente, teniendo en cuenta las limitaciones que se puedan presentar por la cantidad de procedimientos y funciones que existen en el código de la aplicación y la interacción que se tiene con otros sistemas. Es necesario establecer un modelo que permita revisar la usabilidad de la aplicación y hacer una depuración en la capa de presentación del sistema.
La opción de migración, resultado de la investigación, es la reimplementación; es necesario revisar la arquitectura técnica, rediseñando los casos de uso y reemplazando el código fuente, conservando la arquitectura funcional y los objetos almacenados en la base de datos que son invocados desde la aplicación. Se recomienda el patrón arquitectónico en capas para la reimplementación del sistema a futuro, utilizando el modelo vista-controlador, separando los datos de la lógica del negocio y finalizando con el uso de la plataforma de desarrollo de software .NET, como la más recomendada según la investigación, para la reimplementación del SIATH.
Por lo tanto, se establece que, al ser reimplementado el SIATH en una arquitectura de desarrollo moderna, las capas de aplicación y presentación permitirán la interacción entre el usuario y el software a través de un entorno visual sencillo y claro, simplificando y optimizando el cumplimiento de las tareas asignadas al usuario funcional.
Durante el desarrollo de la reimplementación se pueden presentar limitaciones para la puesta en producción del sistema debido a su robustez y a la cantidad de novedades administrativas que tiene la Policía Nacional de Colombia, que son gestionadas desde esta aplicación. No obstante, se puede optar por priorizar algunas novedades y por sacar a producción el software, reimplementadolo en paralelo con el sistema actual. A futuro, teniendo como base la presente investigación, es factible proponer la reimplementación de todos los sistemas de información desarrollados en software heredado, pertenecientes a esta institución, a fin de obtener aplicaciones amigables con el usuario, que permitan la escalabilidad y la mejora de su seguridad, para garantizar la disponibilidad, integridad y confidencialidad de la información.