У меня есть приложение, которое позволяет пользователям создавать сообщения. Я замечаю, что когда пользователь делает post
, сообщение корректно добавляется к его posts
. Однако, когда этот пользователь выходит из системы, а я - другим пользователем, post
добавляется к новому зарегистрированному пользователю posts
. Итак, один и тот же пост присутствует у двух пользователей posts
. Я не могу понять, как это пошло не так. Я пытался использовать точки останова, но я даже не могу найти, где код может это делать. Код для добавления поста:
@IBAction func postButtonTapped(_ sender: Any) {
guard let beverageNameAdd = beverageName.text, beverageNameAdd != "" else {
print("ERIC: Caption must be entered")
return
}
if bevCat == "Wine" {
guard let wineVintageAdd = wineVintage.text, wineVintageAdd != "" else {
print("ERIC: Vintage must be entered")
return
}
self.wineCount = self.wineCount + 1
db.collection("users").document(uid!).setData([ "wineCount": self.wineCount!], merge: true)
}
if bevCat == "Beer" {
self.beerCount = self.beerCount + 1
db.collection("users").document(uid!).setData([ "beerCount": self.beerCount!], merge: true)
}
if bevCat == "Liquor" {
self.liquorCount = self.liquorCount + 1
db.collection("users").document(uid!).setData([ "liquorCount": self.liquorCount!], merge: true)
}
guard let beverageTypeAdd = beverageType.text, beverageTypeAdd != "" else {
print("ERIC: Vintage must be entered")
return
}
guard let img = newPostImage.image, imageSelected == true else {
print("ERIC: An image must be selected")
return
}
if let imageData = img.jpegData(compressionQuality: 0.2) {
let imgUid = NSUUID().uuidString
let metadata = StorageMetadata()
metadata.contentType = "image/jpeg"
let storageItem = STORAGE_BASE.child(imgUid)
print("STORAGE ID: \(storageItem)")
DataService.ds.REF_POST_IMAGES.child(imgUid).putData(imageData, metadata: metadata) { (metadata, error) in
if error != nil {
print("ERIC: Unable to upload image to Firebasee torage")
} else {
print("ERIC: Successfully uploaded image to Firebase storage")
DataService.ds.REF_POST_IMAGES.child(imgUid).downloadURL(completion: { (url, error) in
if error != nil {
print("ERROR in image \(error!)")
print("Error URL for image: \(String(describing: url))")
return
}
if url != nil {
self.postToFirebase(imgUrl: url!.absoluteString)
print("URL for image: \(String(describing: url))")
}
})
}
}
}
performSegue(withIdentifier: "reloadFeed", sender: self)
}
func postToFirebase(imgUrl: String) {
let post: Dictionary<String, AnyObject> = [
//"postTimeStamp": [".sv" : "timestamp"] as AnyObject,
"beverageName": beverageName.text! as AnyObject,
"imageUrl": imgUrl as AnyObject,
"beverageType": beverageType.text! as AnyObject,
"wineVintage": wineVintage.text! as AnyObject,
"beverageRating": beverageRating.rating as AnyObject,
"beveragePrice": beveragePrice.text! as AnyObject,
"beverageCategory": bevCat as AnyObject,
"uid": uid as AnyObject
]
let firebasePost = DataService.ds.REF_POSTS.childByAutoId()
firebasePost.setValue(post)
let userPost = firebasePost.key
print("Firebase Post: \(String(describing: firebasePost))")
let followerList = DataService.ds.REF_USERS.child("\(uid!)").child("followers")
followerList.observe(.value, with: { (snapshot) in
if let snapshot = snapshot.children.allObjects as? [DataSnapshot] {
for snap in snapshot {
print("SNAP -- \(snap.key)")
DataService.ds.REF_TIMELINE.child("\(snap.key)").child("\(userPost!)").setValue(true)
}
}
})
print("ADDING POST \(userPost!)")
_ = Auth.auth().addStateDidChangeListener { (auth,user) in
if let user = user {
let userId = user.uid
print("USER: \(String(describing: userId))")
let newPost = DataService.ds.REF_USERS.child("\(userId)").child("posts").child(userPost!)
newPost.setValue(true)
}
}
beverageName.text = ""
beverageType.text = ""
beveragePrice.text = ""
imageSelected = false
newPostImage.image = UIImage(named: "icons8-camera-100")
}
Тогда код для выхода здесь:
@IBAction func logoutTapped(_ sender: Any) {
let firebaseAuth = Auth.auth()
do {
try firebaseAuth.signOut()
let _: Bool = KeychainWrapper.standard.removeObject(forKey: KEY_UID)
performSegue(withIdentifier: "signOut", sender: self)
}
catch let signOutError as NSError {
print ("Error signing out: %@", signOutError)
}
}
Тогда код для входа здесь:
@IBAction func loginPressed(_ sender: UIButton) {
if let email = emailInput.text, let pwd = passwordInput.text {
Auth.auth().signIn(withEmail: email, password: pwd) { [weak self] user, error in
guard self != nil else { return }
if let user = user {
let uid = user.user.uid
let userData = ["provider": user.user.providerID]
self!.completeSignIn(id: uid, userData: userData)
} else {
let alert = UIAlertController(title: "Email/Password Incorrect", message: "The username/password combination is incorrect. Try again.", preferredStyle: UIAlertController.Style.alert)
alert.addAction(UIAlertAction(title: "Okay", style: UIAlertAction.Style.default, handler: nil))
self!.present(alert, animated: true, completion: nil)
}
}
}
}
Я знаю, что, вероятно, требуется еще больше для диагностики этой проблемы, но мне кажется, основываясь на базе данных Firebase в реальном времени, что сообщение старого пользователя добавляется сразу после входа нового пользователя. Кто-нибудь видел такой тип поведения раньше или имеет Любая идея, как я могу начать отлаживать это?