diff --git a/pkg/neo4j/query-events.go b/pkg/neo4j/query-events.go index 9b04b2c..273c145 100644 --- a/pkg/neo4j/query-events.go +++ b/pkg/neo4j/query-events.go @@ -130,11 +130,13 @@ func (n *N) buildCypherQuery(f *filter.F, includeDeleteEvents bool) (string, map } // Time range filters - for temporal queries - if f.Since != nil { + // Note: Check both pointer and value - a zero timestamp (Unix epoch 1970) is almost + // certainly not a valid constraint as Nostr events didn't exist then + if f.Since != nil && f.Since.V > 0 { params["since"] = f.Since.V whereClauses = append(whereClauses, "e.created_at >= $since") } - if f.Until != nil { + if f.Until != nil && f.Until.V > 0 { params["until"] = f.Until.V whereClauses = append(whereClauses, "e.created_at <= $until") } @@ -300,19 +302,17 @@ func (n *N) parseEventsFromResult(result *CollectedResult) ([]*event.E, error) { _ = tags.UnmarshalJSON([]byte(tagsStr)) } - // Create event + // Create event with decoded binary fields e := &event.E{ + ID: id, + Pubkey: pubkey, Kind: uint16(kind), CreatedAt: createdAt, Content: []byte(content), Tags: tags, + Sig: sig, } - // Copy fixed-size arrays - copy(e.ID[:], id) - copy(e.Sig[:], sig) - copy(e.Pubkey[:], pubkey) - events = append(events, e) } diff --git a/pkg/version/version b/pkg/version/version index 9dc0e18..b0d3f59 100644 --- a/pkg/version/version +++ b/pkg/version/version @@ -1 +1 @@ -v0.49.0 +v0.49.1