This repository was archived by the owner on Nov 3, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathRoot.py
82 lines (68 loc) · 2.78 KB
/
Root.py
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
76
77
78
79
80
81
82
#!/usr/bin/python
import cherrypy
import sys
import csv
import StringIO
import urllib2
from Scheduler import *
from os import listdir
from os.path import isfile, join
from CustomRequestHandler import CustomRequestHandler
class Root(object):
def index(self, **parameters):
return open(os.path.join('', 'html', 'index.html'))
index.exposed = True
def data(self, **parameters):
parameters['source'] = self.getSources()
return data(parameters)
data.exposed = True
def upload(self, **uploadedFile):
string_data = uploadedFile['file'].fullvalue()
return self.validateAndTransform(string_data)
upload.exposed = True
def uploadAndSave(self, **uploadedData):
self.saveIntoFile(uploadedData['filename'], uploadedData['file'].fullvalue())
return self.validateAndTransform(uploadedData['file'].fullvalue())
uploadAndSave.exposed = True
def uploadFromUrl(self, **urlData):
try:
data = urllib2.urlopen(urlData['urlName'])
self.saveIntoFile(urlData['filename'], data.read())
return self.validateAndTransform(data.read())
except ValueError:
return "fail"
uploadFromUrl.exposed = True
def saveIntoFile(self, filename, filedata):
if not os.path.exists(CSV_FOLDER_NAME):
os.makedirs(CSV_FOLDER_NAME)
with open(CSV_FOLDER_NAME + '/' + filename, 'wb') as cvsfile:
cvsfile.write(filedata)
def getUploadedFileList(self):
if not os.path.exists(CSV_FOLDER_NAME):
os.makedirs(CSV_FOLDER_NAME)
onlyfiles = [ f for f in listdir(CSV_FOLDER_NAME + '/') if isfile(join(CSV_FOLDER_NAME + '/',f)) ]
return ';'.join(onlyfiles)
getUploadedFileList.exposed = True
def deleteFile(self, **fileData):
os.remove(CSV_FOLDER_NAME + '/' + fileData['filename'])
deleteFile.exposed = True
def getSources(self):
with open(SOURCE_CONFIG, 'rb') as srcFile:
dataString = srcFile.read()
return dataString
getSources.exposed = True
def setSources(self, **configData):
with open(SOURCE_CONFIG, 'wb') as srcFile:
srcFile.write(str(configData['data']))
setSources.exposed = True
def getFileContent(self, **parameters):
with open(CSV_FOLDER_NAME + '/' + parameters['filename'], 'rb') as srcFile:
dataString = srcFile.read()
return dataString
getFileContent.exposed = True
def validateAndTransform(self, data):
input_file = csv.reader(StringIO.StringIO(data), csv.excel)
handler = CustomRequestHandler()
return handler.main(input_file)
if __name__ == '__main__':
cherrypy.quickstart(Root(), '/', 'TimeTable.conf')