Bulk uploads folders and archives (.zip/.cbz) to MangaDex in a quick and easy way.
Read this in other languages:
Português (Brasil)
Español (LATAM)
Français
Euskara
Tiếng Việt
There will be a release for each language, with English included in each one. To download all the languages, download the source files zip.
Download the latest version from the releases page.
Extract the archive to a folder, and open a new terminal window. On the terminal, navigate to the folder created using cd "<path_to_folder>"
.
Before running the uploader, you will need to install the required modules.
To install the modules, run the command pip install -r requirements.txt
, use pip3
if on mac or linux instead of pip
.
In the folder you extracted the archive to, create the to_upload
and uploaded
folders.
To run the uploader, in the terminal window, use python mupl.py
to start the uploader. Use python3
instead if on mac or linux.
The updater will automatically check at the start of the program if there is a new version available on the releases page. If there is a new version, it will prompt you to update.
If you want to disable the updater, you can add the --update
flag to the command line arguments. For example: python mupl.py --update
.
There are command line arguments that can be added after the main command to change the behaviour of the program, for example: python mupl.py -t
.
--update
-u
Don't check for a new update at the start of the program.--verbose
-v
Make the command line messages and logs more verbose.--threaded
-t
Run the threaded uploader. Default: False--combine
-c
Combine images that are smaller than or equal to 128px with the previous image. Default: False
manga_title [lang] - cXXX (vYY) (chapter_title) {publish_date} [group]
manga_title
Manga title (same as the key inname_id_map.json
) or the MangaDex ID.[lang]
Language code in the ISO format. Omitted for English.cXXX
Chapter number. Omit the chapter prefix if the chapter is a oneshot, e.g.cXXX
>XXX
.(vYY)
Chapter volume. Optional.(chapter_title)
Chapter title. See Chapter title replacement characters for special characters. Optional.{publish_date}
Future date of when chapter is released from MangaDex's side. MUST be in the formatYYYY-MM-DDTHH-MM-SS
if included. Optional.[group]
List of group names or IDs. If group names, they must be included in thename_id_map.json
for the IDs. Separate multiple groups using+
. Optional.
{asterisk}
*
{asterisk}
will be replaced with*
during the upload process.{backslash}
\
{backslash}
will be replaced with\
during the upload process.{slash}
/
{slash}
will be replaced with/
during the upload process.{colon}
:
{colon}
will be replaced with:
during the upload process.{greater_than}
>
{greater_than}
will be replaced with>
during the upload process.{less_than}
<
{less_than}
will be replaced with<
during the upload process.{question_mark}
?
{question_mark}
will be replaced with?
during the upload process.{quote}
"
{quote}
will be replaced with"
during the upload process.{pipe}
|
{pipe}
will be replaced with|
during the upload process.
png
jpg
/jpeg
gif
webp
Will be converted to eitherpng
,jpg
, orgif
during the upload process. This will not change the local file.
Images cannot exceed 10000px
in width or height. To split the image into smaller chunks, the manga id must be in the longstrip or widestrip array in the manga id map, as shown below.
If the id is missing, the image will not be split and WILL be skipped.
If the --combine
flag is used, images smaller than or equal to 128px
will be combined with the previous image IF they are the same width or height as the previous image. (Depends on if the image is a longstrip or widestrip.)
If the flag is not used or the images are not the same width or height as the previous image, the image *WILL be skipped.
User changeable settings are available in the config.json
file. This is also where you put your MangaDex credentials.
Copy and remove the .example
from config.json.example
to start using the config file.
Note: JSON values cannot be empty, and the type of value matters
- Use (
null
) where a value is meant to be empty - Text should be in quotation marks (
"username"
) - Numbers are numbers by themselves (
1.1
)
number_of_images_upload
Number of images to upload at once. Default:10
upload_retry
Attempts to retry image or chapter upload. Default:3
ratelimit_time
Time (in seconds) to sleep after API calls. Default:2
max_log_days
Days to keep logs. Default:30
group_fallback_id
Group ID to use if not found in file or ID map, leave blank to not upload to a group. Default:null
number_threads
: Number of thread for concurrent image upload. This can rate limit you. Threads are limited to the range 1-3 (inclusive). Default:3
language
: Language for command line messages. Default:en
These values cannot be empty, otherwise the uploader will not run.
mangadex_username
MangaDex username.mangadex_password
MangaDex password.client_id
Client ID for the MangaDex API Client.client_secret
Client Secret for the MangaDex API Client.
These options can be left as is, they do not need to be changed.
name_id_map_file
File name for the name-to-id map. Default:name_id_map.json
uploads_folder
Directory to get new uploads from. Default:to_upload
uploaded_files
Directory to move uploaded chapters to. Default:uploaded
mangadex_api_url
MangaDex API url. Default:https://api.mangadex.org
mangadex_auth_url
MangaDex Authentication url. Default:https://auth.mangadex.org/realms/mangadex/protocol/openid-connect
mdauth_path
Local save file for MangaDex login token. Default:.mdauth
The name_id_map.json
has the following format:
{
"manga": {
"hyakkano": "efb4278c-a761-406b-9d69-19603c5e4c8b"
},
"group": {
"XuN": "b6d57ade-cab7-4be7-b2b8-be68484b3ad3"
},
"formats": {
"longstrip": ["efb4278c-a761-406b-9d69-19603c5e4c8b"],
"widestrip": ["69b4df2d-5ca3-4e58-91bd-74827629dcce"]
}
}
manga
and group
contain the map of name to ID for the manga to upload to and group to upload to respectively. The name should be the same as the upload file. To avoid potential problems when uploading, try use a name that is lowercase and doesn't have spaces.
Each new name-id pair should be separated by a comma at the end of the line and a colon between the name and ID. The last pair of each map should not have a comma.
formats
contains a list of ids for the formats that are longstrip (long image) or widestrip (wide image). There can be multiple ids in each array, but there must not be any duplicate ids.
Take hyakkano - c025 (v04) [XuN].cbz
as the chapter I want to upload. In my name_id_map.json
, I would have the key hyakkano
and the value efb4278c-a761-406b-9d69-19603c5e4c8b
for the manga ID to upload to. I would also have XuN
for the group map with the value b6d57ade-cab7-4be7-b2b8-be68484b3ad3
.
The uploader would then look through this file for the hyakkano
key and for the XuN
key for their assigned ids.
If I have a file named efb4278c-a761-406b-9d69-19603c5e4c8b [es] - 000 (Momi-san) [XuN+00e03853-1b96-4f41-9542-c71b8692033b]
, the uploader would take the manga id directly from the file, the language as Spanish with the code es
, chapter number as null (oneshot) with no volume, chapter title as Momi-san
with groups XuN
(id taken form name_id_map.json
) and 00e03853-1b96-4f41-9542-c71b8692033b
.
- Make sure there aren't any duplicate issues opened before opening one.
- Pull requests are free to be opened if you think it is needed, but please format any code with Python Black (default settings) before doing so.
There are two files to translate, this readme and the mupl/loc/en.json file.
- The translated README should be placed in doc/ with the name
readme.<>.md
with the ISO language code between the periods, for example:readme.pt-br.md
. Update your readme to link back to this readme under the "Read this in other languages" list. - The translated json file should be named
<>.json
with the ISO language code being used and placed inside the directory mupl/loc/, for example:pt-br.json
.
After you have translated these files, update this readme with the link to your translated readme. Please submit a PR with these changes.