* remove randomua from madara
* don't use page path for page=1
* add back `madara_load_more`
* cleanup i18n and filters
* load more in a new source
* move back the filters
not worth it
* fix build
* altname to i18n as well
* utf-8
* Revert "utf-8"
This reverts commit 1335bc1b478da54d3a5eb6333ac1a26e3ee2825b.
* utf-8
* autodetect load_more_request
* load genres in background
* make genre classes protected
remove unnecessary change
* fetch genres changes
* launchIO countviews
* don't explicitly optin
* cleanup some request overrides
* make `useLoadMoreRequest` enum to be able to disable autodection where necessary
* fix logic
bruh
* use state variables
* defer countViews in overrides as well
* lint
* select().first -> selectFirst
* `load_more` search as well
* detect in search as well
* remove slipped override
* move detection to the function
* remove fetchGenreFailed
* don't use GlobalScope
* tweak load_more_request parameters
* remove ancient connectTimeout/readTimeout
already present in the client provided by the app
* small cleanup
* remove chapter pagination
page parameter seems to trigger some cache issue in their api
* update baseUrl
* data class -> class
micro optimization
* small refactor
* remove useless interceptor
* oops
* mutable not needed
* NetTruyen/NhatTruyen: avoid return catalog page when searching return empty
They redirect back to catalog page if searching query is not found.
That makes both sites always return un-relevant results when searching should have returned empty.
* fix overrideVersion
* Update domain and other things
* Change popular endpoint
* fetchFilters in getFilterList
* Make SManga and SChapter in DTO
* I just want to update the domain
* Move attempts to finally block
* idk
* update
---------
Co-authored-by: stevenyomi <95685115+stevenyomi@users.noreply.github.com>
* Komga: Filter out EPUB books, fix chapter timestamps
* Add default library setting
* Make some settings not require a restart
* Don't use fixed enums
* Rename None sort to Relevance (#1284)
* make popular default to alphabetical sort
* Add Comikey
* Remove logging
* i18n
* Comikey Brasil, paid chapters toggle, use other chapter endpoint
* Don't parse author/artist in searchMangaFromElement
* makeEpisodeSlug private
* Move gundamUrl outside of class constructor
* paginate latest
* paginate search
* Properly distinguish i18n keys from normal messages in WebView script
* Parse statuses better
* Add genre for entry format
* remove unnecessary getChapterUrl
* Fix status on BR
* ACTUALLY fix status on BR
* Fix more Comikey Brasil stupidity
* Validate that manifestUrl is valid
* Revert "Validate that manifestUrl is valid"
This reverts commit d744fd42b45ae46baf48308ec3f354546d1452af.
* Proper i18n in WebView script
* Add explanation for weird binding
* Move helper functions to bottom
* Support signing in through WebView
* Fix chapter list when signed in
* Properly filter locked chapters
* Remove WebView logging
* maybe fix private fun conflict with ext-lib 1.5 interface methods
* add pages in description
* slight refactor
* bump
* make search default order same as site
some entries don't show up on popular sort
* Add PeachScan
* I love linting
* Also remove old WickedWitchScan
* It's not novo anymore
* Remove unneeded className declaration
* Filter light novel entries from latest view (because we can here)
* ACTUALLY filter light novel entries from latest view (because we can here)
* Fix icon path + add Dango Scan
* Move image-decoder dependency to multisrc project
* shut up android studio
* fix dep specifier in additional.gradle
* Update multisrc/overrides/peachscan/default/additional.gradle
Co-authored-by: stevenyomi <95685115+stevenyomi@users.noreply.github.com>
* Revert "Update multisrc/overrides/peachscan/default/additional.gradle"
This reverts commit 6b8722193a2181a8e9d8f6b65fb24afd30e5a548.
The comment serves as an explanation for why the dependency shouldn't
be in the Gradle version catalog; because no one else cares about this
dependency.
* Optimize icons
---------
Co-authored-by: stevenyomi <95685115+stevenyomi@users.noreply.github.com>
* Add BlogTruyen.vn (unoriginal)
* refactor a thing
* Add final newline
* Epic lint fail
* Move date format out of constructor arguments
* Remove manifest file in override
* Don't display genre list if empty
* Apply rate limit only to real BlogTruyen
* feat: Create Tsuki Mangás base
* feat: Implement popular manga page
* feat: Implement latest updates page
* feat: Implement search page
* feat: Implement manga details page
* fix: Fix URL intent handler
* fix: Fix webview url
* feat: Implement chapter list page
* feat: Implement page list
* fix: Fix chapter URLs
Kotlinx-serialization moment
* feat: Apply rate limit to image CDNs
* refactor: Make the API path a separate constant
* chore: Add source icon
... Actually they don't have a icon yet, they're just using the "TSUKI"
text, so I did the same in the icon. it may be updated later, when they
create a proper icon.
* fix: Fix random http 404 in pages
* fix: Prevent multiple wrong requests
* refactor: Apply suggestion - set custom interceptor before ratelimit
* Update Filter Parsing
Update filter parsing behavior from the okhttp cache to a mutableMap
* Bump User Agent Version
* Update pageListParse
Update pageListParse to select for "entry-content" only
* Remove Deprecated cloudflareClient
* Bump extVersionCode
* Revert "Remove Deprecated cloudflareClient"
This reverts commit c97c479dca056b6bdd432291910389579d9962c5.
* Wicked Witch Scan: Add new website
* use pt-BR locale for parsing dates
* fix: Use the original source name in ID calculation
* move new site to individual extension
* translate some more stuff
* remove import
* use parseBodyFragment
Co-authored-by: AwkwardPeak7 <48650614+AwkwardPeak7@users.noreply.github.com>
* chop down the forest
---------
Co-authored-by: AwkwardPeak7 <48650614+AwkwardPeak7@users.noreply.github.com>
* feat: Create SlimeRead base
* feat: Implement popular manga page
* feat: Implement latest manga page
* feat: Implement search manga page
* feat: Implement manga details page
* feat: Implement chapter list
* feat: Parse page list
* fix: Revert chapter list
* chore: Apply rate-limit in the source API
* chore: Add Origin header to API requests
* chore: Add source icon
* chore: Add isNsfw flag
* Added next page to all
Copied implementation from `Chapters` to all other extensions. New pages load when scrolling now
* Update DynastyDoujins.kt
Circumvent `IndexOutOfBoundsException` when section has no chapters
* Update build.gradle
* Moved functionality to base class
* Update DynastyDoujins.kt
Lazy implementation to load all chapters for `Dynasty Doujins`
* Update build.gradle
* Update src/en/dynasty/src/eu/kanade/tachiyomi/extension/en/dynasty/DynastyDoujins.kt
Co-authored-by: stevenyomi <95685115+stevenyomi@users.noreply.github.com>
* Fix exceeding max retry behavior
* Remove retry logic
* Update DynastyDoujins.kt
---------
Co-authored-by: stevenyomi <95685115+stevenyomi@users.noreply.github.com>
* create super mega extension
* change SUPER MEGA ext name
* fix build errors in SUPER MEGA extension
* reverse chapter order super mega ext
* revert settings.gradle.kts file
---------
Co-authored-by: az4521 <az4521@users.noreply.github.com>
* refactor(reportErrorToUser): enhance reportErrorToUser
* refactor(DataExtractor): add unexpectedErrorCatchingLazy
Makes it easier to quickly find and fix unexpected errors
* refactor(BookDetail): attempt at making BookDetail more extensible
Also fixes a rare bug that would throw a NoSuchElementException when the status or origin fields weren't found in the details table.
* refactor(mangaDetailsParse): refactor mangaDetailsParse to follow BookDetail's refactor
* chore(reportErrorToUser): Review reportErrorToUser messages
* refactor(Search): completely separate simple and smart search
create SmartBookSearchHandler as an attempt to speed up search by wasting less resources on unnecessary multiple normalization and reinitialization of resources via ThreadLocal
* chore(build): bumped extVersionCode to 3
* refactor(activities): Add activities to handle /book and /read URLs
Create a MangasPage with only a single Manga present (unfortunately needs to fetch manga details as title can't be inferred just by bookid)
Group activities in "activities" package for clarity
* fix(KDoc): fix Cannot resolve symbol
* chore: Update README and CHANGELOG
* chore: Add a bit of documentation to SmartBookSearchHandler
* feat: Handle /book and /read urls as search query
* chore(CHANGELOG): entries incorrectly listed as PUBLISHING_FINISHED now are correctly listed as COMPLETED
* chore(README): expanded README
* fix: Fix chapter list & prevent future trolling
* refactor: Minor refactoration for fun
* chore: Bump version
* fix: Prevent NPE in manga details
Didn't happen to me in my tests, but better be safe than sorry.
Thumbnails aren't really worth a (rare but possible?) NPE anyway
* fix: Add rate limit to prevent HTTP 429
* fix: Fix chapter list
* feat: Update search API
* refactor: Use URLs from constants
* refactor: Minor refactoration
* feat: Show more info in manga details page
* chore: Bump version
* fix: Apply suggestion - Use URL Builder in search
Thx alessandrojean!
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
---------
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* feat(src/en): Create Kiutaku base
* feat: Implement popular entries page
* feat: Implement latest updates page
* feat: Implement search
* feat: Implement entry details page
* feat: Implement chapter list page
* feat: Parse page list
* chore: Add source (fav)icon
The source doesn't seems to have a logo, so I'm considering the favicon used by
the site as their icon.
* Update build.gradle
remove jwt lib
* Update Picacomic.kt
Remove the effect of jwt library to fix the conflict from GSON
* Update Picacomic.kt
remove redundant code
* Update build.gradle
bump extension version
* Make it more prescriptive
* Improved compatibility with older versions
* 1.switch to android.util.Base64 API to improved compatibility with older versions
2.Convert the literal constant named leeway from a method parameter to a private member constant, this will improve performance a bit...
* build(gradle)!: Migrate ProjectSuki build.gradle to kotlin dsl
* feat: Add PathPattern
* feat: Add DataExtractor
* feat: Add ProjectSukiAPI
* feat: Add ProjectSukiFilters
* refactor!: migrate to new API and cleanup extension
Completely replace NormalizedURL with HttpUrl, remove PS.kt, PSBook.kt and PSFilters.kt
* chore(naming): rename pattern properties to be consistent
* refactor(preferences): Centralize and cleanup preferences
* chore(preferences): remove Android Preference import
* refactor(everything): Fix most of everything
Now apk builds, and correctly fetches books, chapters and images, including thumbnails.
* revert(gradle): revert to build.gradle.kts to be consistent with other extensions as context receivers are still unusable
* feat(url-activity): enhance
Needs to be tested, got distracted
* feat(preferences): Enhance preferences by providing more robust constructs
* feat(filters): Update and enhance filters
* feat(site-api): add search request data request and response parse
* refactor: replace require and error with reportErrorToUser in PathPattern
* refactor(core): Enhance everything
Now extension will show browse results on popular, main page on latest, will default to actually-useful search (with naive option on older devices) while still allowing old search.
Enhance user interaction by capturing or preventing almost all errors and alerting the user on what went wrong and what to do.
* chore: Suppress warnings
* docs: Document everything
Add documentation and revise pretty much everything.
* docs: Add CHANGELOG.md
* docs: Add README.md
* refactor(search-mode): Combine Naive/Full Site/Strict search options into single filter
* revert(manifest): Remove android:icon
it's set in the core AndroidManifest.xml
* chore(lang): switch extension language to "all"
explicitly set id: 8965918600406781666
* fix(preferences): fix blacklisted languages id
was the same as whitelisted
* fix: Fix bugs and more
Change Naive to Simple, provide more understandable description, make it possible to use Simple mode on any Android version if one wishes to do so.
Provide better regex for Simple search.
Test chapter filtering, download (single chapters and multiple), all searches, chapter view.
* docs: Update README and CHANGELOG
* refactor(url-activity): Refactor Url Activity from kotlin to java
Process kept complaining about java.lang.ClassNotFoundException: kotlin.jvm.internal.Intrinsics
* revert(url-activity): Avoid kotlin Intrinsics
* Finish migration to filters v2
* Implementation for smart filters
* Subtle cleanup
* Localization tests
* Fix 404 for latest update
* Filter out epubs
* Fixed Filter out epubs and optimization of 20 results per page
* Changelog and bump version
* Localization implementation
* Add localization keys
* Fix pub status not displaying. Closes#16318
Co-authored-by: FYannK <fanch.kerguelen@gmail.com>
* Hande exceptions and add version requirements
* Make fetch implementation with error handler.
Added/improved some comments
Added some more translation
* Update changelog
* Updated localization
---------
Co-authored-by: FYannK <fanch.kerguelen@gmail.com>
* Update YM to use their API directly.
* Skip a redirect in the popular manga list.
Co-authored-by: Vetle Ledaal <vetle.ledaal@gmail.com>
* Skip a redirect in the latest manga list.
Co-authored-by: Vetle Ledaal <vetle.ledaal@gmail.com>
---------
Co-authored-by: Vetle Ledaal <vetle.ledaal@gmail.com>
* MyReadingManga: Add WebP image support
Fix issue where manga published with webp images can not displayed correctly in Tachiyomi.
* MyReadingManga: Fix older release images does not parsed
* MyReadingManga: Bump version
* Add setting for Score positioning
Localization support for settings
* Simplify score position evaluation
Reformat code
* Include backup domain in Manifest
* Refine logic for picking the first volume cover
* Officially moved their main TLD
* Fallback to default value instead of empty string
* Avoid stray hyphen on chapter title if it has no name
* Fix typo and add explanation to README
Remove CHANGELOG
* Check and ignore empty string passed as Volume number
* Split Fansubs.cat into two sites (SFW and NSFW), update API calls, and implement search filters
* Unify Fansubs.cat and Fansubs.cat Hentai extensions into a single multisrc theme
* Add missing trailing comma
* Explicitly name custom argument
* Explicitly keep the pkgName for the main extension
* Remove unneeded workaround
* Add Score to the description
Add option to keep the first cover
* Check to prevent the extra call
* Swap from ★☆ to ●◐○ to make use of the half-symbol
Because the half-star character (⯪) is too new and doesn't show up properly
* Missing Override
* Back to the stars on rating.
No half-symbols but makes more sense and is consistent with the site's usage of the ⭐ star emoji
* format the code and change the throw exception
* fix nekopost search
* switch to HttpSource
use request/parse instead of fetch
* Remove commented code.
* update urls again
* small update to filters
* remove unnecessary function and add short title preference
short title stolen from Nhentai ext
* default off
* add magazine info to description
* add description from site
* unify popular and search parsing
* auto update cdn url
* projectsuki initial commit
* update preferences
* non-lazy client
* buildMap -> mapOf
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* inline constants
* switched from custom NormalizedURL to HttpUrl
* band-aid fix for "No results found"
Has edge case where current page has 30 results and next page has 0 results.
* update remote & strip debug Log statements
---------
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* Simplify Manifest data entries
* Map MD and MU tags to genres
* Switch separator for Ignored Groups setting
From comma to newlines for better readability
* Make MU Tags optional via preferences
Because they might contain spoilers.
- Include demographic \ target audience into genres
* Switch from flattening list to a builder
* Remove unneeded Listener
* Switch migration check to preference boolean
Rename muTags parameter to includeMuTags
* Rename a couple variables
More in line with their context
* New Source: One Piece Berwarna
* Filter attr by css selector
* Hardcode author & artist name
Co-Authored-By: Luqman <16263232+Riztard@users.noreply.github.com>
* Fix reversed chapter list
* Filter ads with css selector
Co-Authored-By: Luqman <16263232+Riztard@users.noreply.github.com>
* hardcode manga details
* Use the proper methods for chapter parsing
Co-Authored-By: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
---------
Co-authored-by: Riztard Lanthorn <riyanluqman@gmail.com>
Co-authored-by: Luqman <16263232+Riztard@users.noreply.github.com>
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* BacaKomik: fix title, tweak series info
- remove string from title
- add series type
- remove string from description
* title first
* fix pages not found & add some rate limit
Closes#18686
* fix spelling for villainess in en translations
* custom user agent + more md@h logging
adds a custom user agent setting primarily intended for testing
do note that spoofing to be a different browser might fetch you trouble
as MangaDex's new hotlink/bot abusers can kick in action
also add logging to figure out which MD@H node users are hitting
as currently, the fallback was not observed to be changing even after
a while; leading to user's keep failing to fetch images
* more improvements
make the `Extra` header more verbose
use a `customUserAgent` sharedpreferences variable so that code looks
cleaner
move the useragent logic into an interceptor so that there is no
need for restarting the app after every useragent change
* completely switch to useragent interceptor
removes builder header modification
remove additional logging while testing (didn't really work as
expected since I kept hitting uploads.mangadex.org anyhow,
+ the interceptor logs weren't useful otherwise)
switch to hardcoding version code in header since it wasn't working
as expected...
add linting from android studio gradle release build
* increment extVersionCode
* oopsie be careful of comments
* properly close unsuccessful requests to mdah node
need to ensure this so that it doesn't crash (which has happened before)
inb4 this is why the fallback url never works....
* [RU]Remanga filter only the last non-purchased chapters
* detect LICENSED when metadata not updated (when update library chapters)
* simplify not paid
* naver: fix author parsing
* simplify joinToString
* handle on hiatus status
* use when expression
* adjust order of checks for status
i have found a couple entries that have both rest and finished set to true.
those entires are all definitely on hiatus so let's give the rest flag prio
* Add support to URL guess and add harsh rate limit on GM.
* Fix the checks and add more paths.
* Remove the log statement.
* Use their current URL as of this moment.
---------
Co-authored-by: Alessandro Jean <alessandrojean@users.noreply.github.com>
* Add ComicFury Extension
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
* Change pt to pt-BR as per alessandrojean
Updated Request Builders as per alessandrojean
added fun getMangaUrl to point to the archive page instead of the detail page to help with nfsw comic requiring to click accept on the archive page to allow tachiyomi to read the chapter/comic list
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
* Use new siteLang as override for lang code for Manga Search as suggested by alessandrojean
Change notext lang to No-Text as commented by alessandrojean
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
* Change No-Text lang to other-notext as suggested by alessandrojean
now shows up as Other (NOTEXT)
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
* correct implementation misunderstanding and use extraName for the No text source, based on https://github.com/tachiyomiorg/tachiyomi-extensions/pull/6337
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
---------
Signed-off-by: Theray Tharow <TharowT@Tharow.net>
Co-authored-by: Theray Tharow <TharowT@Tharow.net>
* Add Collected Curios to Tachiyomi extensions.
Still to do:
* Add additional pages like Spider and Scorpion, Portfolio, etc.
* More refactoring.
* * Redone Icon in Android Asset Studio.
* Update src/en/collectedcurios/AndroidManifest.xml
Fixed AndroidManifest as in draft.
Co-authored-by: arkon <arkon@users.noreply.github.com>
* Update src/en/collectedcurios/build.gradle
extVersionCode 1 is enough.
Co-authored-by: arkon <arkon@users.noreply.github.com>
* Update Collectedcurios.kt
Addressed Arkons suggestions. Further refactoring needed.
* Update src/en/collectedcurios/build.gradle
* Shorten source to just itself.
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* Apply suggestions from code review
Accept all suggestions by alessandrojean.
* Exchange blank "date" for "Chapter".
* Remove date_upload as not needed.
* Restructure when condition in imageUrlParse.
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
---------
Co-authored-by: arkon <arkon@users.noreply.github.com>
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* AralosBD: Added support for latest, better support for search and popular, new icons
* AralosBD: used the right icon generator to follow the partern used by other extensions icons
* AralosBD: updated icon to use squared version
* Fixed ShingekiNoShoujo
Changed url
Fixed the code for the new site
* Changed build.gradle
* Fixed ShingekiNoShoujo
Modified the endpoints and the selectors because they modified the website
* Fixes to the code
* Deleted ShingekiNoShoujo.kt
Closes#17043
* increment extVersionCode
closes https://github.com/tachiyomiorg/tachiyomi-extensions/issues/17456
* add filtering to `list:`
* prefer using the constant instead
* revert to fallback url if MD@H node fails
* handle edge case in accessing list entries
mostly just to ensure the Retry message doesn't happen
* finish off TODO as manga redirects work fine nowadays
* linting
* add missing headers
this helps add the necessary tachiyomi ua and other stuff
* fix getMangaUrl
* Novelcool
very shit source
* use better selector to filter novels
* fix genre fetching in search
* add parsing logic for popular/latest as well
in case they break the app api
* HentaiVN: Support mobile site
* mobile: Parse title from cover alt before making a request
* mobile: Fix nextPageSelector
* Fix covers not loading in advanced search
* Add support to better internationalization with a new lib.
* Add info about `lib-i18n` in the contributing guide.
* Use lib-i18n in M+ as well.
* Change properties files to UTF-8.
* use the assets/ folder instead of the res/ folder
files under assets/ are addressible by name
* mangadex: add string invalid_manga_id
* M+: Add translations for Vietnamese
* m+: Add Vietnamese to list of available languages
* mangadex: remove duplicate declarations
---------
Co-authored-by: Alessandro Jean <14254807+alessandrojean@users.noreply.github.com>
* Update Japscan.kt
I completely changed the way to find the keys allowing the decryption of the base64 which contains the information of the images to be recovered. Before there was a recovery by regex, but this was not reliable because the location of these strings changes places and the order is important because it allows to reconstitute the two decryption keys. To succeed in recovering them correctly and in the right order, I debugged the javascript, which allowed me to understand how obfuscation works.
I understood that the base64 encryption file, the zjs, was not the same file when we had a mobile useragent and a PC useragent, it is however the same key, just that they are placed at different other place
at the end of the file we have the JS which assembles the keys directly as parameters of a function:
a0_0x39cacb('0x13d') + a0_0x39cacb('0x130') + a0_0x39cacb('0x118') + '6N', a0_0x39cacb('0x145') + a0_0x39cacb('0x116') + a0_0x39cacb('0x10f') + 'oe'
we have another function here:
return a0_0x46c1 = function(_0x46c1ab, _0x5a3fac) {
_0x46c1ab = _0x46c1ab - 0x105;
let _0x5c76b5 = _0xd80153[_0x46c1ab];
return _0x5c76b5;
}
which call string array which contains the key chunks
0 : "laretiLesrap"
1 : "gnp.600/sgmi/"
2 : "atad"
3 : "daol"
4 : "8ceABpX"
..
_0x46c1ab = _0x46c1ab - 0x105;
this operation allows to know the shift in the table, for example
By subtracting 0x105 from '0x13d', we get:
317 - 261 = 56
at location 56, so at index 55 of the array we have: "ohcVEMDTYO7FpBA20zRg"
so here: a0_0x39cacb('0x13d') + a0_0x39cacb('0x130') + a0_0x39cacb('0x118') + '6N'
we replace a0_0x39cacb('0x13d')
by this chain
"ohcVEMDTYO7FpBA20zRg" + a0_0x39cacb('0x130') + a0_0x39cacb('0x118') + '6N'
and that gives us the beginning of the key
and then reverse it
and that gives us the right key
* Update build.gradle
Update build version
* Update Japscan.kt - Completely reverse JavaScript
My modification was missing part of the javascript code to reverse, this modification brings greater stability.
In the JS is decrypts the data, there is a table of character string, this table is the most important element of the decryption because it is used in almost all the functions.
What the algorithm does in a nutshell:
- he shuffles the board until he arrives at a precise position, he pushes all the elements backwards until he finds the right combination. The correct combination is determined by the sum of the digits in the character strings with a more or less complex calculation.
- It calls the table in a "hidden" way with a function that takes a hexadecimal as a parameter (which corresponds to the index in the table)
- once all the keys have been retrieved from the character string table, it assembles them, then reverses them to give the complete key
How I proceeded:
- For the correct position in the table I perform almost the same calculation as the JS but I simplify, this to a tiny margin of error. In the calculation in the JS it parses the INTs in the chain and makes calculations with it, to simplify my task I only check if ALL the elements used contain INTs, I did several debug tests and they are obliged to contain them when the position is good. So starting from this principle I would almost certainly fall on the right position.
- Once my array is correctly sorted, I can with a simple calculation managed to recover the requested element with the hexadecimal
- I reverse the keys and I test the two positions of the keys to decipher the base64
* Update Japscan.kt
Added the possibility to have the parseInt in negative
* Update Japscan.kt
Modification needed to take into account the wider possibility of script changes
* Update Japscan.kt - Add comments
Ajout des commentaires