
From golangci-lint: > SA1019: rand.Read has been deprecated since Go 1.20 because it >shouldn't be used: For almost all use cases, crypto/rand.Read is more >appropriate. (staticcheck) > SA1019: rand.Seed has been deprecated since Go 1.20 and an alternative >has been available since Go 1.0: Programs that call Seed and then expect >a specific sequence of results from the global random source (using >functions such as Int) can be broken when a dependency changes how >much it consumes from the global random source. To avoid such breakages, >programs that need a specific result sequence should use >NewRand(NewSource(seed)) to obtain a random generator that other >packages cannot access. (staticcheck) See also: - https://pkg.go.dev/math/rand@go1.20#Read - https://pkg.go.dev/math/rand@go1.20#Seed Signed-off-by: Akihiro Suda <akihiro.suda.cz@hco.ntt.co.jp>
46 lines
1.3 KiB
Go
46 lines
1.3 KiB
Go
/*
|
|
Copyright The containerd Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package main
|
|
|
|
import (
|
|
"crypto"
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/containerd/containerd/cmd/ctr/app"
|
|
"github.com/containerd/containerd/pkg/hasher"
|
|
"github.com/containerd/containerd/pkg/seed" //nolint:staticcheck // Global math/rand seed is deprecated, but still used by external dependencies
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
var pluginCmds = []cli.Command{}
|
|
|
|
func init() {
|
|
//nolint:staticcheck // Global math/rand seed is deprecated, but still used by external dependencies
|
|
seed.WithTimeAndRand()
|
|
crypto.RegisterHash(crypto.SHA256, hasher.NewSHA256)
|
|
}
|
|
|
|
func main() {
|
|
app := app.New()
|
|
app.Commands = append(app.Commands, pluginCmds...)
|
|
if err := app.Run(os.Args); err != nil {
|
|
fmt.Fprintf(os.Stderr, "ctr: %s\n", err)
|
|
os.Exit(1)
|
|
}
|
|
}
|