-
-
Notifications
You must be signed in to change notification settings - Fork 120
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
Add file_metadata
field to objects schema
#439
Comments
@bombillazo I generally agree that allowing Storing arbritary metadata could be a nice feature to have in Storage. |
strong agree on adding custom metadata per storge object. Having to maintain a mirror table just for additional data is a pain, especially the lack of usable triggers to keep both sides in sync. |
+2 for this. I would definitely like this. would like to tag files that are being uploaded. |
+1 |
+1 for this |
Also +1 |
Would make multi tenant systems a lot easier to manage. Ie. tenants quota. | +1 |
+1 |
+1000000000 I'm currently having to add metadata into my file names, so would love to clean up this mess! |
+1 for this. I'm currently working with AI generated images and need to store the prediction parameters that generated each image. Otherwise I gotta use AWS S3 cuz I know they have metadata feature. |
+1 |
+1 looking forward to this |
+1 |
1 similar comment
+1 |
+1 looking for same |
This would improve my workflow with supabase as well. Right now, I need to keep a separate table and keep it in sync every time i upload, move or delete objects. |
+1 I switched from self hosting to supabase, closed down my own s3 bucket to use supabase storage, and now I can't store metadata on the objects... Please please please add this functionality! |
+1 seems very helpful!! |
+1 |
+999 would really help out majorly in making supabase storage my go to for all apps. Currently having to use alternatives despite using supabase db and auth |
Great request. |
@fenos on this topic, since we're not sure when we might get this, is it wise to add a custom trigger to the These are the types of things having a dedicated |
+1 |
+1 it could prevent extra table for metadata |
@fenos |
Hi @Aadilhassan thanks for your kind words. Will let you know when these are done 👍 very excited to have this feature! |
Thanks for the update @fenos. I'm currently building my photography portfolio. I'm assuming I'd be able to store photo JSON data alongside each image uploaded to storage, correct? If so, I'm a customer now! |
Hey @fenos , I'm excited about this feature! I saw the changes and don't see any way to pass the new |
@tusamni Yes correct! 🎉 @bombillazo The client-side changes are in the making |
@fenos was just looking for this and couldn't be happier to see this is currently being worked on. Thank you! |
Hey there. Thanks. |
Yeah... any news on it would be nice. Perhaps we should open a new one for this since this case is closed, which is also kind of weird to close a case while there is no way using this feature.... @fenos |
@felipenmoura @logemann |
Awesome, sounds great Thanks. |
+1 Waiting for this. |
+1 waiting for this |
++ excited for this! |
+1 waiting for this feature |
+1 waiting for this |
I am confused. I followed the merge-chain and this feature seems to be fully merged and released. I updated my @supabase/supabase-js package so that it includes @supabase/storage-js:2.7.0. However the type FileOptions do not include a metadata field export interface FileOptions {
/**
* The number of seconds the asset is cached in the browser and in the Supabase CDN. This is set in the `Cache-Control: max-age=<seconds>` header. Defaults to 3600 seconds.
*/
cacheControl?: string
/**
* the `Content-Type` header value. Should be specified if using a `fileBody` that is neither `Blob` nor `File` nor `FormData`, otherwise will default to `text/plain;charset=UTF-8`.
*/
contentType?: string
/**
* When upsert is set to true, the file is overwritten if it exists. When set to false, an error is thrown if the object already exists. Defaults to false.
*/
upsert?: boolean
/**
* The duplex option is a string parameter that enables or disables duplex streaming, allowing for both reading and writing data in the same stream. It can be passed as an option to the fetch() method.
*/
duplex?: string
} Similarly, neither .info() nor .exists() exist on Could you update the documentation or bring me on the right track @fenos ? |
@tillka you should be updating storage-js to @supabase/storage-js:2.7.1 |
Do I get this right that metadata does not yet work with supabase.storage? I have to use the dedicated StorageClient? I would like to get my stored metadata through supabase.storage.list() rather than iterating over it and calling storageClient.info() for each file. |
It would be really nice if In the meantime the solution I'm using is to send a request to the backend where I query the
|
How are you doing this? I keep getting an error:
|
You need to expose the storage schema from Settings > API > Exposed Schemas |
+1 waiting for this feature |
@fenos Is there a way to update the file user_metadata? I can't find that. |
Feature Request
Currently, the
objects
schema in the Storage API schema is a light abstraction over the S3 storage. There is a metadata column in theobjects
table, but it corresponds to the metadata of the S3 file and cannot be used by the user. The API does not expose any way to add related metadata to a file to the objects directly. This metadata would ideally be in JSON format to contain user-determined data. Currently, the user needs to get around this limitation by either:storage.objects
table. This dramatically complicates querying, migrations, and client usage for something that could be colocated within the same table.storage
schema to add this new functionality, potentially breaking compatibility with Supabase-controlled services and implementation.The storage API should natively support metadata, and the API / JS clients should be updated to enable this powerful and common feature for file storage management. My proposal is to add a new column called
file_metadata
to differentiate it to the currentmetadata
field.The text was updated successfully, but these errors were encountered: