Migrate tài khoản đăng nhập bằng Apple

Migrate tài khoản đăng nhập bằng Apple

Tin ngắn hàng ngày dành cho bạn
  • Lại có thêm một công cụ hỗ trợ tìm kiếm nhanh lịch sử gõ lệnh nè mọi người: atuinsh/atuin.

    Điều thú vị là nó dùng SQLite để lưu trữ. Ngoài ra còn cung cấp tính năng đồng bộ hóa (mã hóa) hoàn toàn lịch sử giữa các máy với nhau nữa. Hay ghê 🤓

    » Xem thêm
  • Mình thấy ấn tượng với mô hình gemma-3n-E4B của nhà Google ghê. Đây là một trong những mô hình hứa hẹn mang các mô hình ngôn ngữ lớn xuống chạy trên thiết bị di dộng hoặc web hoặc nhúng (embedded)...

    Cảm giác nó hiểu lời nhắc hơn á, tại vì mình thử nhiều mô hình ít tham số mà nó hay lơ đi lời nhắc của mình. Ví dụ bảo: "Chỉ trả về câu trả lời, không cần giải thích gì thêm" thì rất nhiều cái vẫn cứ phải chêm vào câu mở đầu, giải thích... còn với gemma-3n thì trả lời rất đúng trọng tâm.

    » Xem thêm
  • Trước là sử dụng CSS để tạo hiệu ứng "loading", còn giờ có thể chỉ cần mỗi 1 tệp svg cũng "loading" được luôn: svg-loaders

    » Xem thêm

Vấn đề

Vài tuần trước ứng dụng (app) ở công ty mà tôi đang làm việc thực hiện việc chuyển quyền sở hữu ứng dụng trong Apple Store, tức là chuyển từ tài khoản Apple Develop này sang tài khoản khác. Có nhiều việc cần phải làm trước khi chuyển, về cơ bản phải thực hiện lần lượt các công việc trong danh sách họ đưa ra thì mới có thể bắt đầu chuyển quyền sở hữu.

Một trong số đó là Migrate Sign in with Apple users to another team. Tất cả tài khoản người dùng tạo ra bằng việc bấm vào nút "Đăng nhập với Apple" tích hợp trong ứng dụng cần phải thực hiện migrate dữ liệu người dùng. Apple luôn chú trọng đến quyền riêng tư người dùng, thế nên việc chuyển giao ứng dụng sang tài khoản khác cũng cần phải đảm bảo tính riêng tư. Có một vài thông tin bị thay đổi, trong đó quan trọng nhất là apple id (hay còn gọi là sub) và private email.

Khi người dùng bấm vào nút "Đăng nhập với Apple", dữ liệu mà chúng ta lưu lại để định danh họ thường là địa chỉ email và apple id. Trong trường hợp người dùng không lựa chọn chia sẻ địa chỉ email thật thì chỉ có thể lấy được private email. Apple id và email là cần thiết để định danh một người dùng khi họ đăng nhập vào hệ thống, khi chuyển quyền sở hữu, 2 thông tin quan trọng này có nguy cơ bị thay đổi. Nói cách khác, nếu chuyển giao ứng dụng thành công, người dùng trước đó đăng nhập vào hệ thống thì nhận được apple id và private email khác nhau, dữ liệu này không khớp thì rất có thể chúng ta đối xử với họ như một người dùng mới.

Vậy cần phải thực hiện việc migrate này trước khi chuyển giao ứng dụng. Thật may mắn vì Apple có tài liệu hướng dẫn rất chi tiết, chỉ có điều hơi khó đọc, vì vậy bài viết này giúp bạn làm rõ hơn một chút về cách thực hiện.

Migrate tài khoản

Như đã nói Apple có tài liệu hướng dẫn migrate tài khoản, mục đích cuối cùng là lấy được apple id và private email mới để cập nhật vào dữ liệu người dùng đã có trong hệ thống. Gồm có 2 bước như sau.

Bước 1 được thực hiện ở tài khoản đang sở hữu ứng dụng. Mục đích là lấy được một đoạn mã chuyển giao định danh gọi là transfer_sub. Mỗi tài khoản là một mã, sau khi lấy hết, chuyển giao transfer_sub lại cho đội sắp nhận ứng dụng.

Bước 2 được thực hiện ở tài khoản nhận ứng dụng. Mục đích là từ transfer_sub lấy ra được thông tin tài khoản người dùng mới, bao gồm apple id và private email mới.

Trong tài liệu cũng chỉ rất rõ các đầu API cần dùng để thực hiện các bước ở trên. Như vậy chỉ cần viết một đoạn mã thực hiện việc lấy và sử dụng transfer_sub. Cũng tình cờ tôi tìm thấy một kho lưu trữ đã viết lại các API này thành các hàm tương đối rõ ràng. Bạn đọc có thể tham khảo yjiq150/apple-signin-migration-on-app-transfer

Lưu ý cần phải sửa lại các tham số bên trong các hàm beforeAppTransferafterAppTransfer để đảm bảo nó phù hợp với thông tin ứng dụng. Trong quá trình chạy migrate, Apple không nhắc đến giới hạn cuộc gọi (rate/limits) cho các API, cũng như số lần gọi trên cùng một tài khoản. Về phía tôi chạy thực tế thì đúng là không có giới hạn nào cả, các API có thể gọi liên tục với tốc độ rất nhanh, tuy nhiên thi thoảng một vài lần gọi API sẽ bị lỗi, vậy nên cần có cơ chế thử lại hoặc ghi nhật ký (logs) để xử lý các trường hợp này.

Một lưu ý nữa là các API chuyển giao này chỉ khả dụng trong vòng 60 ngày kể từ thời điểm chuyển giao ứng dụng thành công. Nếu quá 60 ngày mà chưa thực hiện việc migrate, bạn phải thực hiện việc chuyển giao lại ứng dụng về tài khoản cũ thì mới có thể migrate lại từ đầu.

Tổng kết

Việc migrate tài khoản "Đăng nhập bằng Apple" là một bước quan trọng khi chuyển quyền sở hữu ứng dụng trong Apple Store để đảm bảo tính liên tục và bảo mật dữ liệu người dùng. Quá trình này chủ yếu xoay quanh hai bước: đầu tiên là lấy mã định danh transfer_sub từ tài khoản hiện tại và sau đó sử dụng mã này để cập nhật thông tin tài khoản người dùng trên tài khoản mới. Mặc dù tài liệu của Apple cung cấp hướng dẫn chi tiết, nhưng việc triển khai thực tế có thể gặp khó khăn với những ai lần đầu tiếp xúc.

Tuy nhiên, cần lưu ý rằng các API này chỉ khả dụng trong vòng 60 ngày kể từ khi chuyển giao ứng dụng, do đó, việc lập kế hoạch và thực hiện kịp thời là rất quan trọng. Ngoài ra, cần chú ý đến cơ chế thử lại và ghi nhật ký để xử lý các lỗi API không mong muốn.

Cao cấp
Hello

Bí mật ngăn xếp của Blog

Là một lập trình viên, bạn có tò mò về bí mật công nghệ hay những khoản nợ kỹ thuật về trang blog này? Tất cả bí mật sẽ được bật mí ngay bài viết dưới đây. Còn chờ đợi gì nữa, hãy bấm vào ngay!

Là một lập trình viên, bạn có tò mò về bí mật công nghệ hay những khoản nợ kỹ thuật về trang blog này? Tất cả bí mật sẽ được bật mí ngay bài viết dưới đây. Còn chờ đợi gì nữa, hãy bấm vào ngay!

Xem tất cả

Đăng ký nhận thông báo bài viết mới

hoặc
* Bản tin tổng hợp được gửi mỗi 1-2 tuần, huỷ bất cứ lúc nào.

Bình luận (0)

Nội dung bình luận...