Introduction
Salut, je suis WcaleNieWolny - Le chef des ingénieurs logiciels de Capgo.
Au cours des 8 derniers mois, j'ai développé le système d'organisation et, à compter du 14 avril, je suis heureux de vous annoncer que le système est désormais terminé 🎉 🎊 système d'organisationEnfin, après 8 mois, chaque partie de __CAPGO_KEEP_0__ est désormais accessible aux membres de l'organisation. Cela inclut :
Finally, after 8 months, every single part of Capgo is accessible to org members. This includes:
- statistiques
- facturation
- une prise en charge complète de __CAPGO_KEEP_0__
- full CLI support
- Il n'a pas été facile d'arriver là ; il y a eu 3 révisions majeures du système.
Organisations v1
Les débuts ont été difficiles… Au début, j'ai commencé à travailler sur ce projet 2 semaines après avoir rejoint le projet. À l'époque, j'avais peu ou pas de connaissances sur le codebase ou aucune idée plus large sur la manière d'implémenter cela.
applications
Cela a conduit à l'implémentation de la solution la plus hacky qui ne supportait que l'accès aux applications, aux canaux et aux versions. Il ne permettait même pas à l'utilisateur invité d'accéder aux statistiques.
Et puis j'ai attendu que Martin révise cela. J'ai attendu et attendu, mais rien de vraiment important n'est arrivé. 3 mois plus tard, j'ai décidé de revenir sur cela et de résoudre tous les conflits de fusion. J'ai également décidé de tester, ce qui s'est avéré être une excellente idée. Comme prévu, la solution hacky a complètement échoué. À ce moment-là, j'ai décidé de corriger tous les bogues et d'écrire un test E2E exhaustif. J'ai dû travailler avec des code très cassés et de nombreuses mauvaises décisions prises par le passé, mais après 2 semaines difficiles, j'ai finalement réussi à le faire fonctionner.
Cela ne signifie pas, cependant, que cela était parfait. Le propriétaire de l'organisation avait encore beaucoup plus d'accès que même l'utilisateur invité le plus élevé. L'expérience utilisateur était également très insatisfaisante. L'utilisateur invité ne pouvait même pas voir les statistiques de l'application, gérer les factures et le CLI était limité à l'upload uniquement.
Malgré tous ces défis, Martin avait révisé le PR, et une semaine plus tard, il a été poussé en prod.
Organisations v2
Le système d'organisation fonctionnait plutôt bien malgré tous les défis. Les utilisateurs l'utilisaient, et cela a vraiment poussé l'ensemble du projet en avant. Cependant, j'avais encore à :
- corriger le bordel créé dans niveau de sécurité par ligne
- ajouter le support pour l'intégralité du CLI
- s'assurer que les utilisateurs administrateurs ont le même accès que le propriétaire
Après beaucoup de discussions avec Martin, nous avons décidé que la meilleure façon de poursuivre était de réécrire les règles de sécurité entières et de déplacer la propriété de tous les ressources vers les organisations et non les utilisateurs. Cela permettrait une intégration plus facile avec le nouveau système d'organisation, et cela supprimerait également beaucoup de legacy code.
L'écriture des nouveaux RLS code était très fastidieuse, mais après une semaine et demi, la migration entière était prête.
Cette fois, cependant, nous avons décidé de ne pas écrire les tests E2E, ce qui signifie que nous devions les tester manuellement. Après 3 appels très étendus ensemble, Martin et moi avons finalement décidé de pousser vers la production et d'espérer qu'il irait bien 🙏
Ce n'est pas… Il s'avère que j'ai cassé l'enregistrement des utilisateurs, et les nouveaux utilisateurs ne pouvaient pas créer un compte 😅
Après un appel de panique rapide, j'ai rapidement poussé quelques modifications dans prod et suis allé me coucher. Malheureusement, mes modifications n'ont créé que plus de problèmes 😰
Après que j'ai réveillé, j'ai découvert que les utilisateurs avaient beaucoup d'organisations vides. Cela ne devrait pas se produire car il ne devrait y avoir qu'une organisation par utilisateur. Il a fallu du temps de réflexion pour supprimer toutes les organisations dupliquées vides, mais en dehors de cela, les modifications sont allées plutôt bien.
Organisations v3
Même cela n'a pas suffi. Il y avait encore un composant immense manquant - la facturation.
Jusqu'à présent, seul le propriétaire pouvait gérer la facturation. Cela a créé quelques problèmes intéressants où un utilisateur a acheté un plan en pensant qu'il l'achetait pour l'organisation.
Nous avons rapidement résolu le problème manuellement et c'est à ce moment-là que nous avons décidé que ce problème était inacceptable.
Organisations v4 - l'avenir
Après tout ce travail dur, je pense qu'il est temps de se concentrer sur autre chose pour l'instant.
Il ne fut pas facile mais j'ai appris beaucoup et capgo a reçu une très belle et importante fonctionnalité
Merci de lire.
Continuez de A un nouveau système d'organisation
Si vous utilisez Un nouveau système d'organisation pour planifier le tableau de bord et les opérations API, connectez-le avec API Vue d'ensemble pour les détails d'implémentation dans API Vue d'ensemble, Introduction pour les détails d'implémentation dans Introduction, API Clés pour les détails d'implémentation dans API Clés, Appareils pour les détails d'implémentation dans Appareils, et Bundles pour les détails d'implémentation dans Bundles.