-
Notifications
You must be signed in to change notification settings - Fork 79
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cloud Storage API #88
Conversation
The first thing I'm noticing is that this isn't cross-platform and needs to be. This is because for HTML exports, you cannot poll in a loop directly the way you did - those have to be placed essentially in the _process function, because progress cannot be made in the poll() at a rate of faster than a single frame (so everything has to be done on a per-frame basis, basically). However, in theory it should be pretty easy to convert this into that, just gonna take some careful balancing. For more regarding loops and HTML exports: https://docs.godotengine.org/en/stable/getting_started/workflow/export/exporting_for_web.html#class-httpclient-and-class-httprequest - see the third bullet point for more. As far as the rest of the code, I had not, nor had the team, figured out how to do storage at all, so if you can get this working and make it work relatively across exports, we will definitely accept it and thank you very much in the credits. :) |
Oki doki! I'll make the necessary changes.👍
…On Wed, Jan 27, 2021, 10:20 PM Kyle Szklenski ***@***.***> wrote:
The first thing I'm noticing is that this isn't cross-platform and needs
to be. It's not because for HTML exports, you cannot use loops directly the
way you did - those have to be placed essentially in the _process function.
However, in theory it should be pretty easy to convert this into that, just
gonna take some careful balancing. For more regarding loops and HTML
exports:
https://docs.godotengine.org/en/stable/getting_started/workflow/export/exporting_for_web.html#class-httpclient-and-class-httprequest
- see the third bullet point for more. As far as the rest of the code, I
had not, nor had the team, figured out how to do storage at all, so if you
can get this working and make it work relatively across exports, we will
definitely accept it and thank you very much in the credits. :)
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#88 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AIJAAKSVGPSQDH33RE7KRQTS4DJWTANCNFSM4WWEHW2Q>
.
|
How's that? |
Definitely looks much better! Have you been able to test it and see if it works? I'm really excited for this PR. :) |
Uploading, downloading and deleting files with this API works like a dream. There are still some things I need to implement before this PR is ready.
|
You aren't authenticating to get it to work? I find it to be really weird that it would work without that. |
I'm currently testing on my storage with allowed read and write from anywhere. |
The only thing (in theory!) you should need to do when you add authentication is add an authorization header with the appropriate id value from the auth config. You can see how that's done in Firestore here: https://github.com/GodotNuts/GodotFirebase/blob/main/addons/godot-firebase/firestore/firestore_collection.gd#L64 However, it may require some weird form of token exchange - not entirely sure what we're dealing with here. |
Implemented authentication support, Added MIME Type constants in StorageRef.
Ok! It should be feature complete now. I'll do some tests later in the day to make sure that everything's working ok. |
Oh, and we should probably think about documentation. |
This isn't related to the review I'm currently doing for the code, but this issue: GodotNuts/GodotFirebase-UI#4 should reference this PR, so adding it here (hopefully). |
Made some `StorageTask` properties private.
I think this is good to go now! |
Yes, I'm in the process of reviewing. It's going to take a little bit to get merged because we have a big feature on the way as well - are you comfortable with rebase, or would you rather we handle it on our side? I don't think there should be many, if any, conflicts, but it's tough to say ultimately. |
I'm fine with doing the rebasing. 👍 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One very small change.
It's crazy to me that there's as much code as you wrote and I only found one very small thing to change. That is AWESOME. You are a really good coder, and I really appreciate the PR you've submitted. I'm not sure if what we're working on is going to get done tonight actually, so I may merge this sooner and then we'll handle the rebase ourselves. Looking more at it, I actually don't think there'll be any conflicts at all. |
Okay, yeah, I reviewed with the team and I'll merge this as soon as the change to remove the HTTPSEClient is in there. :) |
The HTTPSSEClient constant was no longer needed.
I'm glad I could help out! I think a lot of other Godot users will find this useful for their multiplayer projects. 😁 |
Congrats! And thank you so much! |
Thank you very much for your contribution @SIsilicon |
@SIsilicon I'm testing your implementation. Could be able to provide a minimal example to upload an image? (Not necessarely on your wiki, it is fine just here) |
Yeah - the major thing we need now is a few good working samples. It's quite possible we just don't know how to use uploading and so it's breaking. @SIsilicon - any chance you could provide one or two of those today (maybe one upload, one download, or perhaps a few different filetypes of each)? |
@WolfgangSenff # Must be authorized for this to work.
# If all works well, then this function returns the same texture passed in.
func test_image_storage(texture : Texture) -> Texture:
var storage_ref := Firebase.Storage.ref("testing/image.png")
# Uploading an image
var image := texture.get_data()
var data := image.save_png_to_buffer()
var task := storage_ref.put_data(data)
# Wait until the task is done.
yield(task, "task_finished")
if task.result:
printerr("%s failed to upload!" % storage_ref)
return Texture.new()
else:
print("%s has been uploaded!" % storage_ref)
# Downloading image from the same location
task = storage_ref.get_data()
# Wait until the task is done.
while not task.finished:
print("Download Progress: %s" % task.progress)
yield(get_tree(), "idle_frame")
if task.result:
printerr("%s failed to download!" % storage_ref)
return Texture.new()
else:
print("%s has been download!" % storage_ref)
# Pass the downloaded data into a texture as it was before.
var new_image := Image.new()
new_image.load_png_from_buffer(task.data)
var new_texture := ImageTexture.new()
new_texture.create_from_image(new_image)
return new_texture Something to note. If you don't pass Edit: You know, perhaps two new functions could be added called |
@SIsilicon - hmm. I don't think we need those two functions. I love the idea generally, but most types like that aren't things you'd want to store in Storage in my mind. Basically, you want to store the raw data there, but the Godot-types just need to be dynamically generated inside Godot itself. Does that make sense? Anyway, we'll try out your sample! Thanks! |
@SIsilicon Thank you very much for your example. |
@fenix-hub Certainly. You're right that they both return a |
@SIsilicon Thank you very much for the explaination :) I'm going to release a little PR where I'll add an higher level of communication with your module for signals. Firebase.Storage.connect("task_successful", self, "on_task_successful") with a signal that brings the following parameters: signal task_successful(result : int, response_code : int, data : Dictionary) Also I've managed to add a mirroring signal for errors signal task_failed(result, response_code, data) I'll release the PR as soon as possible later today, I'll ask for your review so I'll wait for your response. |
This pull request will bring a firebase cloud storage API to this wonderful project.
It adds the following features.