Codeberg/Community
54
325
Fork
You've already forked Community
12

Codeberg API inaccessible by any Node client. #1923

Open
opened 2025年05月10日 06:34:21 +02:00 by wale · 1 comment

Comment

I'm writing a fullstack Node app that requires access to the Codeberg API, however the API returns a timeout specifically for Node clients since Tuesday - regardless of IP, user-agent or even library. I have tested this with Python requests (as an example of a working client), Node undici, ofetch and axios.

I have ruled out issues with IPs / ratelimiting, as this is reproducible over multiple networks, and I have also ruled out browsers and cURL.

An example of this is below.

Working client:

import requests
get_response = requests.get("https://codeberg.org/api/v1/repos/codeberg/community/git/trees/7d55578694c587995e8ac43b7e7e236ecda4e00a?recursive=true")
print(get_response.content)

Failing client (uses undici):

async function main() {
 const response = await fetch('https://codeberg.org/api/v1/repos/codeberg/community/git/trees/7d55578694c587995e8ac43b7e7e236ecda4e00a?recursive=true');
 const data = await response.json();
 console.log(data);
}
main().catch(console.error);

Error:

TypeError: fetch failed
 at node:internal/deps/undici/undici:13502:13
 at process.processTicksAndRejections (node:internal/process/task_queues:105:5)
 at async main (/path/to/location/test.js:2:20) {
 [cause]: AggregateError [ETIMEDOUT]: 
 at internalConnectMultiple (node:net:1139:18)
 at internalConnectMultiple (node:net:1215:5)
 at Timeout.internalConnectMultipleTimeout (node:net:1739:5)
 at listOnTimeout (node:internal/timers:596:11)
 at process.processTimers (node:internal/timers:529:7) {
 code: 'ETIMEDOUT',
 [errors]: [ [Error], [Error] ]
 }
}
### Comment I'm writing a fullstack Node app that requires access to the Codeberg API, however the API returns a timeout **specifically for Node clients** since Tuesday - regardless of IP, user-agent or even _library_. I have tested this with Python `requests` (as an example of a working client), Node `undici`, `ofetch` and `axios`. I have ruled out issues with IPs / ratelimiting, as this is reproducible over multiple networks, and I have also ruled out browsers and cURL. An example of this is below. Working client: ```py import requests get_response = requests.get("https://codeberg.org/api/v1/repos/codeberg/community/git/trees/7d55578694c587995e8ac43b7e7e236ecda4e00a?recursive=true") print(get_response.content) ``` Failing client (uses `undici`): ```js async function main() { const response = await fetch('https://codeberg.org/api/v1/repos/codeberg/community/git/trees/7d55578694c587995e8ac43b7e7e236ecda4e00a?recursive=true'); const data = await response.json(); console.log(data); } main().catch(console.error); ``` Error: ``` TypeError: fetch failed at node:internal/deps/undici/undici:13502:13 at process.processTicksAndRejections (node:internal/process/task_queues:105:5) at async main (/path/to/location/test.js:2:20) { [cause]: AggregateError [ETIMEDOUT]: at internalConnectMultiple (node:net:1139:18) at internalConnectMultiple (node:net:1215:5) at Timeout.internalConnectMultipleTimeout (node:net:1739:5) at listOnTimeout (node:internal/timers:596:11) at process.processTimers (node:internal/timers:529:7) { code: 'ETIMEDOUT', [errors]: [ [Error], [Error] ] } } ```
Owner
Copy link

Hmm this is weird, but we probably need more information. I am not aware of a setup on our end that would cause timeouts specifically.

Can you rule out that it is an IPv4/IPv6 issue? They are among the most common sources of issues, and many people don't realize they are having network issues, because so many websites still use IPv4 only. It might be possible that different environments behave differently there.

Hmm this is weird, but we probably need more information. I am not aware of a setup on our end that would cause timeouts specifically. Can you rule out that it is an IPv4/IPv6 issue? They are among the most common sources of issues, and many people don't realize they are having network issues, because so many websites still use IPv4 only. It might be possible that different environments behave differently there.
Sign in to join this conversation.
No Branch/Tag specified
main
No results found.
Labels
Clear labels
accessibility

Reduces accessibility and is thus a "bug" for certain user groups on Codeberg.
bug

Something is not working the way it should. Does not concern outages.
bug
infrastructure

Errors evidently caused by infrastructure malfunctions or outages
Codeberg

This issue involves Codeberg's downstream modifications and settings and/or Codeberg's structures.
contributions welcome

Please join the discussion and consider contributing a PR!
docs

No bug, but an improvement to the docs or UI description will help
duplicate

This issue or pull request already exists
enhancement

New feature
infrastructure

Involves changes to the server setups, use `bug/infrastructure` for infrastructure-related user errors.
legal

An issue directly involving legal compliance
licence / ToS

involving questions about the ToS, especially licencing compliance
please chill
we are volunteers

Please consider editing your posts and remember that there is a human on the other side. We get that you are frustrated, but it's harder for us to help you this way.
public relations

Things related to Codeberg's external communication
question

More information is needed
question
user support

This issue contains a clearly stated problem. However, it is not clear whether we have to fix anything on Codeberg's end, but we're helping them fix it and/or find the cause.
s/Forgejo

Related to Forgejo. Please also check Forgejo's issue tracker.
s/Forgejo/migration

Migration related issues in Forgejo
s/Pages

Issues related to the Codeberg Pages feature
s/Weblate

Issue is related to the Weblate instance at https://translate.codeberg.org
s/Woodpecker

Woodpecker CI related issue
security

involves improvements to the sites security
service

Add a new service to the Codeberg ecosystem (instead of implementing into Gitea)
upstream

An open issue or pull request to an upstream repository to fix this issue (partially or completely) exists (i.e. Gitea, Forgejo, etc.)
wontfix

Codeberg's current set of contributors are not planning to spend time on delegating this issue.
Milestone
Clear milestone
No items
No milestone
Projects
Clear projects
No items
No project
Assignees
Clear assignees
No assignees
2 participants
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".

No due date set.

Dependencies

No dependencies set.

Reference
Codeberg/Community#1923
Reference in a new issue
Codeberg/Community
No description provided.
Delete branch "%!s()"

Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?