mirror of
https://github.com/aljazceru/hypergolic.git
synced 2026-01-19 13:24:26 +01:00
problem: no voting notification for merit request
solution: after voting, also send a kind 1 event
This commit is contained in:
@@ -1,8 +1,8 @@
|
||||
<script lang="ts">
|
||||
import * as Card from '$lib/components/ui/card/index.js';
|
||||
import { type MeritRequest } from '@/event_helpers/merits';
|
||||
import { prepareMeritNoteEvent, type MeritRequest } from '@/event_helpers/merits';
|
||||
import { ndk } from '@/ndk';
|
||||
import { NDKEvent, type NDKKind } from '@nostr-dev-kit/ndk';
|
||||
import { NDKKind } from '@nostr-dev-kit/ndk';
|
||||
import { Avatar, Name } from '@nostr-dev-kit/ndk-svelte-components';
|
||||
import { onDestroy } from 'svelte';
|
||||
|
||||
@@ -14,6 +14,7 @@
|
||||
import { currentUser } from '@/stores/session';
|
||||
import CornerDownLeft from 'lucide-svelte/icons/corner-down-left';
|
||||
import type NDKSvelte from '@nostr-dev-kit/ndk-svelte';
|
||||
|
||||
export let merit: MeritRequest;
|
||||
|
||||
let comments = $ndk.storeSubscribe({ kinds: [1 as NDKKind], '#e': [merit.ID] });
|
||||
@@ -28,18 +29,16 @@
|
||||
if (!ndk.signer) {
|
||||
throw new Error('no ndk signer found');
|
||||
}
|
||||
let e = new NDKEvent(ndk);
|
||||
let author = $currentUser;
|
||||
if (!author) {
|
||||
throw new Error('no current user');
|
||||
}
|
||||
e.author = author;
|
||||
e.kind = 1;
|
||||
e.created_at = Math.floor(new Date().getTime() / 1000);
|
||||
e.content = content;
|
||||
e.tags.push(['p', merit.Pubkey]);
|
||||
e.tags.push(['e', merit.ID, 'root', merit.Pubkey]);
|
||||
console.log(e.rawEvent());
|
||||
const e = prepareMeritNoteEvent({
|
||||
ndk,
|
||||
author,
|
||||
merit,
|
||||
content
|
||||
});
|
||||
e.publish().then((x) => {
|
||||
console.log(x);
|
||||
});
|
||||
|
||||
@@ -1,38 +1,55 @@
|
||||
<script lang="ts">
|
||||
import { Button } from '@/components/ui/button';
|
||||
import { MeritRequest } from '@/event_helpers/merits';
|
||||
import {
|
||||
MeritRequest,
|
||||
prepareMeritNoteEvent,
|
||||
prepareMeritVoteEvent,
|
||||
type VoteDirection
|
||||
} from '@/event_helpers/merits';
|
||||
import type { Rocket } from '@/event_helpers/rockets';
|
||||
import { ndk } from '@/ndk';
|
||||
import { currentUser } from '@/stores/session';
|
||||
import { NDKEvent } from '@nostr-dev-kit/ndk';
|
||||
import type NDKSvelte from '@nostr-dev-kit/ndk-svelte';
|
||||
import { Name } from '@nostr-dev-kit/ndk-svelte-components';
|
||||
import Login from './Login.svelte';
|
||||
|
||||
export let merit: MeritRequest;
|
||||
export let rocket: Rocket;
|
||||
|
||||
function publish(ndk: NDKSvelte, direction: string) {
|
||||
function publish(ndk: NDKSvelte, direction: VoteDirection) {
|
||||
if (!ndk.signer) {
|
||||
throw new Error('no ndk signer found');
|
||||
}
|
||||
let e = new NDKEvent(ndk);
|
||||
let author = $currentUser;
|
||||
if (!author) {
|
||||
throw new Error('no current user');
|
||||
}
|
||||
e.author = author;
|
||||
e.kind = 1410;
|
||||
e.created_at = Math.floor(new Date().getTime() / 1000);
|
||||
e.tags.push(['a', `31108:${rocket.Event.pubkey}:${rocket.Event.dTag}`]);
|
||||
e.tags.push(['request', merit.ID]);
|
||||
e.tags.push(['e', merit.ID]);
|
||||
e.tags.push(['p', merit.Pubkey]);
|
||||
e.tags.push(['vote', direction]);
|
||||
console.log(e.rawEvent());
|
||||
e.publish().then((x) => {
|
||||
console.log(x);
|
||||
});
|
||||
prepareMeritVoteEvent({
|
||||
ndk,
|
||||
author,
|
||||
rocket,
|
||||
merit,
|
||||
direction
|
||||
})
|
||||
.publish()
|
||||
.then((x) => {
|
||||
console.log(x);
|
||||
});
|
||||
let content;
|
||||
if (direction === 'ratify') {
|
||||
content = `I ratify your merit request: \n\n${merit.Problem()}`;
|
||||
} else {
|
||||
content = `I reject your merit request: \n\n${merit.Problem()}`;
|
||||
}
|
||||
prepareMeritNoteEvent({
|
||||
ndk,
|
||||
author,
|
||||
merit,
|
||||
content
|
||||
})
|
||||
.publish()
|
||||
.then((x) => {
|
||||
console.log(x);
|
||||
});
|
||||
}
|
||||
|
||||
$: currentUserHasVotepower = false;
|
||||
|
||||
@@ -1,5 +1,7 @@
|
||||
import type { NDKEvent, NDKFilter, NDKTag } from '@nostr-dev-kit/ndk';
|
||||
import { NDKEvent, NDKKind, type NDKFilter, type NDKTag, type NDKUser } from '@nostr-dev-kit/ndk';
|
||||
import { Rocket, getNumberFromTag, isValidUrl } from './rockets';
|
||||
import type NDKSvelte from '@nostr-dev-kit/ndk-svelte';
|
||||
import { prepareNostrEvent } from '@/helpers';
|
||||
|
||||
export class MeritRequest {
|
||||
ID: string;
|
||||
@@ -338,3 +340,42 @@ function pubkeyLatestVote(votes: Votes) {
|
||||
}
|
||||
return new Votes([...pMap.values()]);
|
||||
}
|
||||
|
||||
export function prepareMeritNoteEvent(args: {
|
||||
ndk: NDKSvelte;
|
||||
author: NDKUser;
|
||||
merit: MeritRequest;
|
||||
content: string;
|
||||
}) {
|
||||
const tags = [
|
||||
['p', args.merit.Pubkey],
|
||||
['e', args.merit.ID, 'root', args.merit.Pubkey]
|
||||
];
|
||||
return prepareNostrEvent({
|
||||
...args,
|
||||
kind: NDKKind.Text,
|
||||
tags
|
||||
});
|
||||
}
|
||||
|
||||
export function prepareMeritVoteEvent(args: {
|
||||
ndk: NDKSvelte;
|
||||
author: NDKUser;
|
||||
rocket: Rocket;
|
||||
merit: MeritRequest;
|
||||
direction: string;
|
||||
}) {
|
||||
const tags = [
|
||||
['a', `31108:${args.rocket.Event.pubkey}:${args.rocket.Event.dTag}`],
|
||||
['request', args.merit.ID],
|
||||
['e', args.merit.ID],
|
||||
['p', args.merit.Pubkey],
|
||||
['vote', args.direction]
|
||||
];
|
||||
return prepareNostrEvent({
|
||||
...args,
|
||||
kind: 1410 as NDKKind,
|
||||
tags,
|
||||
content: ''
|
||||
});
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { NDKEvent, NDKZap, type NDKTag } from '@nostr-dev-kit/ndk';
|
||||
import { NDKEvent, type NDKTag } from '@nostr-dev-kit/ndk';
|
||||
import { MapOfVotes, MeritRequest, Votes } from './merits';
|
||||
import { getAuthorizedZapper } from '@/helpers';
|
||||
|
||||
@@ -12,7 +12,7 @@ export class Rocket {
|
||||
for (let p of this.Event.getMatchingTags('product')) {
|
||||
_products.push(new RocketProduct(p));
|
||||
}
|
||||
return _products
|
||||
return _products;
|
||||
}
|
||||
VotePowerForPubkey(pubkey: string): number {
|
||||
let votepower = 0;
|
||||
@@ -338,7 +338,6 @@ export class ZapPurchase {
|
||||
return false;
|
||||
}
|
||||
Valid(rocket: NDKEvent): boolean {
|
||||
|
||||
//todo: validate zapper pubkey is from a LSP specified in rocket
|
||||
let valid = true;
|
||||
if (!this.ValidAmount(rocket)) {
|
||||
@@ -411,19 +410,21 @@ export function RocketATagFilter(rocket: NDKEvent): string {
|
||||
return `31108:${rocket.pubkey}:${rocket.dTag}`;
|
||||
}
|
||||
|
||||
export async function ValidateZapPublisher(rocket:NDKEvent, zap:NDKEvent):Promise<boolean> {
|
||||
return new Promise((resolve, reject)=>{
|
||||
getAuthorizedZapper(rocket).then(pubkey=>{
|
||||
if (pubkey == zap.pubkey) {
|
||||
resolve(true)
|
||||
} else {
|
||||
reject()
|
||||
}
|
||||
}).catch(reject)
|
||||
export async function ValidateZapPublisher(rocket: NDKEvent, zap: NDKEvent): Promise<boolean> {
|
||||
return new Promise((resolve, reject) => {
|
||||
getAuthorizedZapper(rocket)
|
||||
.then((pubkey) => {
|
||||
if (pubkey == zap.pubkey) {
|
||||
resolve(true);
|
||||
} else {
|
||||
reject();
|
||||
}
|
||||
})
|
||||
.catch(reject);
|
||||
// let z = new NDKZap({ ndk: rocket.ndk!, zappedEvent: rocket, zappedUser: rocket.author });
|
||||
// z.getZapEndpoint().then(x=>{
|
||||
// console.log(x)
|
||||
// resolve(true)
|
||||
// }).catch(()=>{reject(false)})
|
||||
})
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { NDKZap, type NDKEvent } from '@nostr-dev-kit/ndk';
|
||||
import { NDKZap, NDKEvent, type NDKKind, type NDKTag, type NDKUser } from '@nostr-dev-kit/ndk';
|
||||
import type NDKSvelte from '@nostr-dev-kit/ndk-svelte';
|
||||
|
||||
export function getRocketURL(e: NDKEvent): string {
|
||||
let ignitionID = undefined;
|
||||
@@ -152,12 +153,36 @@ export async function getAuthorizedZapper(rocket: NDKEvent): Promise<string> {
|
||||
if (url) {
|
||||
url = url.trim().replace('/callback', '');
|
||||
fetch(url).then((result) => {
|
||||
result.json().then((j) => {
|
||||
resolve(j.nostrPubkey);
|
||||
}).catch(reject);
|
||||
result
|
||||
.json()
|
||||
.then((j) => {
|
||||
resolve(j.nostrPubkey);
|
||||
})
|
||||
.catch(reject);
|
||||
});
|
||||
} else {(reject())}
|
||||
} else {
|
||||
reject();
|
||||
}
|
||||
})
|
||||
.catch(reject);
|
||||
});
|
||||
}
|
||||
|
||||
export function prepareNostrEvent(args: {
|
||||
ndk: NDKSvelte;
|
||||
author: NDKUser;
|
||||
kind: NDKKind;
|
||||
content: string;
|
||||
tags?: NDKTag[];
|
||||
}) {
|
||||
let e = new NDKEvent(args.ndk);
|
||||
e.author = args.author;
|
||||
e.kind = args.kind;
|
||||
e.created_at = Math.floor(new Date().getTime() / 1000);
|
||||
e.content = args.content;
|
||||
if (args.tags) {
|
||||
e.tags = args.tags;
|
||||
}
|
||||
console.log(e.rawEvent());
|
||||
return e;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user