Firebase - принудительное использование уникальных имен пользователей

После получения информации о похожих вопросах в Stack я получил следующее:

База данных:

{
  "user" : {
    "xbStJyCtfzf472" : {
      "avatar" : "avatar",
      "email" : "[email protected]",
      "fbId" : 10154200898,
      "lastLogin" : "Tue Mar 14 22:31:36 GMT+01:00 2017",
      "registerDate" : "Tue Mar 14 22:31:36 GMT+01:00 2017",
      "uid" : "xbStJyCwY5Ttfzf472",
      "username" : "myName"
    }
  },
  "usernames" : {
    "myName" : "xbStJyCtfzf472"
  }
}

Правила:

{
  "rules": {
    ".read": "auth != null",
    ".write": "auth != null",

    "users": {
    "$uid": {
        ".write": "auth !== null && auth.uid === $uid",
        ".read": "auth !== null && auth.provider === 'password'",
        "username": {
        ".validate": "
            !root.child('usernames').child(newData.val()).exists() ||
            root.child('usernames').child(newData.val()).val() == $uid"
            }
        }
        }
  }
}

Код Java для Android:

public void addUserToDatabase(final long fbId){
        final FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
        if (user != null) {
            final String username = "myName";

            //add the user
            mDatabase.child("usernames").child(username).runTransaction(new Transaction.Handler() {
                @Override
                public Transaction.Result doTransaction(MutableData mutableData) {
                    if (mutableData.getValue() == null) {
                        mutableData.setValue(user.getUid());
                        return Transaction.success(mutableData);
                    }

                    return Transaction.abort();
                }

                @Override
                public void onComplete(DatabaseError firebaseError, boolean commited, DataSnapshot dataSnapshot) {
                    if (commited) {
                        String email = user.getEmail();
                        String uid = user.getUid();
                        String avatar = "avatar1";
                        long mFbId = fbId;
                        String registered = Calendar.getInstance().getTime().toString();
                        String lastLogin = Calendar.getInstance().getTime().toString();

                        Log.w("AUTH", "username saved");
                        mDatabase.child("user").child(uid).setValue(new User(username, email, uid, avatar, mFbId, lastLogin, registered));
                    } else {
                        Log.w("AUTH", "username exists");
                    }
                }
            });
        }
    }

Это работает, поскольку, если я пытаюсь зарегистрировать учетные записи с тем же именем пользователя, в моей базе данных ничего не создается. Однако. Пользователь создан в моей аутентификации /Users. Я вижу, что это приводит к возникновению всех проблем.

Как мне заставить форматировать уникальные имена пользователей в моей базе данных таким образом, чтобы не регистрировать пользователя до тех пор, пока проверка не будет выполнена?

EDIT: Чтобы уточнить, я могу обнаружить, что имя пользователя принято, и предложите пользователю ввести другой. Однако, что, если пользователь будет получать вызов/выходить из моего приложения во время этого действия, тогда их электронное письмо будет завершено (т.е. они не могут зарегистрироваться снова), но у них не будет объекта User в моем базы данных, поэтому они никогда не смогут использовать мое приложение.

Ответ 1

Короткий ответ:

Сначала зарегистрируйте пользователя, затем предложите им указать свое имя пользователя, когда они это сделают, создать свой Пользовательский объект в вашей базе данных.

Решение проблемы:

Если пользователь по каким-либо причинам выходит из приложения при принятии решения о имени пользователя, заставляя его электронную почту хранить в таблице аутентификации без User -объекта в базе данных, у нас есть проблема. Чтобы решить эту проблему, всякий раз, когда пользователь заходит, мы можем проверить, существует ли их UID в User -table, если это так, отлично! Если нет, то мы предложим им снова ввести имя пользователя, а затем создать пользовательский объект.