mirror of
https://github.com/moonD4rk/HackBrowserData.git
synced 2026-05-19 18:58:03 +02:00
eed1d12282
* 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.
178 lines
4.5 KiB
Go
178 lines
4.5 KiB
Go
package extension
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/tidwall/gjson"
|
|
"golang.org/x/text/language"
|
|
|
|
"github.com/moond4rk/hackbrowserdata/item"
|
|
"github.com/moond4rk/hackbrowserdata/utils/fileutil"
|
|
)
|
|
|
|
type ChromiumExtension []*extension
|
|
|
|
type extension struct {
|
|
ID string
|
|
URL string
|
|
Enabled bool
|
|
Name string
|
|
Description string
|
|
Version string
|
|
HomepageURL string
|
|
}
|
|
|
|
func (c *ChromiumExtension) Parse(_ []byte) error {
|
|
extensionFile, err := fileutil.ReadFile(item.ChromiumExtension.TempFilename())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer os.Remove(item.ChromiumExtension.TempFilename())
|
|
|
|
result, err := parseChromiumExtensions(extensionFile)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
*c = result
|
|
return nil
|
|
}
|
|
|
|
func parseChromiumExtensions(content string) ([]*extension, error) {
|
|
settingKeys := []string{
|
|
"settings.extensions",
|
|
"settings.settings",
|
|
"extensions.settings",
|
|
}
|
|
var settings gjson.Result
|
|
for _, key := range settingKeys {
|
|
settings = gjson.Parse(content).Get(key)
|
|
if settings.Exists() {
|
|
break
|
|
}
|
|
}
|
|
if !settings.Exists() {
|
|
return nil, fmt.Errorf("cannot find extensions in settings")
|
|
}
|
|
var c []*extension
|
|
|
|
settings.ForEach(func(id, ext gjson.Result) bool {
|
|
location := ext.Get("location")
|
|
if !location.Exists() {
|
|
return true
|
|
}
|
|
switch location.Int() {
|
|
case 5, 10: // https://source.chromium.org/chromium/chromium/src/+/main:extensions/common/mojom/manifest.mojom
|
|
return true
|
|
}
|
|
// https://source.chromium.org/chromium/chromium/src/+/main:extensions/browser/disable_reason.h
|
|
enabled := !ext.Get("disable_reasons").Exists()
|
|
b := ext.Get("manifest")
|
|
if !b.Exists() {
|
|
c = append(c, &extension{
|
|
ID: id.String(),
|
|
Enabled: enabled,
|
|
Name: ext.Get("path").String(),
|
|
})
|
|
return true
|
|
}
|
|
c = append(c, &extension{
|
|
ID: id.String(),
|
|
URL: getChromiumExtURL(id.String(), b.Get("update_url").String()),
|
|
Enabled: enabled,
|
|
Name: b.Get("name").String(),
|
|
Description: b.Get("description").String(),
|
|
Version: b.Get("version").String(),
|
|
HomepageURL: b.Get("homepage_url").String(),
|
|
})
|
|
return true
|
|
})
|
|
|
|
return c, nil
|
|
}
|
|
|
|
func getChromiumExtURL(id, updateURL string) string {
|
|
if strings.HasSuffix(updateURL, "clients2.google.com/service/update2/crx") {
|
|
return "https://chrome.google.com/webstore/detail/" + id
|
|
} else if strings.HasSuffix(updateURL, "edge.microsoft.com/extensionwebstorebase/v1/crx") {
|
|
return "https://microsoftedge.microsoft.com/addons/detail/" + id
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (c *ChromiumExtension) Name() string {
|
|
return "extension"
|
|
}
|
|
|
|
func (c *ChromiumExtension) Len() int {
|
|
return len(*c)
|
|
}
|
|
|
|
type FirefoxExtension []*extension
|
|
|
|
var lang = language.Und
|
|
|
|
func (f *FirefoxExtension) Parse(_ []byte) error {
|
|
s, err := fileutil.ReadFile(item.FirefoxExtension.TempFilename())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
_ = 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
|
|
if v.Get("location").String() != "app-profile" {
|
|
continue
|
|
}
|
|
|
|
if lang != language.Und {
|
|
locale := findFirefoxLocale(v.Get("locales").Array(), lang)
|
|
*f = append(*f, &extension{
|
|
ID: v.Get("id").String(),
|
|
Enabled: v.Get("active").Bool(),
|
|
Name: locale.Get("name").String(),
|
|
Description: locale.Get("description").String(),
|
|
Version: v.Get("version").String(),
|
|
HomepageURL: locale.Get("homepageURL").String(),
|
|
})
|
|
continue
|
|
}
|
|
|
|
*f = append(*f, &extension{
|
|
ID: v.Get("id").String(),
|
|
Enabled: v.Get("active").Bool(),
|
|
Name: v.Get("defaultLocale.name").String(),
|
|
Description: v.Get("defaultLocale.description").String(),
|
|
Version: v.Get("version").String(),
|
|
HomepageURL: v.Get("defaultLocale.homepageURL").String(),
|
|
})
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func findFirefoxLocale(locales []gjson.Result, targetLang language.Tag) gjson.Result {
|
|
tags := make([]language.Tag, 0, len(locales))
|
|
indices := make([]int, 0, len(locales))
|
|
for i, locale := range locales {
|
|
for _, tagStr := range locale.Get("locales").Array() {
|
|
tag, _ := language.Parse(tagStr.String())
|
|
if tag == language.Und {
|
|
continue
|
|
}
|
|
tags = append(tags, tag)
|
|
indices = append(indices, i)
|
|
}
|
|
}
|
|
_, tagIndex, _ := language.NewMatcher(tags).Match(targetLang)
|
|
return locales[indices[tagIndex]]
|
|
}
|
|
|
|
func (f *FirefoxExtension) Name() string {
|
|
return "extension"
|
|
}
|
|
|
|
func (f *FirefoxExtension) Len() int {
|
|
return len(*f)
|
|
}
|