- El antiguo sistema de módulos está obsoleto desde la versión 5.0.0
- Los módulos antiguos seguirán funcionando pero están obsoletos.
- El nuevo sistema tipo Bundle reemplaza al sistema de módulos antiguos.
- A partir de la versión 5.0.0 se empezará a usar un sistema de módulos tipo Bundle
- Esta es la última versión compatible con el antiguo sistema de módulos.
- Se ha cambiado de Fomantic UI a TailwindCSS
- La versión mínima y máxima de PHP es 7.4
- Adaptarlos para la version 6.2.0
- Crear un bundle
lotgd-core-bundle
que agregue todos los paquetes que se requieran como base "7.1.0"
- Bundles
- ¿?
Special Events
: usando el componente even-dispatcher crear uno para los eventos especiales:- Ya creado, falta mejorarlo.
- El sistema se llama
Occurrence
, en referencia a que ha sucedido algo.- Este sistema no me convence, por lo que en la versión 8.0.0 planeo hacer otra cosa:
- Crear bundles de cada zona:
village
,forest
,shop
...- Con estos bundles se podría usar el sistema de event dispatcher de symfony para activar estos tipos de eventos especiales.
- Por ejemplo con el evento
request
antes de procesar toda la petición.
- Por ejemplo con el evento
- Crear bundles de cada zona:
- Este sistema no me convence, por lo que en la versión 8.0.0 planeo hacer otra cosa:
- Agregar opción para priorizar eventos.
- Agregar la prioridad a los eventos esto es útil para los eventos que no tienen menú de opciones y los que sí
- Se permitiría pasar antes los eventos que no tienen menús para así no entrar en conflicto con los que tienen menú
- Agregar la prioridad a los eventos esto es útil para los eventos que no tienen menú de opciones y los que sí
- Se agregará unas constantes con diferentes prioridades:
- Se establecen en orden de prioridad
priority_info
Para los eventos que no necesitan una respuesta y no son interactivos, solo son informativos de que ha pasado algo.- Este evento permite que se ejecute los otros dos.
priority_interactive
Para eventos que no necesitan respuesta, pero son interactivos, por ejemplo, se puede comentar (ejemplo es la pradera donde puede comer la montura y se puede escribir un comentario, pero no hace falta una respuesta)- Este evento impide que se ejecute otro evento con la misma prioridad, pero puede ejecutarse un evento de la prioridad anterior.
priority_needs_response
Para eventos que necesitan una respuesta por parte del usuario (tienen un menú de navegación)- Este tipo de evento impide que se ejecuten los otros dos eventos.
- Se establecen en orden de prioridad
En estudio
- Convertir en un bundle que gestione todo el evento.
- La idea es encapsular el evento dentro de un bundle que controle toda la lógica de dicho evento.
- De esta forma se puede controlar todo el evento y volver a la página que lanzó el evento más fácilmente.
- Se puede usar la sesión para pasar datos de una petición a otra (request)
- De esta forma se omite usar el query param
- Convertir en un bundle que gestione todo el evento.
- ¿?
- Todas las páginas se han migrado al sistema de controlador, queda mejorarlo
- Las páginas Grotto (las de configuración y administración) no se pasarán a un sistema de controlador.
- El panel de administración del juego se va a sustituir por Sonata Admin
- Las páginas Grotto (las de configuración y administración) no se pasarán a un sistema de controlador.
- Se han migrado todos los cronjob a comandos de consola.
- Nota el cronjob del nuevo día (newdayrunonce) no es compatible con el sistema de módulos.
- El nuevo sistema de CronJob se usará en la versión X.0.0 donde se elimina la compatibilidad con los módulos
- Esta será la última versión que use la ordenación de carpetas
src/core
ysrc/local
- La versión X.0.0 será la última versión con esta estructura, y será la versión dedicada a facilitar la transición a la versión LoTGD APP Symfony.
- La estructura actual X.0.0 y anterior es un poco caótica, por lo que se usará esta última versión para facilitar el salto a la versión LoTGD APP Symfony.
- (En la medida de lo posible)
- La estructura actual X.0.0 y anterior es un poco caótica, por lo que se usará esta última versión para facilitar el salto a la versión LoTGD APP Symfony.
- La versión LoTGD APP Symfony usará la ordenación propia de Symfony.
- La versión X.0.0 será la última versión con esta estructura, y será la versión dedicada a facilitar la transición a la versión LoTGD APP Symfony.
- Se revisará el código para hacer la transición más sencilla.
- Esta versión se centrará en hacer la transición a la versión LoTGD APP Symfony más sencilla.
- Esta es la última versión que incluya compatibilidad con el antiguo sistema de módulos.
- WebpackEncore (Se tiene que revisar como seria con Tailwind)
- Organizar mejor los archivos js/css
- El tema se crea en una configuración nueva para personalizar
- El js se crea en una entry común para todo (app por ejemplo), ya que puede dar problemas
- webpack.encore.entry.js
- webpack.encore.theme.js
- Organizar mejor los archivos js/css
- Revisar plantillas y traducciones (ver si se puede mejorar la estructura de las traducciones)
- Usar macros y blocks donde se pueda.
- BC Esta versión será ya una Symfony App (En estudio, puede que la versión 9.0.0 sea la Symfony App)
- Según se vea, dependiendo del sistema de eventos especiales, que parece ser que es el que más problemas va a dar.
- BC Se elimina la compatibilidad del antiguo sistema de módulos.
- Por lo que la versión 7.0.0 sería la última versión compatible con los módulos.
- Se fusiona todos los installer a uno nuevo como clean version
- El installer de la versión 6.0.0 depende de laminas/laminas-serializer
- Es en el único sitio donde se utiliza este componente
- El installer de la versión 6.0.0 depende de laminas/laminas-serializer
- Eliminar paquete laminas/laminas-serializer
- Eliminar la dependencia de Jaxon-PHP, usar Stimulus
- Se usará todos los componentes del Framework de Symfony (router incluido)
- Todo el Core estará compuesto por Bundles, para así poder usar un Skeleton muy similar al de Symfony App Skeleton
- lotgd_core_paypal_currency para poner la moneda que se usa en el servidor para las donaciones por paypal (como en bundle core)
src/core/Controller/CreateController.php
- Recrearlo para usar el Symfony form.
- Permitir la personalización de los datos con el dispatcher.
- Crear un service para el newday runonce (generar un nuevo día)
- Sustituir la función lotgd_mail por Symfony mailer
- lib/lotgd_mail.php Function
lotgd_mail
is deprecated and removed in future versions.- Use
Symfony mailer
instead.
- Use
- lib/lotgd_mail.php Function
- Eliminar https://github.com/Sylius/SyliusThemeBundle y hacerlo opcional
dragonpoints
para los puntos de dragón asignados actualmente es un array serializado- Se registra los valores que se han aumentado al personaje mediante las iniciales del atributo.
$points = [ 'str', 'con', 'int', 'ff', 'dex', 'str', ];
- Pasarlo a una tabla independiente para registrar los valores que se aumentan del personaje.
Posible estructura de la tabla 'attribute' El atributo que se esta mejorando del personaje. Ejem: `strength`, siempre con el nombre que aparece en la tabla. 'value' Valor es la cantidad que se añade de la mejora, puede ser positivo o negativo 'createAt' Fecha en la que se añadio esta mejora
- Se registra los valores que se han aumentado al personaje mediante las iniciales del atributo.
- Crear bundle:
Settings
para poder usarlo en sustitución de lasprefs
para usuarioMail
- Continuar con el que ya tengo iniciado
https://github.com/idmarinas/MessageBundle
- En el inbox cambiar el select para informar de cuantos mensajes tiene cada uno de los remitentes
- Continuar con el que ya tengo iniciado
Energy
un bundle que permite determinar el tipo de sistema que se usa para las acciones turnos/stamina- Se puede elegir el mínimo de energía y el máximo que puede tener el personaje
- Se puede hacer que depende de algún atributo. (que tenga bono)
- Tendrá funciones para poder aumentar y disminuir la energía.
- Correos permitir usar una plantilla para así personalizar los mensajes
- Se usará
Symfony\Bridge\Twig\Mime\TemplatedEmail
para todos los correos del core.
use Symfony\Bridge\Twig\Mime\TemplatedEmail; $email = (new TemplatedEmail()) // ... // html mail ->htmlTemplate('signup.html.twig') //-- or only text mail ->textTemplate('signup.txt.twig') // ... ;
- Habrá dos versiones de cada correo predeterminado version html y txt
- Desde la configuración se podrá decidir si se envían correos en html o txt
- Agregar opción para que el usuario pueda elegir.
- Se usará
- Migrar los cronjobs a cron/cron bundle mediante comandos de symfony console.
- Copiar el sistema de petition (y adaptarlo) en el app bundle.
- Motd, permitir la traducción, y que las encuestas tengan una configuración fuera de un campo serializado.
- Poner las opciones de la encuesta en una tabla separada. Permitiendo que las opciones también se puedan traducir.
- Agregar sistema al core, para poder añadir términos y condiciones y política de privacidad, sin necesidad de módulo.
- BC Hacer el que sistema de combate sea más personalizable, se pueda extender las clases para añadir más opciones.
- BC Rehacer los personajes, para que sean más sencillos de extender, también para que se complemente como el sistema de combate nuevo.
- Se simplifica la forma en la que se calcula las estadísticas del personaje, haciendo que tanto los personajes jugador como los creados por el servidor, tengan una forma de creación muy similar.
- BC Habilidades y sus buffs. Usar la base de datos para guardar los buffs, y asi poder traducir ciertos campos.
- Estos buffs pueden servir para muchas cosas, las monturas por ejemplo.
- Crear el bundle del inventario. Para sustituir el antiguo sistema de armadura y arma.
- Crear el bundle de energía, que permita poner energía o un sistema por turnos.
- Se actualiza el sistema de instalación para admitir la instalación por consola o via web.
- La instalación por consola ya se creó en la versión 5.0.0
- Se mirará incluir una versión de instalación por web
- Problemático la creación del usuario admin
- Se mirará incluir una versión de instalación por web
- Para los admin que no dispongan de esta opción se agrega la opción de instalación via web.
- La instalación por consola ya se creó en la versión 5.0.0
- Posible candidato a sustituir el petition system por https://github.com/hackzilla-project/TicketBundle
- Para limitar los intentos de conexión https://github.com/anyx/LoginGateBundle
- Añadir un check para comprobar si se han usado las funciones obligatorias (copyright(), game_version() ... )
- Crear un sistema de publicidad interno (que permite comprar espacios publicitarios)
- Compatible con el sistema simple (los tipo Google AdSense)
- Códigos de color, cambiar y unir todos los códigos de color, (color, negrita, cursiva, etc.) en un mismo lugar
- IDEA: usar la clase BBCode, ejemplo como se usa en foros y similar
- ¿? Permitir que en los eventos, el chance pueda ser superior a 100, para priorizar que un evento pueda pasar con más frecuencia.
- Usar otra forma
- https://github.com/pirasterize/sonata-form-builder
- https://github.com/nelmio/NelmioSecurityBundle
- https://github.com/nan-guo/Sonata-Menu-Bundle
- https://github.com/KnpLabs/KnpPaginatorBundle para la paginación
- Panel de administración, https://github.com/sonata-project/SonataAdminBundle
- https://github.com/sonata-project/SonataPageBundle
- Puede ser interesante para añadir páginas personalizadas, pero parece que no es compatible con la versión 5 de symfony
- SonataBlockBundle puede ser interesante para agregar bloques en lugares concretos
- https://symfony.com/doc/current/workflow.html
- https://github.com/vimeo/psalm/blob/master/docs/running_psalm/installation.md
- https://symfony.com/doc/current/components/process.html
- https://symfony.com/doc/current/components/config.html
- https://symfony.com/doc/current/components/finder.html
- https://symfony.com/doc/current/components/options_resolver.html
-
Para configurar los componentes y opciones que se pueden usar
-
Esto permite que cada componente tenga las opciones que necesita y los tipos de valor correctos
/* In many cases you may need to define multiple configurations for each option. For example, suppose the InvoiceMailer class has a host option that is required and a transport option which can be one of sendmail, mail and smtp. You can improve the readability of the code avoiding duplicating option name for each configuration using the define() method: */ // ... class InvoiceMailer { // ... public function configureOptions(OptionsResolver $resolver) { // ... $resolver->define('host') ->required() ->default('smtp.example.org') ->allowedTypes('string') ->info('The IP address or hostname'); $resolver->define('transport') ->required() ->default('transport') ->allowedValues(['sendmail', 'mail', 'smtp']); } }
-