Swift Firebase сохранить строку downloadURL - PullRequest
0 голосов
/ 03 октября 2018

Я обновил свой код firebase, потому что они заменили «metaData! .DownloadURL () !. absoluteString» на код, который я опубликую ниже.Моя проблема в том, что мне нужно сохранить строку downloadURL вместе с остальной информацией поста.Поскольку это асинхронный метод, я не могу получить доступ к строке за пределами вызова, и когда я пытаюсь поместить «.setValue» в вызов, он просто не работает.Вот мой предыдущий вопрос, но нет ответов на этот вопрос: Метаданные Swift Firebase! .DownloadURL () !. absoluteString

let photosRef = storage.reference().child("posts").child((loggedInUser?.uid)!)
    let usersRef = Database.database().reference().child("Businesses")
    let databaseRef = Database.database().reference()
    let imageName = NSUUID().uuidString
    let photoRef = photosRef.child("\(uid)")
    let postID = databaseRef.child("posts").child((loggedInUser?.uid)!).childByAutoId().key
    var downloadURLSting = String()

    photoRef.child("\(imageName)").putData(data!, metadata: nil) { (metaData,error) in
        if let error = error {
            print("there was an error")
            print(error.localizedDescription)
            return
        } else {
            // store downloadURL


            storage.reference().downloadURL(completion: {(url, error) in
                if error != nil {
                    print(error!.localizedDescription)
                    return
                }
                let downloadURL = url?.absoluteString

            })

            let values: Dictionary<String, Any> = ["uid": uid, "caption": caption ?? "", "timestamp": ServerValue.timestamp(), "businessName":loggedInUserData?["businessName"] as! String, "businessStreet":loggedInUserData?["businessStreet"] as! String, "businessCity":loggedInUserData?["businessCity"] as! String, "businessState":loggedInUserData?["businessState"] as! String, "businessZIP":loggedInUserData?["businessZIP"] as! String, "businessPhone":loggedInUserData?["businessPhone"] as! String, "businessWebsite":loggedInUserData?["businessWebsite"] as! String, "businessLatitude":loggedInUserData?["businessLatitude"] as! String, "businessLongitude":loggedInUserData?["businessLongitude"] as! String, "facebookURL":loggedInUserData?["facebookURL"] as! String, "twitterURL":loggedInUserData?["twitterURL"] as! String, "instagramURL":loggedInUserData?["instagramURL"] as! String, "googleURL":loggedInUserData?["googleURL"] as! String, "yelpURL":loggedInUserData?["yelpURL"] as! String, "foursquareURL":loggedInUserData?["foursquareURL"] as! String, "snapchatURL":loggedInUserData?["snapchatURL"] as! String, "imageID": imageName, "postID": postID]

            // store downloadURL at database
            let databaseRef = Database.database().reference()
            let path = databaseRef.child("posts").child((loggedInUser?.uid)!).childByAutoId()
            path.setValue(values) { (error, ref) -> Void in
                if error != nil {
                    print("error saving post in db")
                } else {
                    // reset caption field
                    self.descriptionTextView.text = ""
                    // reset placeholder image
                    self.imageView.image = UIImage(named: "filterPlaceholder")
                    MBProgressHUD.hide(for: self.view, animated: true)
                    let viewConrolller = self.storyboard?.instantiateViewController(withIdentifier: "Business Profile") as! UITabBarController
                    self.present(viewConrolller, animated: true, completion: nil)
                }
            }
        }
    }

Правила безопасности

service firebase.storage {
match /b/{bucket}/o {
match /{allPaths=**} {
  allow read, write: if request.auth != null;
}
}
}

Этот код работает просто "downloadURL" возвращает ноль

let photosRef = storage.reference().child("posts").child((loggedInUser?.uid)!)
    let usersRef = Database.database().reference().child("Businesses")
    let databaseRef = Database.database().reference()
    let imageName = NSUUID().uuidString
    let photoRef = photosRef.child("\(uid)")
    let postID = databaseRef.child("posts").child((loggedInUser?.uid)!).childByAutoId().key
    photoRef.child("\(imageName)").putData(data!, metadata: nil) { (metaData,error) in
        if let error = error {
            print("there was an error")
            print(error.localizedDescription)
            return
        } else {
            // store downloadURL
            photoRef.downloadURL(completion: {(url, error) in
                if error != nil {

                    guard let downloadURL = url?.absoluteString else { return }

                    let values: Dictionary<String, Any> = ["uid": uid, "caption": caption ?? "", "download_url": downloadURL, "timestamp": ServerValue.timestamp(), "businessName":loggedInUserData?["businessName"] as! String, "businessStreet":loggedInUserData?["businessStreet"] as! String, "businessCity":loggedInUserData?["businessCity"] as! String, "businessState":loggedInUserData?["businessState"] as! String, "businessZIP":loggedInUserData?["businessZIP"] as! String, "businessPhone":loggedInUserData?["businessPhone"] as! String, "businessWebsite":loggedInUserData?["businessWebsite"] as! String, "businessLatitude":loggedInUserData?["businessLatitude"] as! String, "businessLongitude":loggedInUserData?["businessLongitude"] as! String, "facebookURL":loggedInUserData?["facebookURL"] as! String, "twitterURL":loggedInUserData?["twitterURL"] as! String, "instagramURL":loggedInUserData?["instagramURL"] as! String, "googleURL":loggedInUserData?["googleURL"] as! String, "yelpURL":loggedInUserData?["yelpURL"] as! String, "foursquareURL":loggedInUserData?["foursquareURL"] as! String, "snapchatURL":loggedInUserData?["snapchatURL"] as! String, "imageID": imageName, "postID": postID]

                    // store downloadURL at database
                    let databaseRef = Database.database().reference()
                    let path = databaseRef.child("posts").child((loggedInUser?.uid)!).childByAutoId()
                    path.setValue(values) { (error, ref) -> Void in
                        if error != nil {
                            print("error saving post in db")
                        } else {
                            // reset caption field
                            self.descriptionTextView.text = ""
                            // reset placeholder image
                            self.imageView.image = UIImage(named: "filterPlaceholder")
                            MBProgressHUD.hide(for: self.view, animated: true)
                            let viewConrolller = self.storyboard?.instantiateViewController(withIdentifier: "Business Profile") as! UITabBarController
                            self.present(viewConrolller, animated: true, completion: nil)
                        }
                    }
                } else {
                    print(error!.localizedDescription)
                    print("error")
                    return
                }
            })
        }
    }

1 Ответ

0 голосов
/ 03 октября 2018

Вероятно, потому что ваши переменные не находятся в той же области видимости.Что произойдет, если вы попробуете это вместо этого?

photoRef.child("\(imageName)").putData(data!, metadata: nil) { (metaData,error) in
    if let error = error {
        print("there was an error")
        print(error.localizedDescription)
        return
    } 

    storage.reference().downloadURL(completion: {(url, error) in
            if error != nil {
                print(error!.localizedDescription)
                return
            }
            let downloadURL = url?.absoluteString

            let values: Dictionary<String, Any> = ["uid": uid, "caption": caption ?? "", "timestamp": ServerValue.timestamp(), "businessName":loggedInUserData?["businessName"] as! String, "businessStreet":loggedInUserData?["businessStreet"] as! String, "businessCity":loggedInUserData?["businessCity"] as! String, "businessState":loggedInUserData?["businessState"] as! String, "businessZIP":loggedInUserData?["businessZIP"] as! String, "businessPhone":loggedInUserData?["businessPhone"] as! String, "businessWebsite":loggedInUserData?["businessWebsite"] as! String, "businessLatitude":loggedInUserData?["businessLatitude"] as! String, "businessLongitude":loggedInUserData?["businessLongitude"] as! String, "facebookURL":loggedInUserData?["facebookURL"] as! String, "twitterURL":loggedInUserData?["twitterURL"] as! String, "instagramURL":loggedInUserData?["instagramURL"] as! String, "googleURL":loggedInUserData?["googleURL"] as! String, "yelpURL":loggedInUserData?["yelpURL"] as! String, "foursquareURL":loggedInUserData?["foursquareURL"] as! String, "snapchatURL":loggedInUserData?["snapchatURL"] as! String, "imageID": imageName, "postID": postID]

        let databaseRef = Database.database().reference()
        let path = databaseRef.child("posts").child((loggedInUser?.uid)!).childByAutoId()
        path.setValue(values) { (error, ref) -> Void in
            if error != nil {
                print("error saving post in db")
            } else {
                // reset caption field
                self.descriptionTextView.text = ""
                // reset placeholder image
                self.imageView.image = UIImage(named: "filterPlaceholder")
                MBProgressHUD.hide(for: self.view, animated: true)
                let viewController = self.storyboard?.instantiateViewController(withIdentifier: "Business Profile") as! UITabBarController
                self.present(viewController, animated: true, completion: nil)
            }
        }

    })        
}
...