Story

Sistem organisasi yang sama sekali baru

Cerita di balik bagaimana tim capgo menambahkan sistem organisasi

WcaleNieWolny

WcaleNieWolny

Marketer Konten

Sistem organisasi yang sama sekali baru

Pendahuluan

Hai, saya WcaleNieWolny - insinyur perangkat lunak utama Capgo.

Selama 8 bulan terakhir, saya telah mengembangkan sistem organisasi, dan per 14 April, saya senang mengumumkan bahwa sistemnya telah selesai πŸŽ‰ 🎊

Akhirnya, setelah 8 bulan, setiap bagian dari Capgo dapat diakses oleh anggota organisasi. Ini termasuk:

  • aplikasi
  • statistik
  • penagihan
  • dukungan CLI penuh
  • dan banyak lagi!

Tidak mudah untuk sampai di sini; ada 3 revisi besar dari sistem.

Organisasi v1

Awalnya sangat sulit… Awalnya, saya mulai mengerjakan ini 2 minggu setelah bergabung dengan proyek. Saat itu, saya memiliki sedikit atau tidak ada pengetahuan tentang basis kode atau ide yang lebih besar tentang cara mengimplementasikan ini.

Ini menyebabkan implementasi solusi yang paling rumit yang hanya mendukung akses ke aplikasi, saluran, dan versi. Bahkan tidak memungkinkan pengguna yang diundang untuk mengakses statistik.

Dan kemudian saya menunggu Martin untuk meninjau ini. Saya menunggu dan menunggu, tapi tidak ada yang benar-benar terjadi. 3 bulan kemudian, saya memutuskan untuk kembali ke ini dan memperbaiki semua konflik penggabungan. Saya juga memutuskan untuk menguji, yang ternyata menjadi ide yang bagus. Tidak mengejutkan, solusi rumit itu benar-benar gagal. Pada saat itu, saya memutuskan untuk memperbaiki semua bug dan menulis tes E2E yang ekstensif. Saya harus bekerja dengan kode yang sangat rusak dan banyak keputusan buruk yang dibuat oleh saya di masa lalu, tapi setelah 2 minggu yang berat, akhirnya saya berhasil membuatnya berfungsi.

Namun, itu tidak berarti bahwa itu sempurna. Pemilik organisasi masih memiliki akses yang jauh lebih banyak daripada pengguna yang diundang tertinggi sekalipun. Pengalaman pengguna juga cukup kurang. Pengguna yang diundang bahkan tidak dapat melihat statistik aplikasi, mengelola penagihan, dan CLI terbatas hanya untuk mengunggah.

Terlepas dari semua tantangan tersebut, Martin telah meninjau PR, dan seminggu kemudian, itu didorong ke produksi.

Organisasi v2

Sistem organisasi bekerja cukup baik terlepas dari semua tantangan. Pengguna menggunakannya, dan itu benar-benar mendorong seluruh proyek ke depan. Namun, saya masih harus:

  • memperbaiki kekacauan yang dibuat dalam keamanan tingkat baris
  • menambahkan dukungan untuk seluruh CLI
  • memastikan bahwa pengguna admin memiliki akses yang sama dengan pemilik

Setelah banyak diskusi dengan Martin, kami memutuskan bahwa cara terbaik untuk melanjutkan adalah menulis ulang seluruh aturan keamanan dan memindahkan semua kepemilikan sumber daya ke organisasi dan bukan pengguna. Ini akan memungkinkan integrasi yang lebih mudah dengan sistem organisasi baru, dan juga akan menghapus banyak kode lama.

Menulis kode RLS baru sangat membosankan, tapi setelah seminggu setengah, seluruh migrasi siap.

Namun kali ini, kami memutuskan untuk tidak menulis tes E2E, yang berarti kami harus mengujinya secara manual. Setelah 3 panggilan yang sangat ekstensif bersama-sama, Martin dan saya akhirnya memutuskan untuk mendorong ke produksi dan berharap semuanya akan berjalan dengan baik πŸ™

Ternyata tidak… Ternyata saya merusak pendaftaran pengguna, dan pengguna baru tidak dapat membuat akun πŸ˜…

Setelah panggilan panik yang cepat, saya segera mendorong beberapa perubahan ke prod dan pergi tidur. Sayangnya, perubahan saya hanya menciptakan lebih banyak masalah 😰

Setelah saya bangun, saya menemukan bahwa pengguna memiliki banyak organisasi kosong. Ini tidak seharusnya terjadi karena hanya 1 organisasi yang diizinkan per pengguna. Butuh waktu untuk brainstorming untuk menghapus semua duplikat org kosong, tapi selain itu, perubahan berjalan cukup lancar.

Organisasi v3

Bahkan ini tidak cukup. Masih ada komponen besar yang hilang - penagihan.

Sejauh ini hanya pemilik yang dapat mengelola penagihan. Ini telah menciptakan beberapa masalah menarik di mana pengguna membeli paket berpikir dia membelinya untuk organisasi. Kami dengan cepat memperbaiki masalah secara manual dan pada saat inilah kami memutuskan bahwa masalah ini tidak dapat diterima

Migrasi berjalan cukup lancar. Butuh seminggu kerja tapi dibandingkan dengan V1 dan V2 itu benar-benar tidak terlalu sulit πŸš€

Organisasi v4 - masa depan

Setelah semua kerja keras ini saya pikir sudah waktunya untuk fokus pada hal lain untuk saat ini 😎

Tidak mudah tapi saya belajar banyak dan capgo telah menerima fitur yang sangat bagus dan penting Saya masih harus mendepresiasi fungsi lama, meningkatkan pengalaman pengguna webapp, memantau bug, tapi seharusnya tidak ada perubahan besar pada sistem ini.


Terima kasih telah membaca πŸš€

Pembaruan Instan untuk Aplikasi CapacitorJS

Dorong pembaruan, perbaikan, dan fitur secara instan ke aplikasi CapacitorJS Anda tanpa penundaan toko aplikasi. Rasakan integrasi yang mulus, enkripsi end-to-end, dan pembaruan real-time dengan Capgo.

Mulai Sekarang

Berita terbaru

Capgo memberikan wawasan terbaik yang Anda butuhkan untuk membuat aplikasi seluler yang benar-benar profesional.

Komunikasi 2 Arah di Aplikasi Capacitor
Development,Mobile,Updates
April 26, 2025

Komunikasi 2 Arah di Aplikasi Capacitor

5 Kesalahan Umum OTA Update yang Harus Dihindari
Development,Security,Updates
April 13, 2025

5 Kesalahan Umum OTA Update yang Harus Dihindari