/TODO (070b936e206b567d8ff73a1c2cfa4b8b0042cb26) (1602 bytes) (mode 100644) (type blob)
== BEFORE FIRST RELEASE! ==
[ ] Validate e-mails.
[ ] Validate repo names.
[ ] Validate user names.
[ ]
== Low priority ==
[ ] Count the numbers of clones/pushes/pulls.
[ ] Add memcache caching for all database lookups.
[ ] Allow to configure the limit of the patch size to prevent abuses.
[ ] Allow to configure to refuse binary files.
[ ] Allow to configure to refuse commits with broken spcaes/tab mixes.
[ ] Add a repo_prop_set/get function that will set/get a file in .git folder. THis way we can
speed up some lookups (no need for database). Hm.
[ ] When we delete an repository, we will do repo_prop_set(repo, disabled) and we will
return OK, in the background we will do the removing. Do not forget to also remove clones. Hm.
[ ] SSH keys section.
[ ] E-mail aliases section.
[ ] User details section (full name, e-mail, blog, avatar, mail notifications).
[ ] Change password section.
[ ] Check if user is over-quota on push.
[ ] The cron will have to:
[ ] Compute disk usage, ignoring hard links. Hm. Probably we will add
only the owner, even if the files have multiple links. TBD.
[ ] VACUUM tables.
[ ]
[ ] UTF-8 checks.
[ ] W3C validation on all pages.
[ ] Validate user and repo names. Probably other things.
[ ] What happens if a user is suspended? Do we allow forgot pass sending?
[ ] Do not allow session updates/any command if user is suspended after his/her login.
[ ] Timeout for connections (ssh/git-daemon/etc.)!
[ ] Check if we have to respect 4HEXA also on SSH. I think not.
[ ] Limit number of simultaneously connection per repo and per user. maybe also the time!
[ ]
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
35147 |
94a9ed024d3859793618152ea559a168bbcbb5e2 |
LICENSE |
100644 |
blob |
149 |
73843b52b65f6a00b4b9b4310e2367196067633d |
README |
100644 |
blob |
1602 |
070b936e206b567d8ff73a1c2cfa4b8b0042cb26 |
TODO |
040000 |
tree |
- |
993cf407a732d5a900e83adf1283042f1294fbde |
admin |
040000 |
tree |
- |
9b3b34a3145e2324acd1cb4cedaf9e446e933469 |
inc |
040000 |
tree |
- |
bb3d88327ab90bf80db94514eb422dd3d082a4f1 |
root |
040000 |
tree |
- |
78c9f0e95baa5d134ec011428ee3b5f0728c8e9d |
samples |
040000 |
tree |
- |
51536a53bc9e74f9c93bf51d64d7672933b33784 |
scripts |
040000 |
tree |
- |
7c2083e0ae046493399b2aa93494ba096e0e76d5 |
tests |
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/catalinux/rocketgit
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/catalinux/rocketgit
Clone this repository using git:
git clone git://git.rocketgit.com/user/catalinux/rocketgit
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main