Merge pull request #286 from null-dev/master

Fix MMRCMS sources with non-root baseUrls being broken
This commit is contained in:
Carlos 2018-04-11 16:24:13 -04:00 committed by GitHub
commit 99f56610ed
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 55 additions and 32 deletions

View File

@ -5,8 +5,8 @@ ext {
appName = 'Tachiyomi: My Manga Reader CMS (Many sources)'
pkgNameSuffix = 'all.mmrcms'
extClass = '.MyMangaReaderCMSSources'
extVersionCode = 2
extVersionSuffix = 2
extVersionCode = 3
extVersionSuffix = 3
libVersion = '1.2'
}

File diff suppressed because one or more lines are too long

View File

@ -25,6 +25,7 @@ class MyMangaReaderCMSSource(override val lang: String,
private val tagMappings: List<Pair<String, String>>?) : HttpSource() {
private val jsonParser = JsonParser()
private val itemUrlPath = Uri.parse(itemUrl).pathSegments.first()
private val parsedBaseUrl = Uri.parse(baseUrl)
override fun popularMangaRequest(page: Int) = GET("$baseUrl/filterList?page=$page&sortBy=views&asc=false")
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request {
@ -51,7 +52,7 @@ class MyMangaReaderCMSSource(override val lang: String,
.map {
SManga.create().apply {
val segment = it["data"].string
setUrlWithoutDomain(itemUrl + segment)
url = getUrlWithoutBaseUrl(itemUrl + segment)
title = it["value"].string
// Guess thumbnails
@ -69,7 +70,7 @@ class MyMangaReaderCMSSource(override val lang: String,
return MangasPage(document.getElementsByClass("col-sm-6").map {
SManga.create().apply {
val urlElement = it.getElementsByClass("chart-title")
setUrlWithoutDomain(urlElement.attr("href"))
url = getUrlWithoutBaseUrl(urlElement.attr("href"))
title = urlElement.text().trim()
thumbnail_url = it.select(".media-left img").attr("src")
@ -81,6 +82,28 @@ class MyMangaReaderCMSSource(override val lang: String,
}, document.select(".pagination a[rel=next]").isNotEmpty())
}
private fun getUrlWithoutBaseUrl(newUrl: String): String {
val parsedNewUrl = Uri.parse(newUrl)
val newPathSegments = parsedNewUrl.pathSegments.toMutableList()
for(i in parsedBaseUrl.pathSegments) {
if(i.trim().equals(newPathSegments.first(), true)) {
newPathSegments.removeAt(0)
} else break
}
val builtUrl = parsedNewUrl.buildUpon().path("/")
newPathSegments.forEach { builtUrl.appendPath(it) }
var out = builtUrl.build().encodedPath
if (parsedNewUrl.encodedQuery != null)
out += "?" + parsedNewUrl.encodedQuery
if (parsedNewUrl.encodedFragment != null)
out += "#" + parsedNewUrl.encodedFragment
return out
}
override fun mangaDetailsParse(response:Response) = SManga.create().apply {
val document = response.asJsoup()
title = document.getElementsByClass("widget-title").text().trim()
@ -180,7 +203,7 @@ class MyMangaReaderCMSSource(override val lang: String,
val chapter = SChapter.create()
chapter.setUrlWithoutDomain(url)
chapter.url = getUrlWithoutBaseUrl(url)
chapter.name = titleWrapper.text()
// Parse date