48 lines
2.3 KiB
Markdown
48 lines
2.3 KiB
Markdown
|
<div align="center">
|
||
|
|
||
|
# ForgeFlux StarChart
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/27257/27257d654c49d39b7ba77285b28f794f7acb2dd3" alt="Documentation"](https://forgeflux-org.github.io/starchart/starchart/)
|
||
|
[data:image/s3,"s3://crabby-images/b7cfa/b7cfa8d006222613ce7d436ed48f399f117fd00c" alt="Build"](https://github.com/forgeflux-org/starchart/actions/workflows/linux.yml)
|
||
|
[data:image/s3,"s3://crabby-images/014fa/014fa5bfeb0bb6eca55277e890cfabe93f17dbb3" alt="dependency status"](https://deps.rs/repo/github/forgeflux-org/starchart)
|
||
|
[data:image/s3,"s3://crabby-images/3f773/3f773d5777d026da2e30bce8787213495aceda43" alt="codecov"](https://codecov.io/gh/forgeflux-org/starchart)
|
||
|
<br />
|
||
|
[data:image/s3,"s3://crabby-images/81843/818434c7562660614cf702a952792ce8dc8efc8b" alt="AGPL License"](http://www.gnu.org/licenses/agpl-3.0)
|
||
|
[data:image/s3,"s3://crabby-images/f201d/f201d4fde3bfcd0360a00f1984a5283cfd990d8a" alt="Chat"](https://matrix.to/#/#forgefederation:matrix.batsense.net)
|
||
|
|
||
|
</div>
|
||
|
|
||
|
## Why
|
||
|
|
||
|
There are several small, private forges that host Free Software projects.
|
||
|
Some of these Forges might one day participate in the federated
|
||
|
ecosystem. So it would make sense to have a system(see
|
||
|
[spider mechanism](#consensual-spidering)) that would map and advertise these instances
|
||
|
and the projects that they host.
|
||
|
|
||
|
## Consensual Spidering
|
||
|
|
||
|
We are aware that spiders some [very
|
||
|
aggressive](https://git.sr.ht/~sircmpwn/sr.ht-nginx/commit/d8b0bd6aa514a23f5dd3c29168dac7f89f5b64e7)
|
||
|
and small forges are often running on resource-constrained environments.
|
||
|
Therefore, StarChart(this spider) will only crawl a service if the crawl is
|
||
|
requested by the admin of the forge(more accurately, folks that have
|
||
|
access to the DNS associated with the forge's hostname though).
|
||
|
|
||
|
StarChart will rate limit API calls to one call every 10 seconds. For
|
||
|
instance, a Gitea API call would resemble:
|
||
|
|
||
|
```bash
|
||
|
curl -X 'GET' \
|
||
|
'https://gitea.example.org/api/v1/repos/search?page=2&limit=20' \
|
||
|
-H 'accept: application/json'
|
||
|
```
|
||
|
|
||
|
## Contributing
|
||
|
|
||
|
Thanks for considering contributing on GitHub. If you are not an GitHub
|
||
|
but would like to contribute to ForgeFlux sub-projects(all repositories
|
||
|
under this organisation), I would be happy to manually mirror this
|
||
|
repository on my [Gitea instance](https://git.batsense.net), which has a
|
||
|
much [more respectful privacy policy](https://batsense.net/privacy-policy)
|