From 7996df85e1a7a1e33636500a6b65642581504885 Mon Sep 17 00:00:00 2001 From: Eng Zer Jun Date: Sat, 20 Nov 2021 14:42:50 +0800 Subject: [PATCH] refactor: move from io/ioutil to io and os packages (#1546) The io/ioutil package has been deprecated as of Go 1.16, see https://golang.org/doc/go1.16#ioutil. This commit replaces the existing io/ioutil functions with their new definitions in io and os packages. Signed-off-by: Eng Zer Jun --- controllers/admin/config.go | 4 ++-- controllers/emoji.go | 3 +-- controllers/logo.go | 4 ++-- core/data/data_test.go | 3 +-- core/streamState.go | 3 +-- core/transcoder/thumbnailGenerator.go | 12 ++++++++---- utils/backup.go | 3 +-- utils/utils.go | 5 ++--- yp/yp.go | 7 +++---- 9 files changed, 21 insertions(+), 23 deletions(-) diff --git a/controllers/admin/config.go b/controllers/admin/config.go index 55aa07554..7f4dcae3e 100644 --- a/controllers/admin/config.go +++ b/controllers/admin/config.go @@ -4,9 +4,9 @@ import ( "encoding/base64" "encoding/json" "fmt" - "io/ioutil" "net" "net/http" + "os" "path/filepath" "reflect" "strings" @@ -223,7 +223,7 @@ func SetLogo(w http.ResponseWriter, r *http.Request) { } imgPath := filepath.Join("data", "logo"+extension) - if err := ioutil.WriteFile(imgPath, bytes, 0600); err != nil { + if err := os.WriteFile(imgPath, bytes, 0600); err != nil { controllers.WriteSimpleResponse(w, false, err.Error()) return } diff --git a/controllers/emoji.go b/controllers/emoji.go index ff4d14f1e..b95e279dc 100644 --- a/controllers/emoji.go +++ b/controllers/emoji.go @@ -2,7 +2,6 @@ package controllers import ( "encoding/json" - "io/ioutil" "net/http" "os" "path" @@ -31,7 +30,7 @@ func getCustomEmojiList() []models.CustomEmoji { } if len(emojiCache) == 0 { - files, err := ioutil.ReadDir(fullPath) + files, err := os.ReadDir(fullPath) if err != nil { log.Errorln(err) return emojiCache diff --git a/controllers/logo.go b/controllers/logo.go index 1b72a738f..dd29fcee5 100644 --- a/controllers/logo.go +++ b/controllers/logo.go @@ -1,8 +1,8 @@ package controllers import ( - "io/ioutil" "net/http" + "os" "path/filepath" "strconv" @@ -94,5 +94,5 @@ func writeBytesAsImage(data []byte, contentType string, w http.ResponseWriter, c } func getImage(path string) ([]byte, error) { - return ioutil.ReadFile(path) // nolint + return os.ReadFile(path) // nolint } diff --git a/core/data/data_test.go b/core/data/data_test.go index 2210dd711..2a6dd14db 100644 --- a/core/data/data_test.go +++ b/core/data/data_test.go @@ -2,13 +2,12 @@ package data import ( "fmt" - "io/ioutil" "os" "testing" ) func TestMain(m *testing.M) { - dbFile, err := ioutil.TempFile(os.TempDir(), "owncast-test-db.db") + dbFile, err := os.CreateTemp(os.TempDir(), "owncast-test-db.db") if err != nil { panic(err) } diff --git a/core/streamState.go b/core/streamState.go index 33f2222a4..6f057f95d 100644 --- a/core/streamState.go +++ b/core/streamState.go @@ -4,7 +4,6 @@ import ( "bufio" "fmt" "io" - "io/ioutil" "os" "path/filepath" "time" @@ -88,7 +87,7 @@ func SetStreamAsDisconnected() { offlineFileData := static.GetOfflineSegment() offlineFilename := "offline.ts" - offlineTmpFile, err := ioutil.TempFile(os.TempDir(), offlineFilename) + offlineTmpFile, err := os.CreateTemp(os.TempDir(), offlineFilename) if err != nil { log.Errorln("unable to create temp file for offline video segment") } diff --git a/core/transcoder/thumbnailGenerator.go b/core/transcoder/thumbnailGenerator.go index e50c67fe8..ce1e01bfd 100644 --- a/core/transcoder/thumbnailGenerator.go +++ b/core/transcoder/thumbnailGenerator.go @@ -1,7 +1,6 @@ package transcoder import ( - "io/ioutil" "os" "os/exec" "path" @@ -54,15 +53,20 @@ func fireThumbnailGenerator(segmentPath string, variantIndex int) error { previewGifFile := path.Join(config.WebRoot, "preview.gif") framePath := path.Join(segmentPath, strconv.Itoa(variantIndex)) - files, err := ioutil.ReadDir(framePath) + files, err := os.ReadDir(framePath) if err != nil { return err } var modTime time.Time var names []string - for _, fi := range files { - if path.Ext(fi.Name()) != ".ts" { + for _, f := range files { + if path.Ext(f.Name()) != ".ts" { + continue + } + + fi, err := f.Info() + if err != nil { continue } diff --git a/utils/backup.go b/utils/backup.go index 4523afc2f..f960a7157 100644 --- a/utils/backup.go +++ b/utils/backup.go @@ -8,7 +8,6 @@ import ( "errors" "fmt" "io" - "io/ioutil" "os" "path/filepath" @@ -20,7 +19,7 @@ import ( func Restore(backupFile string, databaseFile string) error { log.Printf("Restoring database backup %s to %s", backupFile, databaseFile) - data, err := ioutil.ReadFile(backupFile) // nolint + data, err := os.ReadFile(backupFile) // nolint if err != nil { return fmt.Errorf("unable to read backup file %s", err) } diff --git a/utils/utils.go b/utils/utils.go index 0eef68fd5..26924caf3 100644 --- a/utils/utils.go +++ b/utils/utils.go @@ -4,7 +4,6 @@ import ( "bytes" "errors" "fmt" - "io/ioutil" "math/rand" "net/url" "os" @@ -52,12 +51,12 @@ func GetIndexFromFilePath(path string) string { // Copy copies the file to destination. func Copy(source, destination string) error { - input, err := ioutil.ReadFile(source) // nolint + input, err := os.ReadFile(source) // nolint if err != nil { return err } - return ioutil.WriteFile(destination, input, 0600) + return os.WriteFile(destination, input, 0600) } // Move moves the file to destination. diff --git a/yp/yp.go b/yp/yp.go index facc676b6..8fef3fee0 100644 --- a/yp/yp.go +++ b/yp/yp.go @@ -2,13 +2,12 @@ package yp import ( "bytes" - "io/ioutil" + "encoding/json" + "io" "net/http" "net/url" "time" - "encoding/json" - "github.com/owncast/owncast/config" "github.com/owncast/owncast/core/data" "github.com/owncast/owncast/models" @@ -107,7 +106,7 @@ func (yp *YP) ping() { } defer resp.Body.Close() - body, err := ioutil.ReadAll(resp.Body) + body, err := io.ReadAll(resp.Body) if err != nil { log.Errorln(err) }