Skip to content

Commit

Permalink
Merge branch 'improve-errors' into 'main'
Browse files Browse the repository at this point in the history
Improve signer timeout errors

See merge request soapbox-pub/ditto!412
  • Loading branch information
alexgleason committed Jul 6, 2024
2 parents 155ca77 + 842adfd commit ed067e5
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 6 deletions.
5 changes: 5 additions & 0 deletions src/controllers/error.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
import { ErrorHandler } from '@hono/hono';
import { HTTPException } from '@hono/hono/http-exception';

export const errorHandler: ErrorHandler = (err, c) => {
if (err instanceof HTTPException) {
return c.json({ error: err.message }, err.status);
}

console.error(err);

if (err.message === 'canceling statement due to statement timeout') {
Expand Down
59 changes: 54 additions & 5 deletions src/signers/ConnectSigner.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// deno-lint-ignore-file require-await
import { HTTPException } from '@hono/hono/http-exception';
import { NConnectSigner, NostrEvent, NostrSigner } from '@nostrify/nostrify';

import { Storages } from '@/storages.ts';
Expand Down Expand Up @@ -27,30 +28,78 @@ export class ConnectSigner implements NostrSigner {

async signEvent(event: Omit<NostrEvent, 'id' | 'pubkey' | 'sig'>): Promise<NostrEvent> {
const signer = await this.signer;
return signer.signEvent(event);
try {
return await signer.signEvent(event);
} catch (e) {
if (e.name === 'AbortError') {
throw new HTTPException(408, { message: 'The event was not signed quickly enough' });
} else {
throw e;
}
}
}

readonly nip04 = {
encrypt: async (pubkey: string, plaintext: string): Promise<string> => {
const signer = await this.signer;
return signer.nip04.encrypt(pubkey, plaintext);
try {
return await signer.nip04.encrypt(pubkey, plaintext);
} catch (e) {
if (e.name === 'AbortError') {
throw new HTTPException(408, {
message: 'Text was not encrypted quickly enough',
});
} else {
throw e;
}
}
},

decrypt: async (pubkey: string, ciphertext: string): Promise<string> => {
const signer = await this.signer;
return signer.nip04.decrypt(pubkey, ciphertext);
try {
return await signer.nip04.decrypt(pubkey, ciphertext);
} catch (e) {
if (e.name === 'AbortError') {
throw new HTTPException(408, {
message: 'Text was not decrypted quickly enough',
});
} else {
throw e;
}
}
},
};

readonly nip44 = {
encrypt: async (pubkey: string, plaintext: string): Promise<string> => {
const signer = await this.signer;
return signer.nip44.encrypt(pubkey, plaintext);
try {
return await signer.nip44.encrypt(pubkey, plaintext);
} catch (e) {
if (e.name === 'AbortError') {
throw new HTTPException(408, {
message: 'Text was not encrypted quickly enough',
});
} else {
throw e;
}
}
},

decrypt: async (pubkey: string, ciphertext: string): Promise<string> => {
const signer = await this.signer;
return signer.nip44.decrypt(pubkey, ciphertext);
try {
return await signer.nip44.decrypt(pubkey, ciphertext);
} catch (e) {
if (e.name === 'AbortError') {
throw new HTTPException(408, {
message: 'Text was not decrypted quickly enough',
});
} else {
throw e;
}
}
},
};

Expand Down
2 changes: 1 addition & 1 deletion src/signers/ReadOnlySigner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ export class ReadOnlySigner implements NostrSigner {

async signEvent(): Promise<NostrEvent> {
throw new HTTPException(401, {
message: 'Log out and back in',
message: 'Log in with Nostr Connect to sign events',
});
}

Expand Down

0 comments on commit ed067e5

Please sign in to comment.