issue-166-open-timestamps #220
@ -9,8 +9,8 @@ import {
|
|||||||
DocSignatureEvent,
|
DocSignatureEvent,
|
||||||
Meta,
|
Meta,
|
||||||
SignedEvent,
|
SignedEvent,
|
||||||
Timestamp,
|
OpenTimestamp,
|
||||||
TimestampUpgradeVerifyResponse
|
OpenTimestampUpgradeVerifyResponse
|
||||||
} from '../../types'
|
} from '../../types'
|
||||||
import {
|
import {
|
||||||
decryptArrayBuffer,
|
decryptArrayBuffer,
|
||||||
@ -43,7 +43,7 @@ import { saveAs } from 'file-saver'
|
|||||||
import { Container } from '../../components/Container'
|
import { Container } from '../../components/Container'
|
||||||
import { useSigitMeta } from '../../hooks/useSigitMeta.tsx'
|
import { useSigitMeta } from '../../hooks/useSigitMeta.tsx'
|
||||||
import { StickySideColumns } from '../../layouts/StickySideColumns.tsx'
|
import { StickySideColumns } from '../../layouts/StickySideColumns.tsx'
|
||||||
import { UsersDetails } from '../../components/UsersDetails.tsx/index.tsx'
|
import { UsersDetails } from '../../components/UsersDetails.tsx'
|
||||||
import FileList from '../../components/FileList'
|
import FileList from '../../components/FileList'
|
||||||
import { CurrentUserFile } from '../../types/file.ts'
|
import { CurrentUserFile } from '../../types/file.ts'
|
||||||
import { Mark } from '../../types/mark.ts'
|
import { Mark } from '../../types/mark.ts'
|
||||||
@ -57,11 +57,7 @@ import {
|
|||||||
faFile,
|
faFile,
|
||||||
faFileDownload
|
faFileDownload
|
||||||
} from '@fortawesome/free-solid-svg-icons'
|
} from '@fortawesome/free-solid-svg-icons'
|
||||||
import {
|
import { upgradeAndVerifyTimestamp } from '../../utils/opentimestamps.ts'
|
||||||
upgradeAndVerifyTimestamp,
|
|
||||||
upgradeTimestamps,
|
|
||||||
verifyTimestamps
|
|
||||||
} from '../../utils/opentimestamps.ts'
|
|
||||||
import _ from 'lodash'
|
import _ from 'lodash'
|
||||||
|
|
||||||
interface PdfViewProps {
|
interface PdfViewProps {
|
||||||
@ -207,7 +203,7 @@ export const VerifyPage = () => {
|
|||||||
}>({})
|
}>({})
|
||||||
|
|
||||||
const signTimestampEvent = async (signerContent: {
|
const signTimestampEvent = async (signerContent: {
|
||||||
timestamps: Timestamp[]
|
timestamps: OpenTimestamp[]
|
||||||
}): Promise<SignedEvent | null> => {
|
}): Promise<SignedEvent | null> => {
|
||||||
return await signEventForMetaFile(
|
return await signEventForMetaFile(
|
||||||
JSON.stringify(signerContent),
|
JSON.stringify(signerContent),
|
||||||
@ -224,37 +220,56 @@ export const VerifyPage = () => {
|
|||||||
}, [currentFileHashes, fileHashes, files])
|
}, [currentFileHashes, fileHashes, files])
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
console.log('timestamps: ', timestamps)
|
||||||
if (timestamps && timestamps.length > 0) {
|
if (timestamps && timestamps.length > 0) {
|
||||||
|
console.log(timestamps.every((t) => !!t.verification))
|
||||||
if (timestamps.every((t) => !!t.verification)) {
|
if (timestamps.every((t) => !!t.verification)) {
|
||||||
|
toast.success('All of your timestamps are fully verified on Bitcoin.')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
const upgradeT = async (timestamps: Timestamp[]) => {
|
const upgradeT = async (timestamps: OpenTimestamp[]) => {
|
||||||
|
try {
|
||||||
|
setLoadingSpinnerDesc('Upgrading and verifying your timestamps.')
|
||||||
const verifiedResults = await Promise.all(
|
const verifiedResults = await Promise.all(
|
||||||
timestamps.map(upgradeAndVerifyTimestamp)
|
timestamps.map(upgradeAndVerifyTimestamp)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if timestamp verification has been achieved for the first time.
|
||||||
|
* Note that the upgrade flag is separate from verification. It is possible for a timestamp
|
||||||
|
* to not be upgraded, but to be verified for the first time.
|
||||||
|
* @param upgradedTimestamp
|
||||||
|
* @param timestamps
|
||||||
|
*/
|
||||||
|
const isNewlyVerified = (
|
||||||
|
upgradedTimestamp: OpenTimestampUpgradeVerifyResponse,
|
||||||
|
timestamps: OpenTimestamp[]
|
||||||
|
) => {
|
||||||
|
if (!upgradedTimestamp.verified) return false
|
||||||
|
const oldT = timestamps.find(
|
||||||
|
(t) => t.nostrId === upgradedTimestamp.timestamp.nostrId
|
||||||
|
)
|
||||||
|
if (!oldT) return false
|
||||||
|
if (!oldT.verification && upgradedTimestamp.verified) return true
|
||||||
|
}
|
||||||
|
|
||||||
const upgradedTimestamps = verifiedResults
|
const upgradedTimestamps = verifiedResults
|
||||||
.filter((t) => t.upgraded || isNewlyVerified(t, timestamps))
|
.filter((t) => t.upgraded || isNewlyVerified(t, timestamps))
|
||||||
.map((t) => {
|
.map((t) => {
|
||||||
const timestamp = t.value
|
const timestamp = t.timestamp
|
||||||
if (t.verified) {
|
if (t.verified) {
|
||||||
timestamp.verification = t.verification
|
timestamp.verification = t.verification
|
||||||
}
|
}
|
||||||
return timestamp
|
return timestamp
|
||||||
})
|
})
|
||||||
|
|
||||||
const isNewlyVerified = (
|
if (upgradedTimestamps.length === 0) {
|
||||||
upgradedTimestamp: TimestampUpgradeVerifyResponse,
|
toast.success('No further timestamp upgrades found.')
|
||||||
timestamps: Timestamp[]
|
return
|
||||||
) => {
|
|
||||||
if (!upgradedTimestamp.verified) return false
|
|
||||||
const oldT = timestamps.find(
|
|
||||||
(t) => t.nostrId === upgradedTimestamp.value.nostrId
|
|
||||||
)
|
|
||||||
if (!oldT) return false
|
|
||||||
if (!oldT.verification && upgradedTimestamp.verified) return true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setLoadingSpinnerDesc('Signing a timestamp upgrade event.')
|
||||||
|
|
||||||
const signedEvent = await signTimestampEvent({
|
const signedEvent = await signTimestampEvent({
|
||||||
timestamps: upgradedTimestamps
|
timestamps: upgradedTimestamps
|
||||||
})
|
})
|
||||||
@ -298,8 +313,15 @@ export const VerifyPage = () => {
|
|||||||
|
|
||||||
await Promise.all(promises)
|
await Promise.all(promises)
|
||||||
|
|
||||||
setTimestamps(finalTimestamps)
|
toast.success('Timestamp updates have been sent successfully.')
|
||||||
|
|
||||||
setMeta(meta)
|
setMeta(meta)
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err)
|
||||||
|
toast.error(
|
||||||
|
'There was an error upgrading or verifying your timestamps!'
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
upgradeT(timestamps)
|
upgradeT(timestamps)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user