What is up with "use node" fetch?

I keep getting this dumb response when I try using the tiktok api from a convex use node action. When I use reqbin with the identical request it goes through perfectly fine
const upload = await (await fetch("https://open.tiktokapis.com/v2/post/publish/video/init/", {
method:"POST",
headers: {
"Authorization": `Bearer ${tiktokData.access_token}`,
"Content-Type": "application/json; charset=UTF-8",
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36"
},
body: {
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}

}
})).text();
console.log(upload);
const upload = await (await fetch("https://open.tiktokapis.com/v2/post/publish/video/init/", {
method:"POST",
headers: {
"Authorization": `Bearer ${tiktokData.access_token}`,
"Content-Type": "application/json; charset=UTF-8",
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36"
},
body: {
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}

}
})).text();
console.log(upload);
Is there some weird default header or something. I even ran it through two cors proxys to see if the IP address of the server, the convex action is on, is blacklisted. I am lost Tiktok response in text:
<HTML><HEAD><br/><TITLE>Access Denied</TITLE><br/></HEAD><BODY><br/><H1>Access Denied</H1><br/> <br/>You don't have permission to access "http&#58;&#47;&#47;open&#46;tiktokapis&#46;com&#47;v2&#47;post&#47;publish&#47;video&#47;init&#47;" on this server.<P><br/>Reference&#32;&#35;18&#46;93c83017&#46;1741929458&#46;2296b32e<br/><P>https&#58;&#47;&#47;errors&#46;edgesuite&#46;net&#47;18&#46;93c83017&#46;1741929458&#46;2296b32e</P><br/></BODY><br/></HTML><br/>
<HTML><HEAD><br/><TITLE>Access Denied</TITLE><br/></HEAD><BODY><br/><H1>Access Denied</H1><br/> <br/>You don't have permission to access "http&#58;&#47;&#47;open&#46;tiktokapis&#46;com&#47;v2&#47;post&#47;publish&#47;video&#47;init&#47;" on this server.<P><br/>Reference&#32;&#35;18&#46;93c83017&#46;1741929458&#46;2296b32e<br/><P>https&#58;&#47;&#47;errors&#46;edgesuite&#46;net&#47;18&#46;93c83017&#46;1741929458&#46;2296b32e</P><br/></BODY><br/></HTML><br/>
Tiktok response when rendered
9 Replies
rgz
rgz4w ago
Have you tried passing this through postman? Can you try this:
curl --location 'https://open.tiktokapis.com/v2/post/publish/video/init/' \
--header 'Authorization: Bearer ${tiktokData.access_token}' \
--header 'Content-Type: application/json; charset=UTF-8' \
--data-raw '{
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}
}'
curl --location 'https://open.tiktokapis.com/v2/post/publish/video/init/' \
--header 'Authorization: Bearer ${tiktokData.access_token}' \
--header 'Content-Type: application/json; charset=UTF-8' \
--data-raw '{
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}
}'
i would crack carmen lopez
it has the same error for some reason when i use reqbin it works
POST /v2/post/publish/video/init/ HTTP/1.1
Accept-Encoding: deflate, gzip
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36
Authorization: Bearer redacted
Host: open.tiktokapis.com
Accept: application/json; charset=UTF-8
Sec-Fetch-Mode: cors
Content-Type: application/json
Content-Length: 353

{
"post_info": {
"title": "Bob",
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": "https://sf16-va.tiktokcdn.com/obj/eden-va2/uvpapzpbxjH-aulauvJ-WV[[/ljhwZthlaukjlkulzlp/3min.mp4"
}
}
POST /v2/post/publish/video/init/ HTTP/1.1
Accept-Encoding: deflate, gzip
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36
Authorization: Bearer redacted
Host: open.tiktokapis.com
Accept: application/json; charset=UTF-8
Sec-Fetch-Mode: cors
Content-Type: application/json
Content-Length: 353

{
"post_info": {
"title": "Bob",
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": "https://sf16-va.tiktokcdn.com/obj/eden-va2/uvpapzpbxjH-aulauvJ-WV[[/ljhwZthlaukjlkulzlp/3min.mp4"
}
}
here is how the reqbin http message looks
rgz
rgz4w ago
So it has to do with your access token
const upload = await (await fetch("https://open.tiktokapis.com/v2/post/publish/video/init/", {
method: "POST",
headers: {
"Authorization": `Bearer ${tiktokData.access_token}`,
"Content-Type": "application/json; charset=UTF-8",
"Accept": "application/json; charset=UTF-8",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36",
"Sec-Fetch-Mode": "cors"
},
body: JSON.stringify({
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}
})
})).text();

console.log(upload);
const upload = await (await fetch("https://open.tiktokapis.com/v2/post/publish/video/init/", {
method: "POST",
headers: {
"Authorization": `Bearer ${tiktokData.access_token}`,
"Content-Type": "application/json; charset=UTF-8",
"Accept": "application/json; charset=UTF-8",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36",
"Sec-Fetch-Mode": "cors"
},
body: JSON.stringify({
"post_info": {
"title": args.title,
"disable_duet": false,
"disable_comment": false,
"disable_stitch": false,
"video_cover_timestamp_ms": 0,
"privacy_level": "SELF_ONLY"
},
"source_info": {
"source": "PULL_FROM_URL",
"video_url": args.videoUrl
}
})
})).text();

console.log(upload);
Can you try this?
i would crack carmen lopez
nvm i fixed it I just didnt json stringify. thank u for taking ur time to help me
rgz
rgz4w ago
Yeah I thought that might have been the case ;P Awesome
i would crack carmen lopez
whats the difference im using use node shouldnt it be the same
rgz
rgz4w ago
🤷‍♂️ The way that tiktok receives data, not sure.
i would crack carmen lopez
have a good evening
rgz
rgz4w ago
Likewise!

Did you find this page helpful?