My goal is to try upload a photo that I have selected from Photo Library or Camera captured, to Firebase Storage into a bucket/folder called ProfilePictures.
Everything works absolutely fine at first, I have used Picasso to assign the image to ImageView and Intent for Camera, except for when I call uploadPhoto()
. The application crashes and relaunches on fileReference.putFile(imageUri)...
.
Here is my manifest:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="com.google.android.apps.photos.permission.GOOGLE_PHOTOS"/>
<uses-feature android:name="android.hardware.camera"
android:required="true" />
I am using Firebase Storage version, which is in my build.gradle file -> implementation 'com.google.firebase:firebase-storage:16.0.4'
Here is my code:
private var mStorageRef = FirebaseStorage.getInstance().getReference("profilePictures")
private fun uploadFile(name: String, callback: ()->Unit) {
if (selectedProfileImage != null) {
val imageUri = selectedProfileImage ?: return
var fileReference = mStorageRef.child(name + "." + getFileExtension(imageUri))
println(fileReference)
fileReference.putFile(imageUri).addOnSuccessListener {
println("Profile Image upload Successful")
callback()
}.addOnFailureListener {
println("Profile image upload failed")
println(it.stackTrace)
println(it.localizedMessage)
callback()
}
} else {
println("No profile picture selected")
callback()
}
}
Here is my stack trace:
2019-12-03 14:23:34.521 7580-7761/com.fisherassociates.mt18academy E/AndroidRuntime: FATAL EXCEPTION: FirebaseStorage-Upload-1
Process: com.fisherassociates.mt18academy, PID: 7580
java.lang.NoSuchMethodError: No virtual method getToken(Z)Lcom/google/android/gms/tasks/Task; in class Lcom/google/firebase/FirebaseApp; or its super classes (declaration of 'com.google.firebase.FirebaseApp' appears in /data/app/com.fisherassociates.mt18academy-CsL1s9aKJKR7OHyF2sQSHw==/base.apk)
at com.google.firebase.storage.internal.Util.getCurrentAuthToken(com.google.firebase:firebase-storage@@16.0.4:148)
at com.google.firebase.storage.internal.ExponentialBackoffSender.sendWithExponentialBackoff(com.google.firebase:firebase-storage@@16.0.4:65)
at com.google.firebase.storage.internal.ExponentialBackoffSender.sendWithExponentialBackoff(com.google.firebase:firebase-storage@@16.0.4:57)
at com.google.firebase.storage.UploadTask.sendWithRetry(com.google.firebase:firebase-storage@@16.0.4:457)
at com.google.firebase.storage.UploadTask.beginResumableUpload(com.google.firebase:firebase-storage@@16.0.4:257)
at com.google.firebase.storage.UploadTask.run(com.google.firebase:firebase-storage@@16.0.4:198)
at com.google.firebase.storage.StorageTask.lambda$getRunnable$7(com.google.firebase:firebase-storage@@16.0.4:1106)
at com.google.firebase.storage.StorageTask$$Lambda$12.run(Unknown Source:2)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)