Skip to content

Commit

Permalink
Simplify the whole application
Browse files Browse the repository at this point in the history
 * Removed the use of database(s) and its dependencies.

 * Added new "AddonVault"-struct singleton that will hold the addons for easy
   access.

 * Added new "SystemVault"-struct singleton that will hold the system
   configuration for easy access

 * Added new config files for both system configurations and addons
   configuration - to be used instead of a database.

 * Moved away from using JSON to TOML - easier to read and understand for
   pesky commoners~
   Keep in mind that in TOML everything needs to be part of a "type",
   just having hanging values and then say, "read this as array of
   values" won't work.

 * Updated FUTURE.md with new goals and plans - the top section about
   the updater is urgent changes as the updater is not working as
   intended right now.
  • Loading branch information
HansenChristoffer committed Sep 8, 2024
1 parent a12fa73 commit a2a9467
Show file tree
Hide file tree
Showing 40 changed files with 805 additions and 1,453 deletions.
Empty file added .addonsconfig.toml
Empty file.
11 changes: 11 additions & 0 deletions .systemsconfig.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
[[config_elements]]
name = "extract.addon.path"
value = "/home/[YOUR_HOST_NAME_HERE]/Games/battlenet/drive_c/Program Files (x86)/World of Warcraft/_retail_/Interface/AddOns"

[[config_elements]]
name = "browser.download.dir"
value = "/home/[YOUR_HOST_NAME_HERE]/Downloads/goaddons_download"

[[config_elements]]
name = "docker.url"
value = "ws://localhost:9222"
15 changes: 15 additions & 0 deletions .useragentconfig.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
[[user_agent]]
id = "Win537"
value = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Safari/537.36"

[[user_agent]]
id = "Mac86"
value = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:86.0) Gecko/20100101 Firefox/86.0"

[[user_agent]]
id = "Win88"
value = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.705.50 Safari/537.36 Edg/88.0.705.50"

[[user_agent]]
id = "Mac605"
value = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_16_0) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15"
22 changes: 14 additions & 8 deletions FUTURE.md
Original file line number Diff line number Diff line change
@@ -1,17 +1,23 @@
# Future plans for GoAddons

## Tests
1. Some tests
2. aaaand some more test
3. and after that even more tests

## Make Docker dependency deprecated
1. Change from MySQL to a simple SQLite database that makes it easier to ship instead of requiring Docker.
2. Look into possibility of not requiring the Docker Chrome browser when downloading files.
## Fix the updater
1. *SOLVED* ~For some reason the downloaded files are owned by ROOT:ROOT. This is not OK, they should be owned by current OS user (perhaps configurable?)~
2. *SOLVED* ~Make it non-parallel - there is no need for concurrency, there is risk for website throttling/blocking us plus extracting is fast enough as is~
3. *SOLVED* ~Make the extracting more simple - anything in the download volume that ends with .zip should be extracted and ultimately removed~
4. Look into possibility of not requiring the Docker Chrome browser when downloading files - the fewer dependencies the better

## Refactoring and generic clean-up

1. Part of the clean-up and refactoring involves more restrict code styling and that is something that is coming!
*. Discuss the possibility of using formatters e.g. gofmt or perhaps Go linters?
2. Refactoring and making code easier to read and follow (the less jumping around the better)
3. Generic Clean-up and whatever that would entail!

## Config

1. Allow more configurations - perhaps look into some config lib that can help
2. *SOLVED* ~Look into possibly leaving JSON for the config and instead use YAML~

## Cli

1. Leave behind the current and basic CLI and look into uses something like ncurses or alternatives for it in Golang
12 changes: 6 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
# GoAddons

GoAddons is a command-line interface (CLI) application designed to enhance the World of Warcraft (WoW) experience by simplifying the management of game addons. Leveraging the power of a database, GoAddons facilitates the effortless discovery, update, and management of WoW addons.
GoAddons is a command-line interface (CLI) application designed to enhance the World of Warcraft (WoW) experience by simplifying the management of game addons. GoAddons facilitates the effortless update and management of WoW addons.

## Features

- **Addon Management**: Easily list, search, add, or remove WoW addons to customize your gaming setup.
- **Updater Menu**: ~~Automatically checks and~~ updates your addons to the latest versions, ensuring you have the latest features and fixes.
- **Updater Menu**: Updates your addons to the latest versions, ensuring you have the latest features and fixes.
- **About**: Learn more about GoAddons.

## Getting Started
Expand All @@ -22,12 +22,12 @@ cd GoAddons
2. **Docker containers**:

Make sure you have Docker/Docker-engine and Docker-compose installed on your system. You will need to edit the docker-compose.yml file to fit your system.
The "kaasufouji-extract-volume" device path needs to be your systems path to your addons directory. Finally, change any [YOUR_HOST_NAME_HERE] to your actual user's name.
The "goaddons-extract-volume" device path needs to be your systems path to your addons directory. Finally, change any [YOUR_HOST_NAME_HERE] to your actual user's name.

Now, run the following command:
Now, run the following script:

```bash
docker-compose up -d
./start_containers.sh
```

This command will pull the relevant Docker images, create volumes and create containers that GoAddons will need to use.
Expand Down Expand Up @@ -86,7 +86,7 @@ In the Addon Management menu, you can:

### Updater Menu

Start the updater ~~to check for~~ and apply updates to your addons.
Start the updater and apply updates to your addons.

### About

Expand Down
105 changes: 46 additions & 59 deletions cli/AddonManagement.go → cmp/cli/AddonManagement.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,38 +14,23 @@
package cli

import (
"encoding/json"
"fmt"
"goaddons/database"
"goaddons/models"
"goaddons/utils"
"github.com/BurntSushi/toml"
"goaddons/cmp/models"
"goaddons/cmp/utils"
"log"
"strconv"
)

func ListAllAddons() {
utils.ClearScreen()
fmt.Printf(" »»» All Addons «««\n\n")

addons, err := database.GetAllAddons(db)
addonsVault, err := models.GetAddonVaultInstance()
if err != nil {
log.Printf("cli.ListAllAddons :: Error while trying to get all addons -> %v\n", err)
return
}

if addons == nil || len(addons) == 0 {
return
log.Fatalf("Error initializing AddonVault: %v", err)
}

b, err := json.MarshalIndent(addons, "", " ")
if err != nil {
log.Printf("cli.ListAllAddons :: Failed to marshal -> %v\n", err)
return
}

if b != nil && utils.IsValidString(string(b)) {
fmt.Println(string(b))
}
addonsVault.PrintAddonVault()
}

func SearchForAddonByName() {
Expand All @@ -60,52 +45,55 @@ func SearchForAddonByName() {
}

// Search for and list addon, all by the argument 'name'
addons, err := database.GetAddonsByName(db, name)
addonsVault, err := models.GetAddonVaultInstance()
if err != nil {
log.Printf("cli.SearchForAddonByName :: Error while getting addon... -> %v\n", err)
return
log.Fatalf("Was unable to get instance of AddonVault")
}

if addons == nil || len(addons) == 0 {
if addonsVault.Length() == 0 {
return
}

b, err := json.MarshalIndent(addons, "", " ")
if err != nil {
log.Printf("cli.SearchForAddonByName :: Failed to marshal -> %v\n", err)
return
}
for _, addon := range addonsVault.Addons {
if addon.Name == name {
b, err := toml.Marshal(&models.AddonConfig{Elements: []models.Addon{addon}})
if err != nil {
log.Printf("Error marshalling addon to TOML: %v", err)
}

if b != nil && utils.IsValidString(string(b)) {
fmt.Println(string(b))
if b != nil && len(b) > 0 {
fmt.Println(string(b))
}
}
}
}

func AddNewAddon() {
const CALLER = "cli.AddNewAddon"
var addon models.Addon

fmt.Printf("\n »»» Insert new addon ««« \n\n Addon name:\n > ")
addon.Name = userInput("cli.AddNewAddon")

fmt.Printf("\n What is the extracted addon directory is called\n > ")
addon.Filename = userInput("cli.AddNewAddon")
addon.Name = userInput(CALLER)

fmt.Printf("\n Addon about URL\n > ")
addon.Url = userInput("cli.AddNewAddon")

fmt.Printf("\n Addon download URL\n > ")
addon.DownloadUrl = userInput("cli.AddNewAddon")
addon.Url = userInput(CALLER)

fmt.Printf("\n »»» New Addon ««« \n")
fmt.Printf(" Name: %s\n URL: %s\n", addon.Name, addon.Url)
fmt.Printf("\n Do you want to commit? [y/N]\n > ")
input := userInput("cli.AddNewAddon")
input := userInput(CALLER)

switch input {
case "Y", "y":
r, err := database.InsertAddon(db, addon)
addonsVault, err := models.GetAddonVaultInstance()
if err != nil {
log.Printf("cli.addNewAddon :: Failed to insert addon(s)! -> %v\n", err)
log.Fatalf("Error initializing AddonVault: %v", err)
}
fmt.Printf(" Inserted total of %d addon(s) into TanukiDB!\n", r)

if err := addonsVault.Append(&addon); err != nil {
log.Printf("Error appending addon to vault: %v", err)
return
}
fmt.Printf(" Successfully inserted addon(s)!")
case "N", "n":
fmt.Println(" Stopped insertion of new addon(s)!")
default:
Expand All @@ -116,30 +104,29 @@ func AddNewAddon() {
func RemoveAddon() {
utils.ClearScreen()

fmt.Printf("\n »»» Remove addon «««\n\n Addon ID\n > ")
id := userInput("cli.RemoveAddon")
fmt.Printf("\n »»» Remove addon «««\n\n Addon name\n > ")
name := userInput("cli.RemoveAddon")

if !utils.IsValidString(id) {
log.Printf("cli.RemoveAddon :: The 'ID' argument is not valid! -> [%s]\n", id)
return
}

idNum, err := strconv.Atoi(id)
if err != nil {
log.Printf("cli.RemoveAddon :: Error while trying to convert ID to its decimal equivalent! -> %v\n", err)
if !utils.IsValidString(name) {
log.Printf("cli.RemoveAddon :: The 'name' argument is not valid! -> [%s]\n", name)
return
}

fmt.Printf("\n Will try to remove addon with the name: %s\n", name)
fmt.Printf("\n Do you want to commit? [y/N]\n > ")
input := userInput("cli.RemoveAddon")

switch input {
case "Y", "y":
r, err := database.RemoveAddonByID(db, idNum)
addonsVault, err := models.GetAddonVaultInstance()
if err != nil {
log.Printf("cli.RemoveAddon :: Failed to remove addon(s)! -> %v\n", err)
log.Fatalf("Error initializing AddonVault: %v", err)
}
beenRemoved, err := addonsVault.Remove(name)
if beenRemoved {
fmt.Printf(" Successfully removed addon with name: %s", name)
} else {
fmt.Printf(" Failed to remove addon with name: %s -> %v\n", name, err)
}
fmt.Printf(" Removed total of %d addon(s) from TanukiDB!", r)
case "N", "n":
fmt.Println(" Stopped deletion of addon(s)!")
default:
Expand Down
31 changes: 6 additions & 25 deletions cli/core.go → cmp/cli/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,13 @@
package cli

import (
"database/sql"
"fmt"
"goaddons/database"
"goaddons/updater"
"goaddons/utils"
"log"
"goaddons/cmp/models"
"goaddons/cmp/updater"
"goaddons/cmp/utils"
"os"
)

const (
databasePath string = "./bin/acd.db"
)

var db *sql.DB

func StartCli() {
utils.ClearScreen()
fmt.Printf(`
Expand Down Expand Up @@ -62,7 +54,7 @@ func StartCli() {

func addonManagement() {
utils.ClearScreen()
initDatabase() // init database connection if it is not already initialized
_, _ = models.GetAddonVaultInstance()
fmt.Printf(`
»»» Addon Management «««
Expand Down Expand Up @@ -101,7 +93,7 @@ func addonManagement() {

func updaterMenu() {
utils.ClearScreen()
initDatabase() // init database connection if it is not already initialized
_, _ = models.GetAddonVaultInstance()
fmt.Printf(`
»»» Updater Menu «««
Expand All @@ -113,7 +105,7 @@ func updaterMenu() {
if len(input) > 0 {
switch input {
case "1":
updater.StartUpdater(db)
updater.StartUpdater()
case "X", "x":
StartCli()
default:
Expand Down Expand Up @@ -152,17 +144,6 @@ func about() {
StartCli()
}

// initDatabase initializes the global database connection.
func initDatabase() {
if db == nil {
var err error
db, err = database.ConnectToServer(databasePath)
if err != nil {
log.Fatalf("cli:core.initDatabase():ConnectToServer(%s) -> %v", databasePath, err)
}
}
}

func terminate() {
os.Exit(0)
}
19 changes: 14 additions & 5 deletions models/ELog.go → cmp/models/Addon.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,18 @@

package models

type ELog struct {
Id int
RunId string
File string
AddedAt []uint8
type AddonConfig struct {
Elements []Addon `toml:"addon"`
}

type Addon struct {
Name string `toml:"name"`
Url string `toml:"url"`
}

func (a *Addon) Validate() bool {
if len(a.Name) == 0 || len(a.Url) == 0 {
return false
}
return true
}
Loading

0 comments on commit a2a9467

Please sign in to comment.