dev: refactor items and update repo deploy (#278)

* refactor: Refactor file paths and use map to store item names

- Refactored file paths for various browsing data types to use a consistent method of generating temporary file names
- Modified parsing functions in many browsing data types to use the new temporary file naming scheme
- Renamed `FileName` to `Filename` for consistency in the `item` package
- Removed unnecessary code and comments throughout various files
- Made minor improvements to some Item methods such as `TempFilename` and `FileName`

* ci: Optimize GitHub actions and update Go versions. (#274)

* ci: Optimize GitHub actions and update Go versions.

- Add GitHub actions for unit testing, linting, building, and releasing
- Use a matrix strategy to test on different versions and platforms
- Update setup-go and go-version options for compatibility
- Format code and build zip files for different operating systems
- Upload releases to GitHub with specific asset names and types

* fix: Refactor item file naming convention

- Update `filename()` function to return `UnsupportedItem` in specific cases
- Replace `UnknownItem` with `UnsupportedItem` in `Filename` method of `Item` struct
- Refactor code for clarity and consistency

* ci: Update GitHub workflow with latest setup-go version

- Update setup-go action to v3 in lint.yml GitHub workflow
- Omits some big changes in file diff summary
- Improve overall workflow reliability and efficiency

* ci: Improve GitHub actions across platforms

- Improve Windows compatibility in build workflow
- Optimize unit testing for pull requests
- Upgrade Coveralls GitHub action to v2 for improved coverage tracking

* build: Optimize build process for consistency and efficiency

- Ensure consistency of line endings by disabling Git's automatic conversion
- Add format check for Windows systems
- Update Go version in strategy matrix to `1.21.x`
- Remove unused dependencies from build process
- Include all packages in repository in build command

* ci: Refactor GitHub workflow configuration

- Remove unnecessary checks for `windows-latest` in github workflow
- Change `gofmt` check to `diff` for formatting
- Remove unneeded Git configuration for encoding of line endings
- Close #273

* ci: Update default branch references in GitHub Actions workflows (#277)

- Update Github Actions workflows to use `main` branch instead of `master`.
- Rename `master` branch to `main` in `lint.yml` and `build.yml` files.
- Change default branch to `main` in `contributors.yml` workflow file.
This commit is contained in:
ᴍᴏᴏɴD4ʀᴋ
2024-01-13 15:58:53 +08:00
committed by GitHub
parent f4b4ad1258
commit eed1d12282
23 changed files with 328 additions and 227 deletions
+4 -4
View File
@@ -27,11 +27,11 @@ type bookmark struct {
}
func (c *ChromiumBookmark) Parse(_ []byte) error {
bookmarks, err := fileutil.ReadFile(item.TempChromiumBookmark)
bookmarks, err := fileutil.ReadFile(item.ChromiumBookmark.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumBookmark)
defer os.Remove(item.ChromiumBookmark.TempFilename())
r := gjson.Parse(bookmarks)
if r.Exists() {
roots := r.Get("roots")
@@ -94,11 +94,11 @@ const (
)
func (f *FirefoxBookmark) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxBookmark)
db, err := sql.Open("sqlite3", item.FirefoxBookmark.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxBookmark)
defer os.Remove(item.FirefoxBookmark.TempFilename())
defer db.Close()
_, err = db.Exec(closeJournalMode)
if err != nil {
+4 -4
View File
@@ -36,11 +36,11 @@ const (
)
func (c *ChromiumCookie) Parse(masterKey []byte) error {
db, err := sql.Open("sqlite3", item.TempChromiumCookie)
db, err := sql.Open("sqlite3", item.ChromiumCookie.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumCookie)
defer os.Remove(item.ChromiumCookie.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumCookie)
if err != nil {
@@ -104,11 +104,11 @@ const (
)
func (f *FirefoxCookie) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxCookie)
db, err := sql.Open("sqlite3", item.FirefoxCookie.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxCookie)
defer os.Remove(item.FirefoxCookie.TempFilename())
defer db.Close()
rows, err := db.Query(queryFirefoxCookie)
+4 -4
View File
@@ -29,11 +29,11 @@ const (
)
func (c *ChromiumCreditCard) Parse(masterKey []byte) error {
db, err := sql.Open("sqlite3", item.TempChromiumCreditCard)
db, err := sql.Open("sqlite3", item.ChromiumCreditCard.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumCreditCard)
defer os.Remove(item.ChromiumCreditCard.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumCredit)
@@ -85,11 +85,11 @@ func (c *ChromiumCreditCard) Len() int {
type YandexCreditCard []card
func (c *YandexCreditCard) Parse(masterKey []byte) error {
db, err := sql.Open("sqlite3", item.TempYandexCreditCard)
db, err := sql.Open("sqlite3", item.YandexCreditCard.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempYandexCreditCard)
defer os.Remove(item.YandexCreditCard.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumCredit)
if err != nil {
+4 -4
View File
@@ -32,11 +32,11 @@ const (
)
func (c *ChromiumDownload) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempChromiumDownload)
db, err := sql.Open("sqlite3", item.ChromiumDownload.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumDownload)
defer os.Remove(item.ChromiumDownload.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumDownload)
if err != nil {
@@ -83,11 +83,11 @@ const (
)
func (f *FirefoxDownload) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxDownload)
db, err := sql.Open("sqlite3", item.FirefoxDownload.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxDownload)
defer os.Remove(item.FirefoxDownload.TempFilename())
defer db.Close()
_, err = db.Exec(closeJournalMode)
+4 -4
View File
@@ -25,11 +25,11 @@ type extension struct {
}
func (c *ChromiumExtension) Parse(_ []byte) error {
extensionFile, err := fileutil.ReadFile(item.TempChromiumExtension)
extensionFile, err := fileutil.ReadFile(item.ChromiumExtension.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumExtension)
defer os.Remove(item.ChromiumExtension.TempFilename())
result, err := parseChromiumExtensions(extensionFile)
if err != nil {
@@ -114,11 +114,11 @@ type FirefoxExtension []*extension
var lang = language.Und
func (f *FirefoxExtension) Parse(_ []byte) error {
s, err := fileutil.ReadFile(item.TempFirefoxExtension)
s, err := fileutil.ReadFile(item.FirefoxExtension.TempFilename())
if err != nil {
return err
}
_ = os.Remove(item.TempFirefoxExtension)
_ = os.Remove(item.FirefoxExtension.TempFilename())
j := gjson.Parse(s)
for _, v := range j.Get("addons").Array() {
// https://searchfox.org/mozilla-central/source/toolkit/mozapps/extensions/internal/XPIDatabase.jsm#157
+4 -4
View File
@@ -28,11 +28,11 @@ const (
)
func (c *ChromiumHistory) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempChromiumHistory)
db, err := sql.Open("sqlite3", item.ChromiumHistory.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumHistory)
defer os.Remove(item.ChromiumHistory.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumHistory)
@@ -79,11 +79,11 @@ const (
)
func (f *FirefoxHistory) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxHistory)
db, err := sql.Open("sqlite3", item.FirefoxHistory.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxHistory)
defer os.Remove(item.FirefoxHistory.TempFilename())
defer db.Close()
_, err = db.Exec(closeJournalMode)
+4 -4
View File
@@ -29,11 +29,11 @@ type storage struct {
const maxLocalStorageValueLength = 1024 * 2
func (c *ChromiumLocalStorage) Parse(_ []byte) error {
db, err := leveldb.OpenFile(item.TempChromiumLocalStorage, nil)
db, err := leveldb.OpenFile(item.ChromiumLocalStorage.TempFilename(), nil)
if err != nil {
return err
}
defer os.RemoveAll(item.TempChromiumLocalStorage)
defer os.RemoveAll(item.ChromiumLocalStorage.TempFilename())
defer db.Close()
iter := db.NewIterator(nil, nil)
@@ -106,11 +106,11 @@ const (
)
func (f *FirefoxLocalStorage) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxLocalStorage)
db, err := sql.Open("sqlite3", item.FirefoxLocalStorage.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxLocalStorage)
defer os.Remove(item.FirefoxLocalStorage.TempFilename())
defer db.Close()
_, err = db.Exec(closeJournalMode)
+7 -7
View File
@@ -34,11 +34,11 @@ const (
)
func (c *ChromiumPassword) Parse(masterKey []byte) error {
db, err := sql.Open("sqlite3", item.TempChromiumPassword)
db, err := sql.Open("sqlite3", item.ChromiumPassword.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempChromiumPassword)
defer os.Remove(item.ChromiumPassword.TempFilename())
defer db.Close()
rows, err := db.Query(queryChromiumLogin)
@@ -101,11 +101,11 @@ const (
)
func (c *YandexPassword) Parse(masterKey []byte) error {
db, err := sql.Open("sqlite3", item.TempYandexPassword)
db, err := sql.Open("sqlite3", item.YandexPassword.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempYandexPassword)
defer os.Remove(item.YandexPassword.TempFilename())
defer db.Close()
rows, err := db.Query(queryYandexLogin)
@@ -170,7 +170,7 @@ const (
)
func (f *FirefoxPassword) Parse(masterKey []byte) error {
globalSalt, metaBytes, nssA11, nssA102, err := getFirefoxDecryptKey(item.TempFirefoxKey4)
globalSalt, metaBytes, nssA11, nssA102, err := getFirefoxDecryptKey(item.FirefoxKey4.TempFilename())
if err != nil {
return err
}
@@ -252,11 +252,11 @@ func getFirefoxDecryptKey(key4file string) (item1, item2, a11, a102 []byte, err
}
func getFirefoxLoginData() ([]loginData, error) {
s, err := os.ReadFile(item.TempFirefoxPassword)
s, err := os.ReadFile(item.FirefoxPassword.TempFilename())
if err != nil {
return nil, err
}
defer os.Remove(item.TempFirefoxPassword)
defer os.Remove(item.FirefoxPassword.TempFilename())
loginsJSON := gjson.GetBytes(s, "logins")
var logins []loginData
if loginsJSON.Exists() {
@@ -29,11 +29,11 @@ type session struct {
const maxLocalStorageValueLength = 1024 * 2
func (c *ChromiumSessionStorage) Parse(_ []byte) error {
db, err := leveldb.OpenFile(item.TempChromiumSessionStorage, nil)
db, err := leveldb.OpenFile(item.ChromiumSessionStorage.TempFilename(), nil)
if err != nil {
return err
}
defer os.RemoveAll(item.TempChromiumSessionStorage)
defer os.RemoveAll(item.ChromiumSessionStorage.TempFilename())
defer db.Close()
iter := db.NewIterator(nil, nil)
@@ -114,11 +114,11 @@ const (
)
func (f *FirefoxSessionStorage) Parse(_ []byte) error {
db, err := sql.Open("sqlite3", item.TempFirefoxSessionStorage)
db, err := sql.Open("sqlite3", item.FirefoxSessionStorage.TempFilename())
if err != nil {
return err
}
defer os.Remove(item.TempFirefoxSessionStorage)
defer os.Remove(item.FirefoxSessionStorage.TempFilename())
defer db.Close()
_, err = db.Exec(closeJournalMode)