nostril

A C cli tool for creating nostr events
git clone git://jb55.com/nostril
Log | Files | Refs | README

commit 098f639f4688ddf1337d18a4e9d626d2f43f62fc
parent 0c583e986837153352a00e0c185ddbe7ccc2b611
Author: William Casarin <jb55@jb55.com>
Date:   Thu, 28 Jul 2022 09:29:33 -0700

dm: allow kind override for encrypted content in other kinds

Signed-off-by: William Casarin <jb55@jb55.com>

Diffstat:
Mnostril.c | 7++++---
1 file changed, 4 insertions(+), 3 deletions(-)

diff --git a/nostril.c b/nostril.c @@ -556,7 +556,7 @@ static int mine_event(struct nostr_event *ev, int difficulty) } static int make_encrypted_dm(secp256k1_context *ctx, struct key *key, - struct nostr_event *ev, unsigned char nostr_pubkey[32]) + struct nostr_event *ev, unsigned char nostr_pubkey[32], int kind) { size_t inl = strlen(ev->content); int enclen = inl + 16; @@ -630,7 +630,7 @@ static int make_encrypted_dm(secp256k1_context *ctx, struct key *key, } ev->content = (const char*)cur.start; - ev->kind = 4; + ev->kind = kind; if (!hex_encode(nostr_pubkey, 32, (char*)cur.p, cur.end - cur.p)) return 0; @@ -683,7 +683,8 @@ int main(int argc, const char *argv[]) } if (args.flags & HAS_ENCRYPT) { - if (!make_encrypted_dm(ctx, &key, &ev, args.encrypt_to)) { + int kind = args.flags & HAS_KIND? args.kind : 4; + if (!make_encrypted_dm(ctx, &key, &ev, args.encrypt_to, kind)) { fprintf(stderr, "error making encrypted dm\n"); return 0; }