您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 
 
 
 

442 行
12 KiB

  1. import sys, os
  2. import webnotes
  3. import webnotes.defs
  4. import webnotes.utils
  5. form = webnotes.form
  6. form_dict = webnotes.form_dict
  7. sql = None
  8. session = None
  9. errdoc = ''
  10. errdoctype = ''
  11. errmethod = ''
  12. # Logs
  13. # refresh / start page
  14. # ------------------------------------------------------------------------------------
  15. def startup():
  16. import webnotes
  17. import webnotes.session_cache
  18. webnotes.response.update(webnotes.session_cache.get())
  19. def cleanup_docs():
  20. import webnotes.model.utils
  21. if webnotes.response.get('docs') and type(webnotes.response['docs'])!=dict:
  22. webnotes.response['docs'] = webnotes.model.utils.compress(webnotes.response['docs'])
  23. # server calls
  24. # ------------------------------------------------------------------------------------
  25. def runserverobj(arg=None):
  26. import webnotes.widgets.form
  27. webnotes.widgets.form.runserverobj()
  28. def logout():
  29. webnotes.login_manager.logout()
  30. # versions
  31. # --------
  32. def get_diff():
  33. v = webnotes.form_dict.get('version_number')
  34. from build.version import VersionControl
  35. webnotes.response['message'] = VersionControl().repo.diff(v)
  36. # DocType Mapper
  37. # ------------------------------------------------------------------------------------
  38. def dt_map():
  39. import webnotes
  40. import webnotes.model.utils
  41. from webnotes.model.code import get_obj
  42. from webnotes.model.doc import Document
  43. form_dict = webnotes.form_dict
  44. dt_list = webnotes.model.utils.expand(form_dict.get('docs'))
  45. from_doctype = form_dict.get('from_doctype')
  46. to_doctype = form_dict.get('to_doctype')
  47. from_docname = form_dict.get('from_docname')
  48. from_to_list = form_dict.get('from_to_list')
  49. dm = get_obj('DocType Mapper', from_doctype +'-' + to_doctype)
  50. dl = dm.dt_map(from_doctype, to_doctype, from_docname, Document(fielddata = dt_list[0]), [], from_to_list)
  51. webnotes.response['docs'] = dl
  52. # Load Month Events
  53. # ------------------------------------------------------------------------------------
  54. def load_month_events():
  55. import webnotes
  56. form = webnotes.form
  57. mm = form.getvalue('month')
  58. yy = form.getvalue('year')
  59. m_st = str(yy) + '-' + str(mm) + '-01'
  60. m_end = str(yy) + '-' + str(mm) + '-31'
  61. import webnotes.widgets.event
  62. webnotes.response['docs'] = webnotes.widgets.event.get_cal_events(m_st, m_end)
  63. # Data import
  64. # ------------------------------------------------------------------------------------
  65. def import_csv():
  66. import webnotes.model.import_docs
  67. form = webnotes.form
  68. from webnotes.utils import cint
  69. i = webnotes.model.import_docs.CSVImport()
  70. r = i.import_csv(form.getvalue('csv_file'), form.getvalue('dateformat'), form_dict.get('overwrite', 0) and 1)
  71. webnotes.response['type']='iframe'
  72. rhead = '''<style>body, html {font-family: Arial; font-size: 12px;}</style>'''
  73. webnotes.response['result']= rhead + r
  74. def get_template():
  75. import webnotes.model.import_docs
  76. webnotes.model.import_docs.get_template()
  77. # File Upload
  78. # ------------------------------------------------------------------------------------
  79. def uploadfile():
  80. import webnotes.utils.file_manager
  81. if webnotes.form_dict.get('from_form'):
  82. webnotes.utils.file_manager.upload()
  83. else:
  84. # save the file
  85. fid, fname = webnotes.utils.file_manager.save_uploaded()
  86. # do something with the uploaded file
  87. if fid and webnotes.form_dict.get('server_obj'):
  88. from webnotes.model.code import get_obj
  89. getattr(get_obj(webnotes.form_dict.get('server_obj')), webnotes.form_dict.get('method'))(fid, fname)
  90. # return the upload
  91. if fid:
  92. webnotes.response['result'] = '<script>window.parent.upload_callback("'+webnotes.form_dict.get('uploader_id')+'", "'+fid+'")</script>'
  93. # File upload (from scripts)
  94. # ------------------------------------------------------------------------------------
  95. def upload_many():
  96. from webnotes.model.code import get_obj
  97. # pass it on to upload_many method in Control Panel
  98. cp = get_obj('Control Panel')
  99. cp.upload_many(webnotes.form)
  100. webnotes.response['result'] = """
  101. <script type='text/javascript'>
  102. %s
  103. </script>
  104. %s
  105. %s""" % (cp.upload_callback(webnotes.form), '\n----\n'.join(webnotes.message_log).replace("'", "\'"), '\n----\n'.join(webnotes.debug_log).replace("'", "\'").replace("\n","<br>"))
  106. webnotes.response['type'] = 'iframe'
  107. # File download
  108. # ------------------------------------------------------------------------------------
  109. def get_file():
  110. import webnotes.utils.file_manager
  111. res = webnotes.utils.file_manager.get_file(form.getvalue('fname'))
  112. if res:
  113. webnotes.response['type'] = 'download'
  114. webnotes.response['filename'] = res[0]
  115. if hasattr(res[1], 'tostring'):
  116. webnotes.response['filecontent'] = res[1].tostring()
  117. else:
  118. webnotes.response['filecontent'] = res[1]
  119. else:
  120. webnotes.msgprint('[get_file] Unknown file name')
  121. # Get Graph
  122. # ------------------------------------------------------------------------------------
  123. def get_graph():
  124. form = webnotes.form
  125. import StringIO
  126. f = StringIO.StringIO()
  127. # call the object
  128. obj = server.get_obj(form_dict.get('dt'))
  129. plt = server.run_server_obj(obj, form_dict.get('method'), form_dict.get('arg'))
  130. plt.savefig(f)
  131. # stream out
  132. webnotes.response['type'] = 'download'
  133. webnotes.response['filename'] = webnotes.user.get_random_password() + '.png'
  134. webnotes.response['filecontent'] = f.getvalue()
  135. # Reset Password
  136. # ------------------------------------------------------------------------------------
  137. def reset_password():
  138. form_dict = webnotes.form_dict
  139. act = form_dict.get('account', '')
  140. user = form_dict.get('user', '')
  141. if act:
  142. webnotes.conn.set_db(act)
  143. try:
  144. p = webnotes.profile.Profile(user)
  145. p.reset_password()
  146. webnotes.msgprint("Password has been reset and sent to your email id.")
  147. except Exception, e:
  148. webnotes.msgprint(str(e))
  149. # Resume session
  150. # ------------------------------------------------------------------------------------
  151. def resume_session():
  152. webnotes.response['message'] = webnotes.session_obj.resume()
  153. # -------------
  154. # Create Backup
  155. # -------------
  156. def backupdb(form_dict, session):
  157. db_name = server.decrypt(form_dict.get('db_name'))
  158. server.backup_db(db_name)
  159. webnotes.response['type'] = 'download'
  160. webnotes.response['filename'] = db_name+'.tar.gz'
  161. webnotes.response['filecontent'] = open('../backups/' + db_name+'.tar.gz','rb').read()
  162. # ---------------------------------------------------------------------
  163. def validate_cmd(cmd):
  164. # check if there is no direct possibility of malicious script injection
  165. if cmd.startswith('webnotes.model.code'):
  166. raise Exception, 'Cannot call any methods from webnotes.model.code directly from the handler'
  167. if cmd.startswith('webnotes.model.db_schema'):
  168. raise Exception, 'Cannot call any methods from webnotes.model.db_schema directly from the handler'
  169. if cmd.startswith('webnotes.conn'):
  170. raise Exception, 'Cannot call database connection method directly from the handler'
  171. # Execution Starts Here
  172. # ---------------------------------------------------------------------
  173. import webnotes.auth
  174. import webnotes.db
  175. # reset password
  176. # ---------------------------------------------------------------------
  177. if form_dict.has_key('cmd') and (form_dict.get('cmd')=='reset_password'):
  178. webnotes.conn = webnotes.db.Database(use_default = 1)
  179. sql = webnotes.conn.sql
  180. sql("START TRANSACTION")
  181. try:
  182. reset_password()
  183. sql("COMMIT")
  184. except Exception, e:
  185. webnotes.errprint(str(e))
  186. sql("ROLLBACK")
  187. # pre-login access - for registration etc.
  188. # ---------------------------------------------------------------------
  189. elif form_dict.has_key('cmd') and (form_dict.get('cmd')=='prelogin'):
  190. webnotes.conn = webnotes.db.Database(use_default = 1)
  191. sql = webnotes.conn.sql
  192. webnotes.session = {'user':'Administrator'}
  193. import webnotes.model.code
  194. sql("START TRANSACTION")
  195. try:
  196. webnotes.response['message'] = webnotes.model.code.get_obj('Profile Control').prelogin(form_dict) or ''
  197. sql("COMMIT")
  198. except:
  199. webnotes.errprint(webnotes.utils.getTraceback())
  200. sql("ROLLBACK")
  201. # main stuff
  202. # ---------------------------------------------------------------------
  203. else:
  204. try:
  205. webnotes.request = webnotes.auth.HTTPRequest()
  206. if form_dict.get('cmd') != 'login' and webnotes.conn:
  207. sql = webnotes.conn.sql
  208. # NOTE:
  209. # guest should only be allowed:
  210. # getdoc (if Guest access)
  211. # runserverobj (if Guest access)
  212. # get command cmd
  213. cmd = form_dict.has_key('cmd') and form_dict.get('cmd') or ''
  214. read_only = form_dict.has_key('_read_only') and form_dict.get('_read_only') or None
  215. validate_cmd(cmd)
  216. module = ''
  217. if '.' in cmd:
  218. module = '.'.join(cmd.split('.')[:-1])
  219. cmd = cmd.split('.')[-1]
  220. exec 'from %s import %s' % (module, cmd) in locals()
  221. # execute
  222. if locals().has_key(cmd):
  223. if (not webnotes.conn.in_transaction) and (not read_only):
  224. webnotes.conn.begin()
  225. if webnotes.form_dict.get('arg'):
  226. # direct method call
  227. ret = locals()[cmd](webnotes.form_dict.get('arg'))
  228. else:
  229. ret = locals()[cmd]()
  230. # returns with a message
  231. if ret:
  232. webnotes.response['message'] = ret
  233. # update session
  234. webnotes.session_obj.update()
  235. if webnotes.conn.in_transaction:
  236. webnotes.conn.commit()
  237. else:
  238. if cmd!='login':
  239. webnotes.msgprint('No Method: %s' % cmd)
  240. except webnotes.ValidationError:
  241. webnotes.conn.rollback()
  242. except:
  243. webnotes.errprint(webnotes.utils.getTraceback())
  244. webnotes.conn and webnotes.conn.rollback()
  245. #### cleanup
  246. #-----------
  247. if webnotes.conn:
  248. webnotes.conn.close()
  249. #### go
  250. import string
  251. import os
  252. acceptsGzip, out_buf, str_out = 0, None, None
  253. try:
  254. if string.find(os.environ["HTTP_ACCEPT_ENCODING"], "gzip") != -1:
  255. acceptsGzip = 1 # problem in win ?
  256. except:
  257. pass
  258. def compressBuf(buf):
  259. import gzip, cStringIO
  260. zbuf = cStringIO.StringIO()
  261. zfile = gzip.GzipFile(mode = 'wb', fileobj = zbuf, compresslevel = 5)
  262. zfile.write(buf)
  263. zfile.close()
  264. return zbuf.getvalue()
  265. # CSV
  266. # -------------------------------------------------------------------
  267. if webnotes.response.get('type')=='csv':
  268. print "Content-Type: text/csv"
  269. print "Content-Disposition: attachment; filename="+webnotes.response['doctype'].replace(' ', '_')+".csv"
  270. print
  271. print webnotes.response['result']
  272. # IFRAME
  273. # -------------------------------------------------------------------
  274. elif webnotes.response.get('type')=='iframe':
  275. print "Content-Type: text/html"
  276. print
  277. if webnotes.response.get('result'):
  278. print webnotes.response['result']
  279. if webnotes.debug_log:
  280. print '''<script type='text/javascript'>alert("%s");</script>''' % ('-------'.join(webnotes.debug_log).replace('"', '').replace('\n',''))
  281. # file
  282. # -------------------------------------------------------------------
  283. elif webnotes.response.get('type')=='download':
  284. import mimetypes
  285. print "Content-Type: %s" % (mimetypes.guess_type(webnotes.response['filename'])[0] or 'application/unknown')
  286. print "Content-Disposition: filename="+webnotes.response['filename'].replace(' ', '_')
  287. print
  288. print webnotes.response['filecontent']
  289. # JSON
  290. # -------------------------------------------------------------------
  291. else:
  292. if webnotes.debug_log:
  293. save_log = 1
  294. if webnotes.debug_log[0].startswith('[Validation Error]'):
  295. save_log = 0
  296. t = '\n----------------\n'.join(webnotes.debug_log)
  297. if errdoctype:
  298. t = t + '\nDocType: ' + errdoctype
  299. if errdoc:
  300. t = t + '\nName: ' + errdoc
  301. if errmethod:
  302. t = t + '\nMethod: ' + errmethod
  303. webnotes.response['exc'] = '<pre>'+t.replace('\n','<br>')+'</pre>'
  304. if save_log: # don't save validation errors
  305. try: save_log(t, 'Server')
  306. except: pass
  307. if webnotes.message_log:
  308. webnotes.response['server_messages'] = '\n----------------\n'.join(webnotes.message_log)
  309. cleanup_docs()
  310. # Convert to JSON
  311. # ---------------
  312. try:
  313. import json
  314. except: # python 2.4
  315. import simplejson as json
  316. str_out = json.dumps(webnotes.response)
  317. if acceptsGzip and 1 and len(str_out)>512:
  318. out_buf = compressBuf(str_out)
  319. print "Content-Encoding: gzip"
  320. print "Content-Length: %d" % (len(out_buf))
  321. print "Content-Type: text/html; charset: utf-8"
  322. # if there ar additional cookies defined during the request, add them here
  323. if webnotes.cookies or webnotes.add_cookies:
  324. for c in webnotes.add_cookies.keys():
  325. webnotes.cookies[c] = webnotes.add_cookies[c]
  326. print webnotes.cookies
  327. print # Headers end
  328. if out_buf:
  329. sys.stdout.write(out_buf)
  330. elif str_out:
  331. print str_out