forked from pyload/pyload
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathContainer.py
More file actions
75 lines (54 loc) · 2.26 KB
/
Container.py
File metadata and controls
75 lines (54 loc) · 2.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
# -*- coding: utf-8 -*-
"""
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License,
or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, see <http://www.gnu.org/licenses/>.
@author: mkaay
"""
from module.plugins.Crypter import Crypter
from os.path import join, exists, basename
from os import remove
import re
class Container(Crypter):
__name__ = "Container"
__version__ = "0.1"
__pattern__ = None
__type__ = "container"
__description__ = """Base container plugin"""
__author_name__ = ("mkaay")
__author_mail__ = ("mkaay@mkaay.de")
def preprocessing(self, thread):
"""prepare"""
self.setup()
self.thread = thread
self.loadToDisk()
self.decrypt(self.pyfile)
self.deleteTmp()
self.createPackages()
def loadToDisk(self):
"""loads container to disk if its stored remotely and overwrite url,
or check existent on several places at disk"""
if self.pyfile.url.startswith("http"):
self.pyfile.name = re.findall("([^\/=]+)", self.pyfile.url)[-1]
content = self.load(self.pyfile.url)
self.pyfile.url = join(self.config["general"]["download_folder"], self.pyfile.name)
f = open(self.pyfile.url, "wb" )
f.write(content)
f.close()
else:
self.pyfile.name = basename(self.pyfile.url)
if not exists(self.pyfile.url):
if exists(join(pypath, self.pyfile.url)):
self.pyfile.url = join(pypath, self.pyfile.url)
else:
self.fail(_("File not exists."))
def deleteTmp(self):
if self.pyfile.name.startswith("tmp_"):
remove(self.pyfile.url)