2020-03-23 19:29:41 +00:00
|
|
|
This repository is forked from https://code.richard.do/richardARPANET/mega.py_.
|
2019-10-16 21:16:46 +00:00
|
|
|
|
|
|
|
--------------
|
|
|
|
|
|
|
|
.. _megapy:
|
|
|
|
|
|
|
|
Mega.py
|
|
|
|
=======
|
|
|
|
|
|
|
|
Python library for the Mega.co.nz API, currently supporting:
|
|
|
|
|
|
|
|
- login
|
|
|
|
- uploading
|
|
|
|
- downloading
|
|
|
|
- deleting
|
|
|
|
- searching
|
|
|
|
- sharing
|
|
|
|
- renaming
|
|
|
|
- moving files
|
|
|
|
|
|
|
|
This is a work in progress, further functionality coming shortly.
|
|
|
|
|
|
|
|
For more detailed information see API_INFO.md
|
|
|
|
|
|
|
|
How To Use
|
|
|
|
----------
|
|
|
|
|
|
|
|
.. _install-megapy-package:
|
|
|
|
|
|
|
|
Install mega.py package
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
#Run the following command, or run setup from the latest github source
|
2019-10-31 22:27:53 +00:00
|
|
|
pip install mega.py
|
2019-10-16 21:16:46 +00:00
|
|
|
|
|
|
|
.. _import-megapy:
|
|
|
|
|
|
|
|
Import mega.py
|
|
|
|
~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
from mega import Mega
|
|
|
|
|
|
|
|
.. _create-an-instance-of-megapy:
|
|
|
|
|
|
|
|
Create an instance of Mega.py
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
mega = Mega()
|
|
|
|
|
|
|
|
Login to Mega
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
m = mega.login(email, password)
|
|
|
|
# login using a temporary anonymous account
|
|
|
|
m = mega.login()
|
|
|
|
|
|
|
|
Get user details
|
|
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
details = m.get_user()
|
|
|
|
|
|
|
|
Get account balance (Pro accounts only)
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
balance = m.get_balance()
|
|
|
|
|
|
|
|
Get account disk quota
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
quota = m.get_quota()
|
|
|
|
|
|
|
|
Get account storage space
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
# specify unit output kilo, mega, gig, else bytes will output
|
|
|
|
space = m.get_storage_space(kilo=True)
|
|
|
|
|
|
|
|
Get account files
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
files = m.get_files()
|
|
|
|
|
|
|
|
Upload a file, and get its public link
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
file = m.upload('myfile.doc')
|
|
|
|
m.get_upload_link(file)
|
|
|
|
# see mega.py for destination and filename options
|
|
|
|
|
2019-10-31 22:21:07 +00:00
|
|
|
Export a file or folder
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
public_exported_web_link = m.export('myfile.doc')
|
|
|
|
public_exported_web_link = m.export('my_mega_folder/my_sub_folder_to_share')
|
|
|
|
# e.g. https://mega.nz/#F!WlVl1CbZ!M3wmhwZDENMNUJoBsdzFng
|
|
|
|
|
2019-11-01 09:57:13 +00:00
|
|
|
Find a file or folder
|
2019-10-31 22:17:48 +00:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
folder = m.find('my_mega_folder')
|
|
|
|
# Excludes results which are in the Trash folder (i.e. deleted)
|
|
|
|
folder = m.find('my_mega_folder', exclude_deleted=True)
|
|
|
|
|
2019-10-16 21:16:46 +00:00
|
|
|
Upload a file to a destination folder
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
folder = m.find('my_mega_folder')
|
|
|
|
m.upload('myfile.doc', folder[0])
|
|
|
|
|
|
|
|
Download a file from URL or file obj, optionally specify destination folder
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
file = m.find('myfile.doc')
|
|
|
|
m.download(file)
|
|
|
|
m.download_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc')
|
|
|
|
m.download(file, '/home/john-smith/Desktop')
|
|
|
|
# specify optional download filename (download_url() supports this also)
|
|
|
|
m.download(file, '/home/john-smith/Desktop', 'myfile.zip')
|
|
|
|
|
|
|
|
Import a file from URL, optionally specify destination folder
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
m.import_public_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc')
|
|
|
|
folder_node = m.find('Documents')[1]
|
|
|
|
m.import_public_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc', dest_node=folder_node)
|
|
|
|
|
|
|
|
Create a folder
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
m.create_folder('new_folder')
|
2019-10-23 20:06:16 +00:00
|
|
|
m.create_folder('new_folder/sub_folder/subsub_folder')
|
|
|
|
|
|
|
|
Returns a dict of folder node name and node_id, e.g.
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
{
|
|
|
|
'new_folder': 'qpFhAYwA',
|
|
|
|
'sub_folder': '2pdlmY4Z',
|
|
|
|
'subsub_folder': 'GgMFCKLZ'
|
|
|
|
}
|
2019-10-16 21:16:46 +00:00
|
|
|
|
|
|
|
Rename a file or a folder
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
file = m.find('myfile.doc')
|
|
|
|
m.rename(file, 'my_file.doc')
|
|
|
|
|
2019-10-23 20:06:16 +00:00
|
|
|
|
2019-10-16 21:16:46 +00:00
|
|
|
~
|
|
|
|
|
2019-10-31 22:25:57 +00:00
|
|
|
.. _`https://code.richard.do/richardARPANET/mega.py`: https://code.richard.do/richardARPANET/mega.py
|
2019-10-16 21:16:46 +00:00
|
|
|
.. _`https://github.com/meganz/sdk`: https://github.com/meganz/sdk
|