nip34: repository state and some ToEvent() helpers.

This commit is contained in:
fiatjaf 2024-08-27 12:05:10 -03:00
parent c78c5658a3
commit 106ca136fd
2 changed files with 109 additions and 0 deletions

View File

@ -52,6 +52,51 @@ func ParseRepository(event nostr.Event) Repository {
return repo
}
func (r Repository) ToEvent() nostr.Event {
tags := make(nostr.Tags, 0, 10)
tags = append(tags, nostr.Tag{"d", r.ID})
if r.Name != "" {
tags = append(tags, nostr.Tag{"name", r.Name})
}
if r.Description != "" {
tags = append(tags, nostr.Tag{"description", r.Description})
}
if r.EarliestUniqueCommitID != "" {
tags = append(tags, nostr.Tag{"r", r.EarliestUniqueCommitID, "euc"})
}
if len(r.Maintainers) > 0 {
tag := make(nostr.Tag, 1, 1+len(r.Maintainers))
tag[0] = "maintainers"
tag = append(tag, r.Maintainers...)
tags = append(tags, tag)
}
if len(r.Web) > 0 {
tag := make(nostr.Tag, 1, 1+len(r.Web))
tag[0] = "web"
tag = append(tag, r.Web...)
tags = append(tags, tag)
}
if len(r.Clone) > 0 {
tag := make(nostr.Tag, 1, 1+len(r.Clone))
tag[0] = "clone"
tag = append(tag, r.Clone...)
tags = append(tags, tag)
}
if len(r.Relays) > 0 {
tag := make(nostr.Tag, 1, 1+len(r.Relays))
tag[0] = "relays"
tag = append(tag, r.Relays...)
tags = append(tags, tag)
}
return nostr.Event{
Kind: 30617,
Tags: tags,
}
}
func (repo Repository) GetPatchesSync(ctx context.Context, s nostr.RelayStore) []Patch {
res, _ := s.QuerySync(ctx, nostr.Filter{
Kinds: []int{nostr.KindPatch},

64
nip34/state.go Normal file
View File

@ -0,0 +1,64 @@
package nip34
import (
"strings"
"github.com/nbd-wtf/go-nostr"
)
type RepositoryState struct {
nostr.Event
ID string
HEAD string
Tags map[string]string
Branches map[string]string
}
func ParseRepositoryState(event nostr.Event) RepositoryState {
st := RepositoryState{
Event: event,
Tags: make(map[string]string),
Branches: make(map[string]string),
}
for _, tag := range event.Tags {
if len(tag) < 2 {
continue
}
switch tag[0] {
case "d":
st.ID = tag[1]
case "HEAD":
if strings.HasPrefix(tag[1], "ref: refs/heads/") {
st.HEAD = tag[1][16:]
}
default:
if strings.HasPrefix(tag[0], "refs/heads/") {
st.Branches[tag[0][11:]] = tag[1]
} else if strings.HasPrefix(tag[0], "refs/tags/") {
st.Branches[tag[0][10:]] = tag[1]
}
}
}
return st
}
func (rs RepositoryState) ToEvent() nostr.Event {
tags := make(nostr.Tags, 0, 2+len(rs.Branches)+len(rs.Tags))
tags = append(tags, nostr.Tag{"d", rs.ID})
tags = append(tags, nostr.Tag{"ref: refs/heads/" + rs.HEAD})
for branchName, commitId := range rs.Branches {
tags = append(tags, nostr.Tag{"refs/heads/" + branchName, commitId})
}
for tagName, commitId := range rs.Tags {
tags = append(tags, nostr.Tag{"refs/tags/" + tagName, commitId})
}
return nostr.Event{
Kind: 30618,
Tags: tags,
}
}