Добавление сообщения в сообщения другого пользователя при входе - PullRequest
0 голосов
/ 11 февраля 2020

У меня есть приложение, которое позволяет пользователям создавать сообщения. Я замечаю, что когда пользователь делает 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 в реальном времени, что сообщение старого пользователя добавляется сразу после входа нового пользователя. Кто-нибудь видел такой тип поведения раньше или имеет Любая идея, как я могу начать отлаживать это?

1 Ответ

0 голосов
/ 22 февраля 2020

Проблема, как указал @Jay, связана с

    _ = 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)

        }
    }

Я добавлял сообщение в сообщения пользователя каждый раз, когда менялся автор, что не имеет никакого смысла. Мне нужно только добавить сообщение, когда пользователь нажимает добавить сообщение. Я удалил весь этот код за исключением:

let newPost = DataService.ds.REF_USERS.child("\(uid)").child("posts").child(userPost!) newPost.setValue(true)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...