r/o

add deploy keys UI 9eda7463 parent 3b7eec1b

authored by ~lotte

1
* [ ] https://github.com/GitoxideLabs/gitoxide instead of libgit2
2
3
* [ ] We might want to make an über-NIF including connecting to Comrak/ammonia/etc. ourselves (or a separate NIF for that), since overriding stuff in MDEx/Autumn is hard. See markdown.ex.
4
5
* [ ] show dag nav on mobile with popout
6
7
* [ ] use read replica where appropriate
8
* [ ] address our lack of sendmail in container; send mail to status.hostIP:25 (no auth)
9
* [ ] "hooks" also point HEAD to tags when received, oops
10
* [ ] autumn and mdex NIFs are both around 80MB; the latter includes the former. dedupe.
11
12
* [ ] tree view isn't getting the right commits for files in subdirectories
13
since we're back to one-directory-at-a-time and need to redo how we search
14
for the last changed commit.
15
* [ ] relative URIs: ugc- prefix, #xyz shouldn't navigate away, etc.
16
* [ ] pressing browser forward/back should trigger fancy blob highlights, not
17
just the automatic :target ones
18
* [ ] some patch links really need to scroll back to top
19
* [ ] actually show commit details at top of tree/blob views
20
21
* [ ] https://talya.nossa.ee ?
22
23
* [ ] visual confirmation on "copy to clipboard" shouldn't be a modal, just temporarily change the icon
24
25
### short term
26
27
- [x] blob
28
- [x] images
29
- [ ] pdfs, etc.
30
- [ ] less polysaturated, leaner design
31
- [ ] do we use Binary explicitly to not have to pass Unk back as a linked list? @fun
32
- [ ] get our tests and coverage fixed again. @pls
33
- [ ] message to end-user when following a redirect (via git)
34
35
### features
36
37
- [ ] dag infinite scroll/load to context
38
- [ ] blob permalink
39
- [ ] responsive (mobile) styles
40
- [ ] override locale user option
41
- [ ] diff 2+ parent commit
42
- [ ] passkey support
43
- jfc https://shadowfacts.net/2023/phoenix-passkeys/
44
- [ ] default branch: choose from existing branches; non-UTF-8 support
45
46
### housekeeping
47
48
- [ ] tab indices on e.g. crear repositorio
49
- [ ] IPv6 check
50
- [ ] redirect to primary host if not on it
51
- [ ] reverse where the structs are defined (between Git2/Nossa.Storage*)
52
- [ ] rename RepositorySelf* to RepositorySettings*?
53
- [ ] extract CGI into its own application; stream request/response in/out
54
- [ ] consider erlexec, or write our own driver, so we can get stderr out of
55
the way
56
- [ ] gettext once-over in hard-to-reach spots
57
- [ ] verify typescript in compile step
58
- [ ] override elixir/erlang used in autumn/mdex to keep all together
59
- there's some wip of this in zmlqmwzq
60
61
### graceful degradation
62
63
- [x] branch selector disappears on safari with javascript on
64
- [ ] "method" links don't work with noscript since they don't do the right
65
thing
66
- [ ] can't dismiss flash
67
- [ ] javascriptless sidebar changes? (then they must go in the URL)
68
69
### production ops
70
71
- [ ] caching: nginx, varnish? fragment?, git object? how much does bandwidth
72
cost at ovh? bunny? integrate caching, backup into nix module.
73
- right now the pawiwo visibly reloads on every page
74
- [ ] DIY anubis? (for easy deploy to other Phoenix/etc. strength in diversity @fun
75
is a real consideration in this fight.)
76
- [ ] backup restore procedure/test
77
- [ ] feature that restores from backup as we make it. ez!
78
- [ ] admin diagnostics page (combine into/with live dashboard somehow?)
79
- [ ] per repo: audit log, pushes, etc. (git hooks?)
80
- [ ] LRU-ish app-level caching: memcached? redis? ets? mnesia?
81
82
### future
83
84
- [ ] avatar upload
85
- [ ] federation?
86
- identity: auth to other nossa instance
87
- auth another instance for avatars
88
- federated MR-type deal?
89
- don't want to redo a whole code review thing here, idt? check out gerrit
90
etc.
91
- see also simon tatham's thing on git; pull request is just "please check
92
again"
93
- opinionated about rebase/jj norms
94
- at the very least we could show interdiffs between pushes etc.
95
- [ ] merge queue? what do i need at work?
96
- [ ] Log in with GitHub/GitLab/Forgxejo? make it easy to work across, to not be
97
completely hecked by network effects?
98
99
100
## archivo
101
102
- [x] change "settings" top right to "account"
103
- [x] repository delete
104
- [x] repository storage
105
- [x] push keys
106
- [x] proper logging (insert some in e.g. storage creation failure)
107
- [x] some kind of log aggregation/interface on kala
108
- [x] test coverage back up
109
- [x] do some more!
110
- [x] work out why jj fails to push!
111
- [x] fix up this /blah/!url nonsense
112
- [x] git store tests
113
- [x] git tests async: use per-runner store
114
- [x] last controller tests
115
- [x] don't rename storage: use only numeric ids in storage
116
- [x] figure out why our distribution metrics ("phoenix.*") don't make it to
117
grafana (or appear in /metrics at all)
118
- [x] try ETS
119
- [x] pawiwo icon
120
- [x] clean up RepositoryGitControllerTest
121
- [x] Anubis/Nepenthes/?
122
- See https://lobste.rs/s/dmuad3/mitigating_sourcehut_s_partial_outage --- we
123
will need to be prepared; robots.txt, etc., and above all usage stats/graphs
124
so we can see it happen.
125
- [x] https://git.sr.ht/robots.txt is a good start, though of course it isn't
126
saving them. Still, no reason to start from zero.
127
- [x] start of gettext support
128
- [x] main browsing interface, ui polish/consistency
129
- [x] navigate tree
130
- [x] zindex fix for icons overlaying nav bit
131
- [x] select commit
132
- need to resolve a rev instead of a branch now
133
- [x] include breadcrumbs in Diff view
134
- [x] wherever "path=" is sneaking into our URLs, get it out (breadcrumbs)
135
- [x] liveview for navigating within
136
- [x] extract inline classes into css (w/ @apply)
137
- [x] dark mode styles
138
- [x] actual colour system
139
- [x] pawiwo svg for colours
140
- [x] ok dark mode again
141
- [x] safari, chromium
142
- [x] repository redirects
143
- [x] tailwind v4
144
https://elixirforum.com/t/mix-tailwind-4-0-0-beta-1-support/67636/17
145
- [x] more post-liveview cleanup of repository controller; check over
146
auth-related stuff.
147
- [x] then back to (re)design
148
- [x] work out whether diff view will be within the same liveview, a different
149
one, etc.? - it may be overkill; navigating the tree responsively is nice,
150
but the huge diffs might make browsers sick. gotta test!
151
- [x] decide on the repository view design; do we keep the commits there? do
152
we make the sidebar collapsable a la ~~yuta~~ hexdocs etc.? something
153
else entirely?
154
- what do i want to see when i hit a root of a repo? what are the various
155
reasons i end up on one of those on github/srht/etc.?
156
* linked to as a project's "home page", searched and the first result (or
157
apparent best result for an official download or similar)
158
* directly navigated to because i want to browse the source of something
159
i don't have a local clone of (and i haven't yet hit the threshold
160
where i need to use tools to look thru; source aware views can sometimes
161
abrogate the need but often (e.g. github's views + semantic index)
162
they're an untenable degree of both meh design usability (in e.g., links
163
are all too small, everything bunched up on the side, often starting to
164
scroll horizontally by this point; not a priority) and flawed impl (in
165
e.g. elixir outlining. is this just from elixir-ls? tree-sitter?))
166
* often want a specific version (i.e. something i'm running/using),
167
sometimes just browse main/master if cbf/not relevant/more interested
168
in design than exact
169
* summary of this point: "whatever would be unnecessary if i always had
170
a clone of everything". i don't, but i'm in the position of improving
171
the situation for when you don't -- what actually helps?
172
* sometimes i do this even in the presence of a clone on disk, because
173
i'm *using* that one somehow, but i cbf creating a new worktree.
174
similar result. a browser window (and the way you can open lots of
175
them, to various paths/versions/etc) is a much smaller cognitive unit
176
to manage than a worktree.
177
* how often do i want to see the whole commit list straight up front like
178
this? (day separations would give this a lot more context, for what
179
it is.)
180
* almost always would prefer the *graph*; i almost never prefer the
181
straight log style locally. (think about jj log view.)
182
* there are three axes: commit (temporal), path (spatial), view (fn).
183
github exposes commit consistently, path inconsistently (compare blob
184
view to commit history restricted to a subpath), view inconsistently
185
("Commits" page vs 2.5 tree pages (root, non-root w/ README, non-root;
186
sidebar tree only visible in non-root) vs blob (very aligned with
187
non-root tree). root really is the odd one out, since it's a landing
188
page.)
189
* big commit *graph* that stashes in side: file listing-style tree view
190
that then collapses into expanding tree sidebar: blob.
191
* then you can shift around points in the graph while retaining
192
visibility over the directory tree, no reloads/scrolls breaking
193
"immersion".
194
* does the graph stash over to a plain log? i should make sure while i'm
195
developing that i work with the browser the sizes i want to actually
196
be using it at. (i.e. push back against default to 2/3rds code, unless
197
i'm developing a usecase where i'd have the browser at 1/3rd).
198
* sometimes you do want to view just the log of a file or subtree.
199
kinda wanna apply that filter *to* the far-left graph, as a
200
saved-in-navigation thing. then you can nav to a commit (still
201
centred on the tree or file you started the filter from), see it in
202
context, move around, and then at some point you back up or clear
203
the 'path filter' on the DAG view.
204
* note that we want the current path to remain in the tree view
205
when navigating the DAG view even when we don't have a path filter
206
active. same with current blob, if any.
207
* this kind of removes that fake third axis, exposes the other two as
208
proper orthogonal ones. github flattening the DAG with no way to
209
recover is criminal.
210
* and then there's commit view, which is a whole other thing: viewing a
211
commit message & diff.
212
- [x] let's fix our URIs in gen i guess, ?path= is ugly
213
- [x] support submodules in tree
214
- [x] be explicit in which params are UTF-8 encoded & which aren't
215
- [x] global support for non-UTF-8; no error messages
216
- [x] navigate commits on left; focus current commit as navigating
217
- [x] compile-time the storage layer choice
218
- [x] vyxos push fails!
219
- [x] "last commit modified" links are incorrect for subtrees, there's a TODO in
220
git2.rs somewhere
221
- [x] decompose git2's monster "resolve_commit" into somewhat orthogonal ops
222
- [x] syntax highlighting
223
- [x] little live demo with channels of push response
224
- [x] reaffirm backup situation for kala
225
- [x] nix syntax highlighting egumi??
226
- [x] wow! nossa in docker/k8s!
227
- [x] ES: "Clave de empujar creada exitosamente" when creating a new repo!?
228
- [x] new repo => brocken
229
- [x] remove register links if register is disabled
230
- [x] install our own git hooks in repositories, set HEAD on push if unset
231
- [x] assign default branch on first push
232
- [x] this causes clone failures, the weird nix flake stuff we've been seeing, etc.
233
- [x] floating windows don't preserve state on livereload
234
- [x] let's fix the first thing: navigating back to a subtree shouldn't close an
235
open blob. we can keep our existing assigns, or just stream.
236
- [x] open new windows in specified order
237
- [x] default orientation based on aspect ratio
238
- [x] splith(3): need to have up/down too; splitv(3) needs to have left/right.
239
it's too hard to just do that with merges and unmerges.
240
- [x] skip floating windows when finding clientInDirection; similarly,
241
moveClient/mergeClient; their behaviour is very puzzling if it's not clear
242
what's happening
243
- [x] "hooks" are breaking on current live because they're symlinks into old
244
versions of nossa, since GC'd from the nix store!
245
* [x] shynet: add javascript call on live patch
246
* [x] what's nom? https://github.com/NixOS/nixpkgs/pull/430275#pullrequestreview-3089109039
247
* [x] set inline-block for repo breadcrumbs so the underline doesn't over-extend
248
* [x] NixOS tests to ensure the module stays good even after we move to deploying on k8s
249
* [x] per-repo deploy keys: R/O, R/W
250
* i want this for flux
251
* [x] everything except the UI
252
* [x] the UI
253
* [x] update the unique index to be per-repo since we've changed auth anyway
254