La plupart des bases de données traitent les mises à jour comme des opérations destructrices. La base de données de FLIN est temporelle par conception. Chaque entité suit automatiquement son historique complet de versions. Chaque sauvegarde crée une nouvelle version. Rien n'est jamais véritablement écrasé.
La propriété .history
flintask = Todo.find(4)
{for version in task.history}
<div class="version-row">
<span class="version-number">v{version.version}</span>
<span class="title">{version.title}</span>
<span class="timestamp">{version.updated_at}</span>
</div>
{/for}La propriété .history retourne une liste d'instances d'entités, une par version. Chaque instance historique a tous les mêmes champs que l'enregistrement actuel, plus des métadonnées : version, valid_from et valid_to.
La session 266 a aussi corrigé une régression liée à la gestion des portées dans le moteur de rendu, où les variables de portée n'étaient pas reconnues comme des valeurs côté serveur, causant des symptômes bizarres dans les sélecteurs de langue et les bascules de thème.
Les données temporelles transforment la console d'administration d'un visualiseur de données en un outil forensique. Quand un utilisateur signale que ses données ont changé de manière inattendue, le développeur peut inspecter l'historique pour voir exactement quand et à quelle valeur chaque changement s'est produit.
Le slogan de FLIN est « E flin nu » -- une phrase en Fon signifiant « Il se souvient des choses ». La propriété .history et les vues temporelles de la console en sont l'implémentation littérale.
Ceci est la partie 144 de la série « Comment nous avons construit FLIN », documentant comment un CEO à Abidjan et un CTO IA ont amené les capacités de base de données temporelle dans une console d'administration web.
Navigation de la série : - [143] Vues d'administration du stockage et de la base de données - [144] Historique des entités et vues temporelles dans l'admin (vous êtes ici) - [145] Polissage final UI/UX de la console