После получения информации о похожих вопросах в 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 в моем базы данных, поэтому они никогда не смогут использовать мое приложение.