[Rails + UT] How to use UploadThing outside of JS ecosystem, using Rest API?

Hey, I am building file upload functionality for my Expo+Rails app. I was hoping to use UploadThing for it's robust FE library and the managed s3 experience. Firstly, the docs aren't friendly for non-JS folks, please look into that - a lot of contradicting/variety of information. I am calling the /v6/prepareUpload endpoint in my /api/uploadthing api controller but it is not returning presigned urls as one would hope reading the REST api docs. Here is the shape of the output:
export interface PrepareUploadResposne {
url: string;
fields: Fields;
key: string;
contentDisposition: string;
fileUrl: string;
appUrl: string;
pollingJwt: string;
pollingUrl: string;
fileName: string;
fileType: string;
customId: string;
}
export interface Fields {
acl: string;
Content-Type: string;
Content-Disposition: string;
bucket: string;
X-Amz-Algorithm: string;
X-Amz-Credential: string;
X-Amz-Date: string;
key: string;
Policy: string;
X-Amz-Signature: string;
}
export interface PrepareUploadResposne {
url: string;
fields: Fields;
key: string;
contentDisposition: string;
fileUrl: string;
appUrl: string;
pollingJwt: string;
pollingUrl: string;
fileName: string;
fileType: string;
customId: string;
}
export interface Fields {
acl: string;
Content-Type: string;
Content-Disposition: string;
bucket: string;
X-Amz-Algorithm: string;
X-Amz-Credential: string;
X-Amz-Date: string;
key: string;
Policy: string;
X-Amz-Signature: string;
}
I am using expo in the FE, here is the code that calls my /api/uploadthing api:
const rnHelper = generateReactNativeHelpers<{
direct_upload: Uploader<
Omit<AnyParams, "_input"> & {
_input: { checksums: string[] };
}
>;
}>({
url: apiClient.baseUrl + "/api/uploadthing",
});

const resp = await rnHelper.createUpload("direct_upload", {
files,
input: {
checksums: await Promise.all(
expoFiles.map(async (f) => computeMD5Checksum(await readFileData(f))),
),
},
headers: {
Authorization: `Bearer ${await getToken()}`,
},
});
const rnHelper = generateReactNativeHelpers<{
direct_upload: Uploader<
Omit<AnyParams, "_input"> & {
_input: { checksums: string[] };
}
>;
}>({
url: apiClient.baseUrl + "/api/uploadthing",
});

const resp = await rnHelper.createUpload("direct_upload", {
files,
input: {
checksums: await Promise.all(
expoFiles.map(async (f) => computeMD5Checksum(await readFileData(f))),
),
},
headers: {
Authorization: `Bearer ${await getToken()}`,
},
});
My understanding is that the response of prepareUpload should be the result of my uploadthing controller and the FE library will read it and take care of the direct upload. Please advise what can be done here.
99 Replies
sudhanshug
sudhanshugOP4mo ago
The createUpload expects the API response to be
{
url: S.String,
key: S.String,
customId: S.NullOr(S.String),
name: S.String,
}
{
url: S.String,
key: S.String,
customId: S.NullOr(S.String),
name: S.String,
}
but that's not what the api is returning
julius
julius4mo ago
hey, it seems like you're trying to use v7 of the package with v6 endpoints. that's probably where your type mismatch expectations are coming from
sudhanshug
sudhanshugOP4mo ago
Here is my ruby code, i think I am calling the right api
class Uploadthing
def fetch_presigned_urls(files)
response = Uploadthing.faraday.post("/v6/prepareUpload") do |req|
req.body = {
files: files.map { |file| {name: file[:name], size: file[:size], type: file[:type], customId: file[:key]} },
callbackUrl: Rails.application.routes.url_helpers.callback_api_uploadthing_index_url(host: Rails.configuration.x.api_origin),
callbackSlug: "direct_upload",
metadata: {},
routeConfig: %w[image video audio pdf text blob]
}
end

response.body
end

def self.faraday
@faraday ||= Faraday.new(
url: "https://api.uploadthing.com",
headers: {
"X-Uploadthing-Api-Key" => Rails.configuration.x.uploadthing_secret_key,
"x-uploadthing-fe-package" => "@uploadthing/react",
"x-uploadthing-version" => "6.10.0"
}
) do |f|
f.request :json
f.response :json
end
end
end
class Uploadthing
def fetch_presigned_urls(files)
response = Uploadthing.faraday.post("/v6/prepareUpload") do |req|
req.body = {
files: files.map { |file| {name: file[:name], size: file[:size], type: file[:type], customId: file[:key]} },
callbackUrl: Rails.application.routes.url_helpers.callback_api_uploadthing_index_url(host: Rails.configuration.x.api_origin),
callbackSlug: "direct_upload",
metadata: {},
routeConfig: %w[image video audio pdf text blob]
}
end

response.body
end

def self.faraday
@faraday ||= Faraday.new(
url: "https://api.uploadthing.com",
headers: {
"X-Uploadthing-Api-Key" => Rails.configuration.x.uploadthing_secret_key,
"x-uploadthing-fe-package" => "@uploadthing/react",
"x-uploadthing-version" => "6.10.0"
}
) do |f|
f.request :json
f.response :json
end
end
end
The response from fetch_presigned_urls is the response that the client receives anything @julius 🙂 I am paying for the product, hoping to get some support. mailed [email protected] as well, but nothing so far
julius
julius4mo ago
hey sorry - didn't see this. thanks for the ping brought this up with the team and we were a bit unsure what you were having issues with specifically. what is the api response that's unexpected? also I made a python sdk a while back, maybe you can take some inspiration from there. it was made a bit in between v6 and v7 so it's invoking some endpoints that doesn't exist, but the overall concept might be useful: https://github.com/juliusmarminge/uploadthing-py/blob/main/uploadthing_py/request_handler.py#L99 i was also in the process of upgrading that to v7 when we noticed it's quite hard for others to re-implement the necessary crypto stuff to generate correct signed urls, this is something we're looking to fix. https://github.com/juliusmarminge/uploadthing-py/blob/v7/uploadthing_py/utapi.py#L105-L136 but the v6 endpoints according to the open api spec should definetely match the expected output i was just a bit confused since rnHelper.createUpload is a v7 thing and you were calling v6 endpoints. the v7 frontend is not compatible with v6 backend endpoints
sudhanshug
sudhanshugOP4mo ago
Can the frontend libraries (specifically the createUpload ) directly consume the response of "/v6/prepareUpload".
const rnHelper = generateReactNativeHelpers<{
direct_upload: Uploader<
Omit<AnyParams, "_input"> & {
_input: { checksums: string[] };
}
>;
}>({
url: apiClient.baseUrl + "/api/uploadthing",
});

const resp = await rnHelper.createUpload("direct_upload", {
files,
input: {
checksums: await Promise.all(
expoFiles.map(async (f) => computeMD5Checksum(await readFileData(f))),
),
},
headers: {
Authorization: `Bearer ${await getToken()}`,
},
});
const rnHelper = generateReactNativeHelpers<{
direct_upload: Uploader<
Omit<AnyParams, "_input"> & {
_input: { checksums: string[] };
}
>;
}>({
url: apiClient.baseUrl + "/api/uploadthing",
});

const resp = await rnHelper.createUpload("direct_upload", {
files,
input: {
checksums: await Promise.all(
expoFiles.map(async (f) => computeMD5Checksum(await readFileData(f))),
),
},
headers: {
Authorization: `Bearer ${await getToken()}`,
},
});
I was expecting this code to: 1. call by /api/uploadthing api with the files 2. get the presigned urls from "/v6/prepareUpload" 3. upload the file to UT cloud however, that's not happening. only pt 1 works as expected
julius
julius4mo ago
the frontend libraries, yes. but you need a v6 version of the frontend sdk
sudhanshug
sudhanshugOP4mo ago
yes i looked into your python package but couldnt find a working example or directions 🙂
julius
julius4mo ago
React – uploadthing
Docs for the best file uploader to date
sudhanshug
sudhanshugOP4mo ago
okkk that makes sense, does the v7 not have prepareUpload yet?
julius
julius4mo ago
v7 is completely different, you don't request presigned urls. you upload directly to us https://docs.uploadthing.com/uploading-files
Uploading Files - UploadThing Docs
Uploading files is the first step in the process of uploading files to UploadThing. This page explains the general process of uploading files and how you can use the UploadThing API to upload files. There are two ways to upload files to UploadThing:
julius
julius4mo ago
that page describes how to build an adapter for v7
sudhanshug
sudhanshugOP4mo ago
yes i was very confused, the rest api docs had the API but this page talked about sqids
julius
julius4mo ago
but the difficult thing we've noticed is getting the crypto here to match since different langauges does math differently xd https://docs.uploadthing.com/uploading-files#generating-presigned-urls, this is something we're looking into how to fix, but iirc i got the python package to work in this regard
Uploading Files - UploadThing Docs
Uploading files is the first step in the process of uploading files to UploadThing. This page explains the general process of uploading files and how you can use the UploadThing API to upload files. There are two ways to upload files to UploadThing:
julius
julius4mo ago
i can verify in a bit. just gotta wrap up a tihng
sudhanshug
sudhanshugOP4mo ago
Well, i'll give it a try. Can you guys work on a short guide for a DIY setup for non nextjs folks? Specifically what I want to know is that once I compute the file key, how will I get that to work with my FE library? Like what function should i call with the filekey/presigned url.
julius
julius4mo ago
yea definetely something i want to make easier. v7 in theory makes this very trivial, since all your server should do is generate a URL and send it to the frontend
sudhanshug
sudhanshugOP4mo ago
yes - all i could find was a direct PUT request to the presigned URL which I want to avoid because of disconnections, multipart etc etc you guys should handle that! that's where the money is!
julius
julius4mo ago
we actually expose resumable uploads instead of multipart for v7 which is what the createUplaod you were trying to use is for, that allows you to pause/resume the upload any way you want
sudhanshug
sudhanshugOP4mo ago
cool, i'll give it a shot. in the meantime, if you can give me a short guide, plain md is also fine – that'd be awesome
julius
julius4mo ago
about to fire up the python v7 branch and see if that worked
julius
julius4mo ago
GitHub
uploadthing-py/uploadthing_py/utils.py at v7 · juliusmarminge/uploa...
(UNOFFICIAL) Python SDK for UploadThing. Contribute to juliusmarminge/uploadthing-py development by creating an account on GitHub.
julius
julius4mo ago
then you just return the urls from your server to the client formatted like
{
url: S.String,
key: S.String,
customId: S.NullOr(S.String),
name: S.String,
}
{
url: S.String,
key: S.String,
customId: S.NullOr(S.String),
name: S.String,
}
sudhanshug
sudhanshugOP4mo ago
awesome,
curl -X POST https://{{ REGION_ALIAS }}.ingest.uploadthing.com/route-metadata \
curl -X POST https://{{ REGION_ALIAS }}.ingest.uploadthing.com/route-metadata \
this will happen on the backend itself right?
julius
julius4mo ago
yea that you can do concurrently as the files are being uploaded
sudhanshug
sudhanshugOP4mo ago
when the upload is done, what will be the file url? assuming I am sending customId as well
julius
julius4mo ago
Working with Files - UploadThing Docs
After your files have been uploaded, you will most likely want to do something with them. This page shows how to work with your uploaded files.
julius
julius4mo ago
the put request also responds with the url
sudhanshug
sudhanshugOP4mo ago
alright, i dont see a rest api for getSignedURL (for accessing pvt files), can you guys add that pls
julius
julius4mo ago
/v6/requestFileAccess
sudhanshug
sudhanshugOP4mo ago
yea just was it 🙂 - confused. by v6/v7 thanks! I'll ping you if I come across any issues - otherwise i'll try to create an activestorage adapter for rails folks!
julius
julius4mo ago
👍 happy to help if you run into issues (although not with the Rails parts since i've never used Rails myself 😅 )
sudhanshug
sudhanshugOP3mo ago
It’s never too late to be a rails convert. xD Yo, I got back to working on uploads and I am confused about '/callback-result' endpoint in this documentation https://docs.uploadthing.com/uploading-files. What is this? Dont see mentions anywhere else also, what are these onUploadComplete and onUploadError callbacks? are they backend apis? are they functions exported by the FE library?
awaitServerData: If set to true, the upload request will not respond immediately after file upload, but instead wait for your server to call the /callback-result endpoint with the result of running the onUploadComplete callback. Enable this only if your client needs to get data from the server callback as it will increase the duration of the upload.
This is under the route-metadata part of the documentation. Does the upload not complete in the FE if this is true or does the route-metadata api call not resolve, 😕
julius
julius3mo ago
File Routes - UploadThing Docs
File Routes is a core concept of UploadThing that defines what your users can upload
julius
julius3mo ago
if you're doing server uploads you don't need to worry about those correct - the connection would hold until we receive the data you report through /callback-result . This allows you to return some data from onUploadComplete and access it in onClientUploadComplete
sudhanshug
sudhanshugOP3mo ago
sorry, where is the documentation on callback-result? Question 1: is it an endpoint i have to build in my app or is it a uploadthing endpoint Question 2: When i register a bunch of file keys in route-metadata, will i receive a single callback or multiple? Question 3: When isDev is true, each chunk received will be equivalent to a single callback? - if the answer to 2 is that there are N callbacks for N registered files, then each chunk should correspond to a single callback.
julius
julius3mo ago
callbacks are sent individually as each file is uploaded. but due to how streaming work a chunk may have multiple json blobs it's an endpoint on the ingest server, similar to route-metadata
sudhanshug
sudhanshugOP3mo ago
can you point me to the documentation of that endpoint please. and when/where to call it. and the python library doesn't call that endpoint either
sudhanshug
sudhanshugOP3mo ago
the search only points to this page and this page only says that we have to call that endpoint, that's it
No description
sudhanshug
sudhanshugOP3mo ago
oh, is it /v6/serverCallback?
julius
julius3mo ago
no i don't think we have it documented
sudhanshug
sudhanshugOP3mo ago
can you tell me how and when i have to call it
julius
julius3mo ago
what are you struggling with? you call it after you have run the onUploadComplete
sudhanshug
sudhanshugOP3mo ago
alright, and what does the request look like? headers, body, query etc
julius
julius3mo ago
yea no i never got to building client side adapter for v7 yet
julius
julius3mo ago
No description
sudhanshug
sudhanshugOP3mo ago
cool and this endpoint replaces /v6/serverCallback endpoint?
julius
julius3mo ago
yes but it's on the ingest server, not the api
sudhanshug
sudhanshugOP3mo ago
yep Yo, getting "failed to verify url" error when the client tries to upload the file to the presigned url, how can i debug what's happening. the url in question:
https://sea1.ingest.uploadthing.com/UcOlsqhe264cZXlKZmNtRnBiSE1pT25zaVpHRjBZU0k2T1Rnc0luQjFjaUk2SW1Kc2IySmZhV1FpZlgwPS0tZGIwZGMyYjA1YTI3ZTA2YjdiNWNhZWE1Zjk5ZTgwMDAxY2Y0ZGUwMA==?expires=1730461375000&x-ut-acl=public-read&x-ut-content-disposition=inline&x-ut-file-name=Screenshot+2024-06-03+at+7.56.57%E2%80%AFPM.png&x-ut-file-size=19185&x-ut-file-type=image%2Fpng&x-ut-identifier=72uz6xz82c&signature=c1ef437afc02dbc63886a7c57e763321b079dcc93d9b326f02975842f19c1856
https://sea1.ingest.uploadthing.com/UcOlsqhe264cZXlKZmNtRnBiSE1pT25zaVpHRjBZU0k2T1Rnc0luQjFjaUk2SW1Kc2IySmZhV1FpZlgwPS0tZGIwZGMyYjA1YTI3ZTA2YjdiNWNhZWE1Zjk5ZTgwMDAxY2Y0ZGUwMA==?expires=1730461375000&x-ut-acl=public-read&x-ut-content-disposition=inline&x-ut-file-name=Screenshot+2024-06-03+at+7.56.57%E2%80%AFPM.png&x-ut-file-size=19185&x-ut-file-type=image%2Fpng&x-ut-identifier=72uz6xz82c&signature=c1ef437afc02dbc63886a7c57e763321b079dcc93d9b326f02975842f19c1856
It is probably failing at hmac signature comparison, can you share the code you guys have for comparing signatures I've tried everything - using hex hmac signature with and without prefix, using b64 of the binary signature. nothing seems to work (copying your py library / following the uploading files doc)
julius
julius3mo ago
julius
julius3mo ago
Uploading Files - UploadThing Docs
Uploading files is the first step in the process of uploading files to UploadThing. This page explains the general process of uploading files and how you can use the UploadThing API to upload files. There are two ways to upload files to UploadThing:
sudhanshug
sudhanshugOP3mo ago
I got it to work! (mostly) Thanks for the hand holdling. Upon upload when I request the file, I get a 202 response with almost a nil response when the uploaded file is 10kb
No description
sudhanshug
sudhanshugOP3mo ago
if I reload my page, which re-requests the file, it works fine magically - probably you guys take some time to serve the file?
julius
julius3mo ago
Hmm how do you mean ”upon upload when I request the file”
julius
julius3mo ago
It should be available fairly instantly after the upload request closes, although some delay may be expected. You can also preload the image something like this before displaying it on the page https://github.com/pingdotgg/uploadthing/blob/1b23106bfdbeb0c06d21034ef13e5307ec833580/examples/profile-picture/src/app/_components/profile-pic-uploader.tsx#L190
GitHub
uploadthing/examples/profile-picture/src/app/_components/profile-pi...
File uploads for modern web devs. Contribute to pingdotgg/uploadthing development by creating an account on GitHub.
julius
julius3mo ago
How long delays are you seeing between upload complete -> file loading
sudhanshug
sudhanshugOP3mo ago
I have an API which uploads the image and returns the file url on successful upload which is utfs.io/f/<f-key>. My expo frontend tries to render the file using this url but it fails because utfs.io/f/<f-key> returns an empty response with status 202. This is what i mean by "upon upload when I request the file" . I dont know the exact delay but i am seeing the image on a reload post upload. Can you check your backend APIs to see when 202 is returned?
julius
julius3mo ago
202 is returned from the worker when it’s still uploading
sudhanshug
sudhanshugOP3mo ago
Huh, but the file is uploaded from our server for sure (because my request only resolves when the upload request resolves). Is there a quick way to know the actual status of the file? I can create a client component which retries when it sees a 202 response, but clearly that is not a proper solution 🙂
julius
julius3mo ago
Afaict there should be no way to get a 202 if you request the file after the upload request has succeeded. utfs reads db for a field that’s set and awaited before the upload request finishes
julius
julius3mo ago
No description
julius
julius3mo ago
here's me rendering the images in the dom as well:
sudhanshug
sudhanshugOP3mo ago
Can you try a server upload? Create an API that: 1. uploads the file 2. returns the file url Here is how I am uploading the file
response = Faraday.post("https://api.uploadthing.com/v6/uploadFiles") do |req|
req.headers["Content-Type"] = "application/json"
req.headers["X-Uploadthing-Api-Key"] = Rails.application.credentials.uploadthing.api_key
req.headers["X-Uploadthing-Version"] = "7.0.0"
req.body = {
files: [{name: key, size: io.size, type: options[:content_type], customId: key}],
acl: "public-read",
contentDisposition: "inline"
}.to_json
end

raise "Upload failed: #{response.status} #{response.body}" unless response.success?

signed_data = JSON.parse(response.body)["data"].first

url = signed_data["url"]
fields = signed_data["fields"]
file_name = signed_data["fileName"] || "file"
content_type = signed_data["fileType"] || "application/octet-stream"

# Ensure the IO object is at the beginning of the file
io.rewind if io.respond_to?(:rewind)

# Prepare the payload for the multipart form data
payload = fields.merge(
"file" => Faraday::UploadIO.new(io, content_type, file_name)
)

# Create a Faraday connection
connection = Faraday.new(url: url) do |faraday|
faraday.request :multipart
faraday.request :url_encoded
faraday.adapter Faraday.default_adapter
end

# Perform the POST request to upload the file
response = connection.post do |req|
req.body = payload
end
response = Faraday.post("https://api.uploadthing.com/v6/uploadFiles") do |req|
req.headers["Content-Type"] = "application/json"
req.headers["X-Uploadthing-Api-Key"] = Rails.application.credentials.uploadthing.api_key
req.headers["X-Uploadthing-Version"] = "7.0.0"
req.body = {
files: [{name: key, size: io.size, type: options[:content_type], customId: key}],
acl: "public-read",
contentDisposition: "inline"
}.to_json
end

raise "Upload failed: #{response.status} #{response.body}" unless response.success?

signed_data = JSON.parse(response.body)["data"].first

url = signed_data["url"]
fields = signed_data["fields"]
file_name = signed_data["fileName"] || "file"
content_type = signed_data["fileType"] || "application/octet-stream"

# Ensure the IO object is at the beginning of the file
io.rewind if io.respond_to?(:rewind)

# Prepare the payload for the multipart form data
payload = fields.merge(
"file" => Faraday::UploadIO.new(io, content_type, file_name)
)

# Create a Faraday connection
connection = Faraday.new(url: url) do |faraday|
faraday.request :multipart
faraday.request :url_encoded
faraday.adapter Faraday.default_adapter
end

# Perform the POST request to upload the file
response = connection.post do |req|
req.body = payload
end
It's ruby code, but should be easy to understand. Faraday is a http client library.
julius
julius3mo ago
Oh you’re doing v6 - let’s think Yea that won’t have the request resolve before the url is updated, so there’s some race conditions you might run into there
sudhanshug
sudhanshugOP3mo ago
i am using v7 sdk, i am using v6 here because the rest api docs didnt have any docs for v7 server upload
julius
julius3mo ago
That probably won’t work very well. v6/uploadFiles starts multipart uploads which you then need to complete. This is not compatible with the way the v7 front end SDK works I added a /v7/prepareUpload endpoint that you can use to get presigned urls for v7 if you were unable to generate working ones That endpoint will return urls which you can return to the frontend sdk
sudhanshug
sudhanshugOP3mo ago
but I need to do server uploads
julius
julius3mo ago
Ngl I am so confused with your setup. You say you use ruby and v7 uploadthing sdk? What sdk?
sudhanshug
sudhanshugOP3mo ago
lol - I have both frontend and backend uploads.
julius
julius3mo ago
Can you make some sequence diagram esque of what you’re doing
sudhanshug
sudhanshugOP3mo ago
ok
julius
julius3mo ago
That’s fine. You can use v7 for both and the process is very similar.
sudhanshug
sudhanshugOP3mo ago
alright, if i get the presigned url using the prepareUpload api - how do i upload the file? How is the upload request structured? What are the query params/headers or body I need to send
julius
julius3mo ago
Server uploads you can see here: https://github.com/juliusmarminge/uploadthing-py/blob/9bfa50b7e93e86601b2c413b3c2b9b11ce58b3d8/uploadthing_py/utapi.py#L106 just generate urls (or request if you can’t generate working ones) and PUT the formdata
GitHub
uploadthing-py/uploadthing_py/utapi.py at 9bfa50b7e93e86601b2c413b3...
(UNOFFICIAL) Python SDK for UploadThing. Contribute to juliusmarminge/uploadthing-py development by creating an account on GitHub.
julius
julius3mo ago
PrepareUpload is documented in the REST doc The upload itself is a simple PUT to the URL with the file embedded in formdata Then you can add resumability by sending a HEAD request first and get an offset, but that’s optional
sudhanshug
sudhanshugOP3mo ago
alright, thanks
julius
julius3mo ago
I should wrap up the python PR to have client uploads as well - it’s a good reference to have 😅
sudhanshug
sudhanshugOP3mo ago
I suppose i need to register the upload using the route-metadata endpoint, right? Would've been nice if I didn't have to do that. for my server uploads, i dont want a callback - can i pass nil to callback url and slug in the router-metadata request?
choco
choco3mo ago
if i am correct, you can just PUT request to V7 api for that
sudhanshug
sudhanshugOP3mo ago
i tried that and it looks like the PUT request waits till the file-key is registered with UT
choco
choco3mo ago
i think it is still faster than using uploadFile from v6 or atleast should be the same
sudhanshug
sudhanshugOP3mo ago
Okay, I will give you a rundown since you are new on this thread. I am trying to do server uploads and here are the issues I am facing: With v6 uploadFile, the file is uploaded correctly but it is not available immediately, my client receives an empty response when requesting the file (via an <img tag). This is fixed on immediately reloading my page, so I am assuming the lag is ~1sec. With v7 prepareUpload, I will have to generate the signed url, register the upload, and then upload the file (3 calls). Since my use case is server uploads, I do not need a callback and hence want to avoid the upload registration entirely. If i dont register the upload, the PUT request never resolves and the file is stuck in uploading state. Lmk if that makes sense 🙂
choco
choco3mo ago
you dont need to register the upload if you are not using any FileRoute and you can generate signed url without extra request on your own server do you use FileRoute?
sudhanshug
sudhanshugOP3mo ago
I am on rails, there is no concept of file route.
you dont need to register the upload if you are not using any FileRoute
ok this is news, will try that
and you can generate signed url without extra request
I am aware of this but the crypto is not matching with what UT server expects and I gave up and used prepareUpload
choco
choco3mo ago
oh the last one relatable, i am facing the same situation rn
sudhanshug
sudhanshugOP3mo ago
I am giving up on this for now and adding a very very bad fix for now - hopefully the UT team can give me a better solution
No description
julius
julius3mo ago
you don't for server uploads
julius
julius3mo ago
Uploading Files - UploadThing Docs
Uploading files is the first step in the process of uploading files to UploadThing. This page explains the general process of uploading files and how you can use the UploadThing API to upload files. There are two ways to upload files to UploadThing:
julius
julius3mo ago
No description
julius
julius3mo ago
what language? i added some reference examples for python, php and go that i've tested myself to work
choco
choco3mo ago
i think the problem is not with fileKey but with algorithm 256. But not sure. https://ptb.discord.com/channels/966627436387266600/1302368823630102579
julius
julius3mo ago
what language?
choco
choco3mo ago
Java I can give you the code that generates signedKey if it would help
julius
julius3mo ago
sure - i don't have a way to run java rn though
choco
choco3mo ago
if it will not bother you, you can run it online, because i use build in classes, let me chekc if its possible myself first
julius
julius3mo ago
send away i'll try to look tomorrow. gotta go to sleep now
choco
choco3mo ago
absolutely, i appreciate it
Cristobal Burgos
has anyone used the REST API to send things from python? I have an extremely edge case that I cannot use any external libraries so I'm converting everything from the Rest API but after I send the files correctly with /v6/uploadFiles (at least my understanding) is that I need to call the /v6/completeMultipart but I'm having issues understanding some keys on the api: -How can I get the uploadId -If i'm uploading only one file, is the default config enough?
No description
sudhanshug
sudhanshugOP3mo ago
you should probably post a new question because this thread is mostly about v7.
Cristobal Burgos
So sorry! I though this was on main!

Did you find this page helpful?