From d9c5154c5e1db9125bd31fc0fa3adaac010a498e Mon Sep 17 00:00:00 2001 From: Alex Freska Date: Thu, 12 Dec 2024 15:32:07 -0500 Subject: [PATCH] refactor(renterd): min account expiry and min price table validity units --- .changeset/rich-rats-try.md | 5 +++++ .changeset/spicy-dots-wait.md | 5 +++++ apps/renterd/contexts/config/transform.spec.ts | 8 ++++---- apps/renterd/contexts/config/transformDown.ts | 8 ++++---- apps/renterd/contexts/config/transformUp.ts | 6 ++++-- libs/units/src/time.ts | 10 +++++----- 6 files changed, 27 insertions(+), 15 deletions(-) create mode 100644 .changeset/rich-rats-try.md create mode 100644 .changeset/spicy-dots-wait.md diff --git a/.changeset/rich-rats-try.md b/.changeset/rich-rats-try.md new file mode 100644 index 000000000..9a48667c6 --- /dev/null +++ b/.changeset/rich-rats-try.md @@ -0,0 +1,5 @@ +--- +'renterd': minor +--- + +The min account expiry and min price table validity configuration settings are now stored in milliseconds. diff --git a/.changeset/spicy-dots-wait.md b/.changeset/spicy-dots-wait.md new file mode 100644 index 000000000..23a51ab0b --- /dev/null +++ b/.changeset/spicy-dots-wait.md @@ -0,0 +1,5 @@ +--- +'@siafoundation/units': minor +--- + +Add and remove time methods. diff --git a/apps/renterd/contexts/config/transform.spec.ts b/apps/renterd/contexts/config/transform.spec.ts index 82f04e310..d858bf3d8 100644 --- a/apps/renterd/contexts/config/transform.spec.ts +++ b/apps/renterd/contexts/config/transform.spec.ts @@ -270,9 +270,9 @@ describe('tansforms', () => { maxRPCPrice: '99970619000000000000000000', maxStoragePrice: '210531181019', maxUploadPrice: '1000232323000000', - minAccountExpiry: 86400000000000, + minAccountExpiry: 86400000, minMaxEphemeralAccountBalance: '1000000000000000000000000', - minPriceTableValidity: 300000000000, + minPriceTableValidity: 300000, }) }) }) @@ -503,9 +503,9 @@ function buildAllResponses() { maxRPCPrice: '99970619000000000000000000', maxStoragePrice: '210531181019', maxUploadPrice: '1000232323000000', - minAccountExpiry: 86400000000000, + minAccountExpiry: 86400000, minMaxEphemeralAccountBalance: '1000000000000000000000000', - minPriceTableValidity: 300000000000, + minPriceTableValidity: 300000, } as SettingsGouging, pinned: { currency: 'usd' as CurrencyId, diff --git a/apps/renterd/contexts/config/transformDown.ts b/apps/renterd/contexts/config/transformDown.ts index 421c2d6fe..435f3e045 100644 --- a/apps/renterd/contexts/config/transformDown.ts +++ b/apps/renterd/contexts/config/transformDown.ts @@ -8,8 +8,8 @@ import { import { blocksToWeeks, bytesToTB, - nanosecondsInDays, - nanosecondsInMinutes, + millisecondsInDays, + millisecondsInMinutes, toSiacoins, valuePerBytePerBlockToPerTBPerMonth, valuePerByteToPerTB, @@ -106,10 +106,10 @@ export function transformDownGouging({ ), hostBlockHeightLeeway: new BigNumber(gouging.hostBlockHeightLeeway), minPriceTableValidityMinutes: new BigNumber( - nanosecondsInMinutes(gouging.minPriceTableValidity) + millisecondsInMinutes(gouging.minPriceTableValidity) ), minAccountExpiryDays: new BigNumber( - nanosecondsInDays(gouging.minAccountExpiry) + millisecondsInDays(gouging.minAccountExpiry) ), minMaxEphemeralAccountBalance: toSiacoins( gouging.minMaxEphemeralAccountBalance, diff --git a/apps/renterd/contexts/config/transformUp.ts b/apps/renterd/contexts/config/transformUp.ts index 2b11b7a16..5d0610016 100644 --- a/apps/renterd/contexts/config/transformUp.ts +++ b/apps/renterd/contexts/config/transformUp.ts @@ -14,6 +14,8 @@ import { daysInNanoseconds, minutesInNanoseconds, valuePerTBToPerByte, + minutesInMilliseconds, + daysInMilliseconds, } from '@siafoundation/units' import { getAdvancedDefaultsAutopilot, @@ -102,10 +104,10 @@ export function transformUpGouging( maxContractPrice: toHastings(v.maxContractPrice).toString(), hostBlockHeightLeeway: Math.round(v.hostBlockHeightLeeway.toNumber() || 0), minPriceTableValidity: Math.round( - minutesInNanoseconds(v.minPriceTableValidityMinutes.toNumber() || 0) + minutesInMilliseconds(v.minPriceTableValidityMinutes.toNumber() || 0) ), minAccountExpiry: Math.round( - daysInNanoseconds(v.minAccountExpiryDays.toNumber()) + daysInMilliseconds(v.minAccountExpiryDays.toNumber()) ), minMaxEphemeralAccountBalance: toHastings( v.minMaxEphemeralAccountBalance diff --git a/libs/units/src/time.ts b/libs/units/src/time.ts index 4da525414..fda7fcc9c 100644 --- a/libs/units/src/time.ts +++ b/libs/units/src/time.ts @@ -30,16 +30,16 @@ export function nowInMilliseconds() { return new Date().getTime() } -export function nanosecondsInMinutes(ns: number) { - return ns / 1000 / 1000 / 1000 / 60 +export function millisecondsInMinutes(ms: number) { + return ms / 1000 / 60 } export function millisecondsInHours(ms: number) { - return ms / 1000 / 1000 / 60 / 60 + return ms / 1000 / 60 / 60 } -export function millisecondsInMinutes(ms: number) { - return ms / 1000 / 60 +export function millisecondsInDays(ms: number) { + return ms / 1000 / 60 / 60 / 24 } export function microsecondsInMinutes(us: number) {