Refine domain classes: behavior tags, extra-tag passthrough, cleanups
tests / tests (push) Failing after 5m10s
tests / tests (push) Failing after 5m10s
Iterate on @welshman/domain following review: - base: add `group`/`protect`/`expires` behavior tags (parsed in base, emitted via addBehaviorTags before hashing) and an `extraTags` passthrough (opt-in via reservedTagKeys) so tag carry-over lives in one place; migrate Handler, Comment, Thread onto it. Comment gains nested root/parent ref structs + setters. - List: fix inverted keepTags; add clearTags/clearPublicTags/clearPrivateTags and use them in the relay/server list setters. - RelayList: preserve complementary read/write capability instead of dropping modeless entries. - Split Relay/Room membership ops into per-kind classes (RelayAddMember/ RelayRemoveMember, RoomAddMember/RoomRemoveMember) over a shared base. - TimeEvent (renamed from CalendarEvent): derive "D" day tags in toTemplate. - Feed: default to an empty feed, fail parse when the "feed" tag is missing. - RelaySet added; CommunityList renamed to GroupList; predicate bare add/remove mutators; RoomMeta uses randomId; PollResponse.selections drops pollType. - Remove ChannelList, FileServerList, Settings, and event-asserting getAddress/ display accessors. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com> Claude-Session: https://claude.ai/code/session_01V67tPYdvh1qCkjEBhJGZUR
This commit is contained in:
@@ -0,0 +1,21 @@
|
||||
import {uniq} from "@welshman/lib"
|
||||
import {COMMUNITIES, getAddressTagValues} from "@welshman/util"
|
||||
import {EncryptableList} from "./List.js"
|
||||
|
||||
// NIP-51 kind-10004 group (community) membership list. Entries are `a` tags
|
||||
// pointing at kind-34550 community definitions.
|
||||
export class GroupList extends EncryptableList {
|
||||
readonly kind = COMMUNITIES
|
||||
|
||||
addresses() {
|
||||
return uniq(getAddressTagValues(this.tags()))
|
||||
}
|
||||
|
||||
addGroup(address: string, relayHint?: string) {
|
||||
return this.addPublicTags(["a", address, relayHint || ""])
|
||||
}
|
||||
|
||||
removeGroup(address: string) {
|
||||
return this.removeTagsWithValue(address)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user