feat: Utils to do bindLan and have ipv4 and ipv6 if need be

This commit is contained in:
BluJ
2023-04-27 11:22:42 -06:00
parent 353692bf55
commit c7d38fc7ce
79 changed files with 1754 additions and 1744 deletions

View File

@@ -1,4 +1,4 @@
export type TriggerInput = {
lastResult?: "success" | "failure" | null;
hadSuccess?: boolean;
};
lastResult?: "success" | "failure" | null
hadSuccess?: boolean
}

View File

@@ -1,31 +1,31 @@
import { TriggerInput } from "./TriggerInput";
import { Trigger } from "./index";
import { TriggerInput } from "./TriggerInput"
import { Trigger } from "./index"
export function changeOnFirstSuccess(o: {
beforeFirstSuccess: Trigger;
afterFirstSuccess: Trigger;
beforeFirstSuccess: Trigger
afterFirstSuccess: Trigger
}): Trigger {
return async function* (getInput) {
const beforeFirstSuccess = o.beforeFirstSuccess(getInput);
yield;
let currentValue = getInput();
beforeFirstSuccess.next();
const beforeFirstSuccess = o.beforeFirstSuccess(getInput)
yield
let currentValue = getInput()
beforeFirstSuccess.next()
for (
let res = await beforeFirstSuccess.next();
currentValue?.lastResult !== "success" && !res.done;
res = await beforeFirstSuccess.next()
) {
yield;
currentValue = getInput();
yield
currentValue = getInput()
}
const afterFirstSuccess = o.afterFirstSuccess(getInput);
const afterFirstSuccess = o.afterFirstSuccess(getInput)
for (
let res = await afterFirstSuccess.next();
!res.done;
res = await afterFirstSuccess.next()
) {
yield;
currentValue = getInput();
yield
currentValue = getInput()
}
};
}
}

View File

@@ -1,8 +1,8 @@
export function cooldownTrigger(timeMs: number) {
return async function* () {
while (true) {
await new Promise((resolve) => setTimeout(resolve, timeMs));
yield;
await new Promise((resolve) => setTimeout(resolve, timeMs))
yield
}
};
}
}

View File

@@ -1,7 +1,7 @@
import { cooldownTrigger } from "./cooldownTrigger";
import { changeOnFirstSuccess } from "./changeOnFirstSuccess";
import { cooldownTrigger } from "./cooldownTrigger"
import { changeOnFirstSuccess } from "./changeOnFirstSuccess"
export const defaultTrigger = changeOnFirstSuccess({
beforeFirstSuccess: cooldownTrigger(0),
afterFirstSuccess: cooldownTrigger(30000),
});
})

View File

@@ -1,7 +1,7 @@
import { TriggerInput } from "./TriggerInput";
export { changeOnFirstSuccess } from "./changeOnFirstSuccess";
export { cooldownTrigger } from "./cooldownTrigger";
import { TriggerInput } from "./TriggerInput"
export { changeOnFirstSuccess } from "./changeOnFirstSuccess"
export { cooldownTrigger } from "./cooldownTrigger"
export type Trigger = (
getInput: () => TriggerInput,
) => AsyncIterator<unknown, unknown, never>;
) => AsyncIterator<unknown, unknown, never>