
Research
/Security News
Critical Vulnerability in NestJS Devtools: Localhost RCE via Sandbox Escape
A flawed sandbox in @nestjs/devtools-integration lets attackers run code on your machine via CSRF, leading to full Remote Code Execution (RCE).
github.com/majiddarvishan/go-multimap
This is the missing multimap
collection for the Go language (also a simple practice in creating a proper library/package).
A multimap (sometimes also multihash or multidict) is a generalization of a map or associative array abstract data type in which more than one value may be associated with and returned for a given key.
Some use cases and examples for this data type includes:
There are two different multimap implementations, slicemultimap
and setmultimap
, which has slices and sets
as the map values respectively. slicemultimap
is useful when duplicate key/value pairs is allowed and
insertion ordering is important. On the other hand, setmultimap
is suitable when duplicates of key/value
pairs are not allowed.
This package was heavily inspired by the Google Guava interface of MultiMap and written in the style of the container package.
Install the package via the following:
go get -u github.com/jwangsadinata/go-multimap
The go-multimap package can be used similarly to the following:
// example/example.go
package main
import (
"fmt"
"github.com/jwangsadinata/go-multimap/slicemultimap"
)
func main() {
usPresidents := []struct {
firstName string
middleName string
lastName string
termStart int
termEnd int
}{
{"George", "", "Washington", 1789, 1797},
{"John", "", "Adams", 1797, 1801},
{"Thomas", "", "Jefferson", 1801, 1809},
{"James", "", "Madison", 1809, 1817},
{"James", "", "Monroe", 1817, 1825},
{"John", "Quincy", "Adams", 1825, 1829},
{"John", "", "Tyler", 1841, 1845},
{"James", "", "Polk", 1845, 1849},
{"Grover", "", "Cleveland", 1885, 1889},
{"Benjamin", "", "Harrison", 1889, 1893},
{"Grover", "", "Cleveland", 1893, 1897},
{"George", "Herbert Walker", "Bush", 1989, 1993},
{"George", "Walker", "Bush", 2001, 2009},
{"Barack", "Hussein", "Obama", 2009, 2017},
}
m := slicemultimap.New()
for _, president := range usPresidents {
m.Put(president.firstName, president.lastName)
}
for _, firstName := range m.KeySet() {
lastNames, _ := m.Get(firstName)
fmt.Printf("%v: %v\n", firstName, lastNames)
}
}
Example output:
$ go run example.go
George: [Washington Bush Bush]
John: [Adams Adams Tyler]
Thomas: [Jefferson]
James: [Madison Monroe Polk]
Grover: [Cleveland Cleveland]
Benjamin: [Harrison]
Barack: [Obama]
To see the benchmark, run the following on each of the sub-packages:
go test -run=NO_TEST -bench . -benchmem -benchtime 1s ./...
Please see the GoDoc API page for a
full API listing. For more examples, please consult example_test.go
file located in each subpackages.
FAQs
Unknown package
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.
Research
/Security News
A flawed sandbox in @nestjs/devtools-integration lets attackers run code on your machine via CSRF, leading to full Remote Code Execution (RCE).
Product
Customize license detection with Socket’s new license overlays: gain control, reduce noise, and handle edge cases with precision.
Product
Socket now supports Rust and Cargo, offering package search for all users and experimental SBOM generation for enterprise projects.