
Security News
npm Tooling Bug Incorrectly Marks One-Character Packages as Security Holders
npm confirmed a tooling bug incorrectly marked several one-character packages as security holders and said it was working on a rollback.
@samual/types
Advanced tools
This package was split from `@samual/lib` to contain the types I regularly use.
@samual/typesThis package was split from @samual/lib to contain the types I regularly use.
import type {
AnyFunction, Async, Brand, Cloneable, Falsy, IntersectUnion, JsonValue, LaxPartial, NonFalsy, PickByValue, Rejecter,
Replace, Resolver, Slice1, ValueOf
} from "@samual/types"
// AnyFunction
let functions: AnyFunction[] = []
// Resolver and Rejecter
let resolver: Resolver<number>
let rejecter: Rejecter
let promiseWithResolvers = Promise.withResolvers<number>()
resolver = promiseWithResolvers.resolve
rejecter = promiseWithResolvers.reject
// Async
function myAsyncWrapper<T extends AnyFunction>(toWrap: T): Async<T> {
// ...
}
// JsonValue
let fooJson = JSON.stringify({ … } satisifes JsonValue)
let fooParsed = JSON.parse(fooJson) as JsonValue
// Cloneable
const clonedFoo = structuredClone(foo satisfies Cloneable)
worker.postMessage(foo satisfies Cloneable)
// LaxPartial
type FooOptions = {
bar: number
baz: string
}
export function foo(options: LaxPartial<FooOptions>) {
// ...
}
// Slice1
type Foo = Slice1<[ 1, 2, 3 ]>
// ^? type Foo = [ 2, 3 ]
// Falsy
type ConditionalFoo<T> = T extends Falsy ? DoOneThing : OtherwiseDoSomethingElse
// NonFalsy
type NonFalsyJsonValue = NonFalsy<JsonValue>
// IntersectUnion
type Foo = IntersectUnion<{ a: number } | { b: string }>
// ^? type Foo = { a: number, b: string }
// ValueOf
type Foo = ValueOf<{ a: 1, b: 2, c: 3 }>
// ^? type Foo = 1 | 2 | 3
type Bar = ValueOf<[ 1, 2, 3 ]>
// ^? type Bar = 1 | 2 | 3
// PickByValue
type Foo = PickByValue<{ a: 1, b: "2", c: 3, d: "4" }, number>
// ^? type Foo = { a: 1, c: 3 }
// Replace
type Foo = Replace<{ a: string, b: string }, { b: number }>
// ^? type Foo = { a: string, b: number }
// Brand
type CheckedString = Brand<string, { readonly CheckedString: unique symbol }[`CheckedString`]>
// ^? type CheckedString = string & { [CheckedString]: true }
FAQs
This package was split from `@samual/lib` to contain the types I regularly use.
The npm package @samual/types receives a total of 9 weekly downloads. As such, @samual/types popularity was classified as not popular.
We found that @samual/types demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
npm confirmed a tooling bug incorrectly marked several one-character packages as security holders and said it was working on a rollback.

Research
/Security News
Newer packages in this compromise use native extensions and .pth loaders to execute JavaScript stealers in developer environments.

Research
Socket found 37 malicious PyPI wheels that abuse Python startup hooks to launch a Bun-powered credential stealer tied to Mini Shai-Hulud/Miasma.