Commit Graph

632 Commits

Author SHA1 Message Date
fiatjaf ccbb44989f get rid of WriteJSON() and replace calls with manually marshaled envelopes. 2023-05-09 17:02:22 -03:00
fiatjaf d36fbb95b9 ParseMessage() returns an Envelope, use that on the main relay handler loop. 2023-05-09 16:55:21 -03:00
fiatjaf f7ce78d7f8 add custom envelope types with json codecs. 2023-05-09 16:31:10 -03:00
fiatjaf 52a493fd96 EnsureRelay() returns an error. 2023-05-09 00:09:05 -03:00
shota3506 6c186812c9 fix readme code example 2023-05-07 06:21:25 -03:00
shota3506 96f3d4c9a0 fix event comparison in EventSerialization test 2023-05-07 06:21:12 -03:00
fiatjaf c0a42ff2ff SimplePool improvements. 2023-05-06 14:32:39 -03:00
fiatjaf_ 2b2c000d6a Merge pull request #81 from wozuo/master 2023-05-05 21:06:07 -03:00
Marc Tarnutzer 69b9d82bb1 check if messages are compressed on receive 2023-05-06 01:48:01 +02:00
fiatjaf 98a2a39521 add SimplePool. 2023-05-05 19:05:11 -03:00
Marc Tarnutzer c86e907142 enable compression by default 2023-05-05 22:00:25 +02:00
Marc Tarnutzer ee9502bc3e fix: outgoing pings 2023-05-05 12:14:29 +02:00
Marc Tarnutzer f152a5e0c7 simplify connection close 2023-05-04 23:54:39 +02:00
Marc Tarnutzer 9c01ead91f switch to gobwas/ws, add compression 2023-05-04 23:51:15 +02:00
fiatjaf 1c118cd83e take context.Context for nip-05 resolving. 2023-05-04 13:20:15 -03:00
fiatjaf 53e0935308 parse kind in nevent. 2023-05-04 08:24:39 -03:00
fiatjaf 6fc1627fcc json tags on pointers. 2023-05-04 08:24:26 -03:00
fiatjaf 32ca737acf remove unused ping handler (it is done automatically).
fixes https://github.com/nbd-wtf/go-nostr/pull/74, thanks @patdz
2023-04-26 08:12:50 -03:00
Patrick Bennett ebae5d41e6 Add most NIP-11 extension structures to the RelayInformationDocument struct. (#80)
* Fix race condition on status in Relay.Publish method and failure to send

A race-condition exists between setting of the (unprotected) status and the callback which sets the status upon receiving an OK.
The message is sent which can receive an OK in separate goroutine (setting status) prior to the status being set to 'sent.'
The OK can be received prior to the status being set.

This fix also sets the status to PublishStatusFailed if the WriteJSON call fails.

* Add some NIP-11 extension structures to the RelayInformationDocument struct.

Added additional NIP-11 fields for relays that want to provide additional details based on NIP-11 extensions.
The retention structure has been left out as it doesn't have a clean schema for kinds (array of kinds, or pairs of kinds?)
Specified the fields w/ omitempty so marshaled will be same as original NIP-11 if nothing else is specified.
Nested structs defined as pointers so they are omitted if not specified.

* Fix TestPublishWriteFailed so that the socket is given a brief amount of time to close prior to publish being called.
The test relies on Publish always failing.
2023-04-26 08:06:05 -03:00
fiatjaf 3838ed7e91 guard ping writes with the mutex.
fixes https://github.com/nbd-wtf/go-nostr/issues/76#issuecomment-1521170395
2023-04-26 08:04:51 -03:00
Patrick Bennett b077a41f83 Fix race condition on status in Relay.Publish method and failure to send
A race-condition exists between setting of the (unprotected) status and the callback which sets the status upon receiving an OK.
The message is sent which can receive an OK in separate goroutine (setting status) prior to the status being set to 'sent.'
The OK can be received prior to the status being set.

This fix also sets the status to PublishStatusFailed if the WriteJSON call fails.
2023-04-21 07:48:08 -03:00
fiatjaf 9b89a49e5e cancel relay context when calling .Close().
fixing https://github.com/nbd-wtf/go-nostr/issues/76#issuecomment-1517251898
2023-04-21 07:45:28 -03:00
fiatjaf 3785daf8aa normalize relay url from Tag.Relay(). 2023-04-19 14:40:44 -03:00
fiatjaf fc7b20114b update readme and example. 2023-04-16 16:25:25 -03:00
fiatjaf 2695854e56 fixing json filter json + marshaling filter tags. 2023-04-16 16:22:32 -03:00
fiatjaf c42059f4b4 tests run (but not pass) and fine-tuning (specially tag filters) on filter_easyjson.go 2023-04-16 16:16:16 -03:00
fiatjaf 0a3e898c2f using easyjson. 2023-04-16 15:56:50 -03:00
fiatjaf af52f8d490 debug log events received. 2023-04-14 10:07:10 -03:00
fiatjaf 326d2790de rename interface{} to any. 2023-04-12 12:14:24 -03:00
fiatjaf ec3f1287c4 debug log CLOSE messages. 2023-04-12 12:14:16 -03:00
fiatjaf 2314db57a1 tweak timeouts on Publish() 2023-04-11 15:33:29 -03:00
fiatjaf dd692560ff fill in event pubkey when signing. 2023-04-11 15:33:13 -03:00
fiatjaf 32768b1a5b improve debug logging, fix stringer interface, debuglog events sent, fix debuglogging affecting the actual values. 2023-04-11 11:02:35 -03:00
fiatjaf 7f64f2f65e improve logic for subscribing to just-published events. 2023-04-11 10:38:30 -03:00
fiatjaf df7abe72fa fix: return PublishStatusFailed if connection can't be established etc. 2023-04-11 09:52:01 -03:00
fiatjaf 6f74d284c4 improved logging thing with the "debug" build tag. 2023-04-11 09:35:37 -03:00
fiatjaf 7b0af23f1a implement Stringer for Event. 2023-04-11 07:36:59 -03:00
fiatjaf 4507477486 slight improvements to debug logging. 2023-04-11 07:10:05 -03:00
fiatjaf e103c99bb8 a pluggable logging interface and more debug logging. 2023-04-11 00:32:32 -03:00
fiatjaf f918809e21 add subscription test using the damus relay. 2023-04-07 12:52:10 -03:00
fiatjaf a666994ae7 fix test that was broken when the context passed to RelayConnect() became the relay context for its full timeline.
30e0e1040a
2023-04-06 16:22:24 -03:00
fiatjaf ef428ff39f Subscription.Fire() can error, so Relay.Subscribe() must also. 2023-04-06 16:21:25 -03:00
fiatjaf 4c9db5928a log relay url too when filter doesn't match. 2023-04-06 12:57:15 -03:00
fiatjaf abfb7de394 add a mutex lock around Challenges and Notices channel. 2023-03-31 22:09:01 -03:00
fiatjaf 411718f3c1 reformat nip04 errors. 2023-03-31 09:30:33 -03:00
fiatjaf 30e0e1040a use context passed to .Connect() for the live of the relay. 2023-03-30 18:26:43 -03:00
fiatjaf e84a7936d5 fix some concurrency things. 2023-03-29 14:55:52 -03:00
fiatjaf b0031bfd86 sdk.ParseReferences() 2023-03-27 08:47:59 -03:00
fiatjaf d3a1624880 ping every 29 seconds.
fixes https://github.com/nbd-wtf/go-nostr/issues/72
2023-03-25 14:59:38 -03:00
fiatjaf 35875e6071 replace vendored bech32 code with btcd library. 2023-03-23 16:59:46 -03:00