Skip to content

Commit

Permalink
fixes for comicextra and builds
Browse files Browse the repository at this point in the history
  • Loading branch information
Girbons committed Feb 22, 2024
1 parent 7944b34 commit 58f3bb1
Show file tree
Hide file tree
Showing 10 changed files with 60 additions and 71 deletions.
2 changes: 1 addition & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
language: go

go:
- 1.18
- 1.22

before_install:
- sudo apt-get update
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ windows-386-build: # Creates Windows
@GOOS=windows GOARCH=386 go build -o build/comics-downloader-win-386.exe ./cmd/downloader

linux-build: # Creates Linux
@GOOS=linux go build -o build/comics-downloader ./cmd/downloader
@GOOS=linux GOARDCH=amd64 go build -o build/comics-downloader-x86-64 ./cmd/downloader

linux-386-build:
@GOOS=linux GOARCH=386 go build -o build/comics-downloader-linux-386 ./cmd/downloader
Expand Down
4 changes: 2 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
module github.com/Girbons/comics-downloader

go 1.21.0
go 1.22.0

require (
fyne.io/fyne v1.4.3
Expand All @@ -13,7 +13,7 @@ require (
github.com/schollz/progressbar/v2 v2.15.0
github.com/sirupsen/logrus v1.9.3
github.com/stretchr/testify v1.8.4
golang.org/x/mod v0.14.0
golang.org/x/mod v0.15.0
golang.org/x/sync v0.6.0
)

Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@ golang.org/x/image v0.0.0-20190910094157-69e4b8554b2a/go.mod h1:FeLwcggjj3mMvU+o
golang.org/x/image v0.0.0-20200430140353-33d19683fad8 h1:6WW6V3x1P/jokJBpRQYUJnMHRP6isStQwCozxnU7XQw=
golang.org/x/image v0.0.0-20200430140353-33d19683fad8/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.14.0 h1:dGoOF9QVLYng8IHTm7BAyWqCqSheQ5pYWGhzW00YJr0=
golang.org/x/mod v0.14.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c=
golang.org/x/mod v0.15.0 h1:SernR4v+D55NyBH2QiEQrlBAnj1ECL6AGrA5+dPaMY8=
golang.org/x/mod v0.15.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c=
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
Expand Down
2 changes: 1 addition & 1 deletion internal/version/version.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import (

// Tag specifies the current release tag.
// It needs to be manually updated.
const Tag = "v0.33.8"
const Tag = "v0.33.9-alpha"

// IsNewAvailable will fetch the latest project releases
// and will compare the latest release Tag against the current Tag.
Expand Down
4 changes: 4 additions & 0 deletions pkg/core/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,10 @@ func (comic *Comic) makeCBRZ(options *config.Options) error {

// DownloadImages will download the comic/manga images
func (comic *Comic) DownloadImages(options *config.Options) (string, error) {
if len(comic.Links) == 0 {
return "", fmt.Errorf("Download failed, no links found for:", comic.URLSource)
}

var dir string
var err error

Expand Down
70 changes: 28 additions & 42 deletions pkg/sites/comicextra.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,73 +86,58 @@ func (c *Comicextra) retrieveLastIssue(url string) (string, error) {
func (c *Comicextra) RetrieveIssueLinks() ([]string, error) {
url := c.options.URL

splittedUrl := util.TrimAndSplitURL(url)

comicName := splittedUrl[3]

if c.options.Last {
issue, err := c.retrieveLastIssue(url)
return []string{issue}, err
}

// check if the user has submitted a generic url
if !strings.HasSuffix(url, "/issue") {
// enable `-all` flag in this case
c.options.Logger.Warning("URL does not contain a specific issue, `-all` flag will be automaticcaly enabled")
c.options.All = true
}

if c.options.All && c.isSingleIssue(url) {
url = "https://" + c.options.Source + "/comic" + util.TrimAndSplitURL(url)[3]
url = "https://" + c.options.Source + "/comic/" + comicName
} else if c.isSingleIssue(url) {

if !strings.HasSuffix(url, "/full") {
url = url + "/full"
}

return []string{url}, nil
}

// retrieve pages before

name := util.TrimAndSplitURL(url)[4]
var (
pages []string
links []string
elements []soup.Root
)

// do not handle pagination
// remove the page that comes within the url
parts := strings.Split(url, "/")
if len(parts) >= 6 {
url = parts[0] + "//" + parts[2] + "/" + parts[3] + "/" + parts[4]
}

// and start from 1
pages = append(pages, url+"/1")

response, err := soup.Get(url)
if err != nil {
return nil, err
}

doc := soup.HTMLParse(response)

pagesDiv := doc.Find("div", "class", "general-nav")
if pagesDiv.Pointer != nil {
elements = pagesDiv.FindAll("a")
episodeList := doc.Find("div", "class", "episode-list")
if episodeList.Pointer != nil {
elements = episodeList.FindAll("a")
}

for _, element := range elements {
pageURL := element.Attrs()["href"]
if !strings.Contains(pageURL, "onclick") && !util.IsValueInSlice(pageURL, pages) {
pages = append(pages, pageURL)
}
}

re := regexp.MustCompile("<a[^>]+href=\"([^\">]+" + "/" + name + "/.+)\"")

for _, pageURL := range pages {
response, err := soup.Get(pageURL)
if err != nil {
return nil, err
}

match := re.FindAllStringSubmatch(response, -1)

for i := range match {
url := match[i][1]
if !strings.Contains(url, "onclick") && !util.IsValueInSlice(url, pages) {
url = url + "/full"
if util.IsURLValid(url) && !util.IsValueInSlice(url, links) {
links = append(links, url)
}
if !strings.Contains(pageURL, "onclick") && !util.IsValueInSlice(pageURL, links) {
if !strings.HasSuffix(pageURL, "/full") {
pageURL = pageURL + "/full"
}

links = append(links, pageURL)
}
}

Expand All @@ -166,8 +151,9 @@ func (c *Comicextra) RetrieveIssueLinks() ([]string, error) {
// GetInfo extracts the basic info from the given url.
func (c *Comicextra) GetInfo(url string) (string, string) {
parts := util.TrimAndSplitURL(url)
name := parts[4]
issueNumber := parts[5]

name := parts[3]
issueNumber := parts[4]

return name, issueNumber
}
Expand Down
31 changes: 15 additions & 16 deletions pkg/sites/comicextra_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,11 @@ import (

func TestComicExtraSetup(t *testing.T) {
comic := new(core.Comic)
comic.URLSource = "https://comicextra.net/comic/batman-unseen/issue-5/full"
comic.URLSource = "https://comicextra.me/batman-unseen/issue-5/full"

opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen/issue-5",
URL: "https://comicextra.me/batman-unseen/issue-5/full",
All: false,
Last: false,
Debug: false,
Expand All @@ -32,15 +32,15 @@ func TestComicExtraSetup(t *testing.T) {
func TestComicExtraGetInfo(t *testing.T) {
opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen/issue-5",
URL: "https://comicextra.me/batman-unseen/issue-5/full",
All: false,
Last: false,
Debug: false,
Logger: logger.NewLogger(false, make(chan string)),
}

comicextra := NewComicextra(opt)
name, issueNumber := comicextra.GetInfo("https://comicextra.net/comic/batman-unseen/issue-5")
name, issueNumber := comicextra.GetInfo("https://comicextra.me/batman-unseen/issue-5/full")

assert.Equal(t, "batman-unseen", name)
assert.Equal(t, "issue-5", issueNumber)
Expand All @@ -49,7 +49,7 @@ func TestComicExtraGetInfo(t *testing.T) {
func TestComicextraRetrieveIssueLinks(t *testing.T) {
opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen/issue-5",
URL: "https://comicextra.me/batman-unseen/issue-5/full",
All: false,
Last: false,
Debug: false,
Expand All @@ -60,13 +60,13 @@ func TestComicextraRetrieveIssueLinks(t *testing.T) {
issues, err := comicextra.RetrieveIssueLinks()

assert.Nil(t, err)
assert.Equal(t, 5, len(issues))
assert.Equal(t, 1, len(issues))
}

func TestComicextraRetrieveIssueLinksURLWithPage(t *testing.T) {
opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen",
URL: "https://comicextra.me/batman-unseen/full",
All: false,
Last: false,
Debug: false,
Expand All @@ -77,13 +77,13 @@ func TestComicextraRetrieveIssueLinksURLWithPage(t *testing.T) {
issues, err := comicextra.RetrieveIssueLinks()

assert.Nil(t, err)
assert.Equal(t, 5, len(issues))
assert.Equal(t, 1, len(issues))
}

func TestComicextraRetrieveIssueLinksInASinglePage(t *testing.T) {
opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen/issue-4/full",
URL: "https://comicextra.me/batman-unseen/issue-4/full",
All: false,
Last: false,
Debug: false,
Expand All @@ -94,13 +94,13 @@ func TestComicextraRetrieveIssueLinksInASinglePage(t *testing.T) {
issues, err := comicextra.RetrieveIssueLinks()

assert.Nil(t, err)
assert.Equal(t, 5, len(issues))
assert.Equal(t, 1, len(issues))
}

func TestComicextraRetrieveIssueLinksLastChapter(t *testing.T) {
opt :=
&config.Options{
URL: "https://comicextra.net/comic/batman-unseen/issue-4/full",
URL: "https://comicextra.me/batman-unseen/issue-4/full",
All: false,
Last: true,
Debug: false,
Expand All @@ -116,17 +116,16 @@ func TestComicextraRetrieveIssueLinksLastChapter(t *testing.T) {

func TestComicExtraRetrieveLastIssueLink(t *testing.T) {
comicextra := new(Comicextra)
issue, err := comicextra.retrieveLastIssue("https://comicextra.net/comic/batman-unseen/issue-1/full")
issue, err := comicextra.retrieveLastIssue("https://comicextra.me/batman-unseen/issue-1/full")

assert.Nil(t, err)
assert.Equal(t, "https://comicextra.net/comic/batman-unseen/issue-5/full", issue)
assert.Equal(t, "https://comicextra.me/batman-unseen/issue-5/full", issue)
}

func TestComicExtraRetrieveLastIssueLinkNotDetail(t *testing.T) {
comicextra := new(Comicextra)
issue, err := comicextra.retrieveLastIssue("https://comicextra.net/comic/batman-unseen/issue-1/full")

issue, err := comicextra.retrieveLastIssue("https://comicextra.me/batman-unseen/issue-1/full")

assert.Nil(t, err)
assert.Equal(t, "https://comicextra.net/comic/batman-unseen/issue-5/full", issue)
assert.Equal(t, "https://comicextra.me/batman-unseen/issue-5/full", issue)
}
6 changes: 3 additions & 3 deletions pkg/sites/loader_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ func TestCustomComicName(t *testing.T) {
//}

func TestSiteLoaderComicExtra(t *testing.T) {
url := "https://comicextra.net/comic/batman-unseen/issue-5/full"
url := "https://comicextra.me/batman-unseen/issue-5/full"
outputFolder := filepath.Dir(os.Args[0])
options := &config.Options{
All: false,
Expand All @@ -114,7 +114,7 @@ func TestSiteLoaderComicExtra(t *testing.T) {
collection, err := LoadComicFromSource(options)

assert.Nil(t, err)
assert.Equal(t, 5, len(collection))
assert.Equal(t, 1, len(collection))

comic := collection[0]

Expand Down Expand Up @@ -149,7 +149,7 @@ func TestLoaderUnknownSource(t *testing.T) {
}

func TestIssuesRange(t *testing.T) {
url := "https://comicextra.net/comic/batman-unseen/issue-5/full"
url := "https://comicextra.net/batman-unseen/issue-5/full"
outputFolder := filepath.Dir(os.Args[0])
options := &config.Options{
All: true,
Expand Down
6 changes: 3 additions & 3 deletions pkg/sites/readcomiconline.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,9 +30,9 @@ func deobfuscateUrl(imageLink string) (string, error) {
imageLink = strings.Replace(imageLink, "_x236", "d", -1)
imageLink = strings.Replace(imageLink, "_x945", "g", -1)

if strings.HasPrefix(imageLink, "https://2.bp.blogspot.com") {
return imageLink, nil
}
if strings.HasPrefix(imageLink, "https://2.bp.blogspot.com") {
return imageLink, nil
}

var quality string

Expand Down

0 comments on commit 58f3bb1

Please sign in to comment.