Forgejo/docs/unsure-where-to-put/dev-notes.md

129 lines
3.1 KiB
Markdown
Raw Normal View History

2023-11-10 14:06:17 +01:00
# enable federation
copy the app.ini in this folder in custom/conf in the forgejo root directory.
Then change the paths in app.ini accordingly to you local environment.
2023-11-10 14:37:00 +01:00
```
; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; ;
; ; SQLite Configuration
; ;
DB_TYPE = sqlite3
; defaults to data/gitea.db
PATH = /home/jem/repo/opensource/forgejo/data/gitea.db
; Query timeout defaults to: 500
SQLITE_TIMEOUT =
; defaults to sqlite database default (often DELETE), can be used to enable WAL mode. https://www.sqlite.org/pragma.html#pragma_journal_mode
SQLITE_JOURNAL_MODE =
HOST =
NAME =
USER =
PASSWD =
SCHEMA =
SSL_MODE = disable
LOG_SQL = false
[federation]
ENABLED = true
```
# build
```
2023-10-27 11:50:39 +02:00
TAGS="sqlite" make build generate-swagger
```
# launch local
```bash
# create a user
2023-11-30 16:00:39 +01:00
./gitea admin user create --name me --password me --email "buero@meissa.de" --config
# create a token
2023-10-27 11:50:39 +02:00
./gitea admin user generate-access-token -u me -t token --scopes write:activitypub,write:repository,write:user
# create a repo
curl -X 'POST' \
'http://localhost:3000/api/v1/user/repos?token=ReplaceThisWithYourGeneratedToken' \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"auto_init": false,
"default_branch": "main",
"description": "none",
"gitignores": "none",
"issue_labels": "",
"license": "apache",
"name": "repo",
"private": true,
"readme": "This is a readme",
"template": false,
"trust_model": "default"
}'
```
2023-11-29 13:24:59 +01:00
# Datastructures handy for local tests
## Star activity
```json
{
"id": "http://localhost:3000/api/v1/activitypub/user-id/1/outbox/12345",
"type": "Star",
"source": "forgejo",
"actor": "http://localhost:3000/api/v1/activitypub/user-id/1",
"object": "http://localhost:3000/api/v1/activitypub/repository-id/1"
}
```
# sync base branch
```
2023-11-06 09:27:41 +01:00
# setup a second repo for excosy implementation
git clone https://git.exozy.me/a/gitea.git exosy
2023-11-06 09:12:09 +01:00
# add remotes
git remote add forgejo git@codeberg.org:forgejo/forgejo.git
# rebase on top of forgejo/forge-development
git checkout forgejo-development
2023-11-07 18:01:52 +01:00
git fetch forgejo
2023-11-03 17:05:48 +01:00
git rebase --onto forgejo/forgejo-development
git push --force
git checkout forgejo-federated-star
git rebase forgejo-development
git push --force
2023-11-03 17:58:47 +01:00
2023-11-06 09:12:09 +01:00
# continue local development after rebase & force-push has happened
2023-11-03 17:58:47 +01:00
git reset --hard origin/forgejo-federated-star
2023-11-03 17:45:53 +01:00
```
2023-11-15 09:08:17 +01:00
# generate swagger api client
2023-11-17 17:19:08 +01:00
go run github.com/go-swagger/go-swagger/cmd/swagger@v0.30.5 generate client -f './templates/swagger/v1_json.tmpl' -c "modules/activitypub2" --operation 'activitypubPerson' --skip-models --existing-models 'github.com/go-ap/activitypub' --skip-validation
2023-11-29 09:21:54 +01:00
2023-11-30 16:00:39 +01:00
# Documentation for learn & reference
# Thoughts on testing
I would like to be able to quickly test a change in the repo code.
For that i need:
A test server with federation enabled
A test user
A test repo
A test auth token (?)
A test request as input value to the API
An expected result for comparison with the output value.
Tests that provide some examples are:
tests/integration/api_activitypub_person_test.go
tests/integration/api_token_test.go
maybe tests/integration/api_repo_test.go