main.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. from flask import Flask, request, session, g, redirect, url_for, abort, \
  4. render_template, flash, jsonify
  5. from flask.ext.babel import Babel, gettext as _
  6. import sqlite3
  7. from datetime import date, time, timedelta, datetime
  8. import locale
  9. locale.setlocale(locale.LC_ALL, '')
  10. import string
  11. from settings import *
  12. import forms
  13. app = Flask(__name__)
  14. app.config.from_object(__name__)
  15. babel = Babel(app)
  16. def connect_db():
  17. return sqlite3.connect(app.config['DATABASE'])
  18. @app.before_request
  19. def before_request():
  20. g.db = connect_db()
  21. #g.db.execute("PRAGMA foreign_keys = ON")
  22. @app.teardown_request
  23. def teardown_request(exception):
  24. g.db.close()
  25. @app.route('/')
  26. def home():
  27. return render_template('index.html', active_button="home")
  28. def query_db(query, args=(), one=False):
  29. cur = g.db.execute(query, args)
  30. rv = [dict((cur.description[idx][0], value)
  31. for idx, value in enumerate(row)) for row in cur.fetchall()]
  32. return (rv[0] if rv else None) if one else rv
  33. def init_db():
  34. with closing(connect_db()) as db:
  35. with app.open_resource('schema.sql') as f:
  36. db.cursor().executescript(f.read())
  37. db.commit()
  38. @app.route('/members')
  39. def members():
  40. members = query_db('select * from fai where is_member = 1')
  41. return render_template('members.html', members=members)
  42. @app.route('/projects')
  43. def projects():
  44. projects = list()
  45. for project in query_db('select * from fai order by is_member desc,step desc,name'):
  46. project['stepname'] = STEPS[project['step']]
  47. projects.append(project)
  48. return render_template('projects.html', projects=projects)
  49. @app.route('/fai/<projectid>')
  50. def project(projectid):
  51. project = query_db('select * from fai where id = ?', [projectid], one=True)
  52. if project is None:
  53. abort(404)
  54. project['stepname'] = STEPS[project['step']]
  55. return render_template('project.html', project=project)
  56. @app.route('/edit/<projectid>', methods=['GET', 'POST'])
  57. def edit_project(projectid):
  58. project = query_db('select * from fai where id = ?', [projectid], one=True)
  59. if project is None:
  60. abort(404)
  61. if request.method == 'POST':
  62. if request.form['name']:
  63. if request.form['shortname']:
  64. if query_db('select * from fai where id!=? and (name=? or shortname=?)', [projectid, request.form['name'], request.form['shortname']], one=True) is None:
  65. is_member = 0
  66. if 'is_member' in request.form.keys():
  67. is_member = 1
  68. g.db.execute('update fai set name = ?, shortname = ?, description = ?, website = ?, email = ?, irc_channel = ?, irc_server = ?, zone = ?, gps = ?, step = ?, is_member = ? where id = ?',
  69. [request.form['name'], request.form['shortname'], request.form['description'], request.form['website'], request.form['email'], request.form['irc_channel'], request.form['irc_server'], request.form['zone'], request.form['gps1'] + ':' + request.form['gps2'], request.form['step'][:1], is_member, projectid])
  70. g.db.commit()
  71. flash(u"Le projet a bien été mis à jour. Merci pour votre contribution !", "success")
  72. project = query_db('select * from fai where id = ?', [projectid], one=True)
  73. return redirect(url_for('project', projectid=projectid))
  74. else:
  75. flash(u'Le nom complet ou le nom court que vous avez choisi est déjà pris.', 'error')
  76. else:
  77. flash(u'Vous devez spécifier un nom court (éventuellement, le même que le nom complet).', 'error')
  78. else:
  79. flash(u'Vous devez spécifier un nom.', 'error')
  80. project['stepname'] = STEPS[project['step']]
  81. return render_template('edit_project.html', project=project)
  82. @app.route('/create_old', methods=['GET', 'POST'])
  83. def create_project_old():
  84. if request.method == 'POST':
  85. if request.form['name']:
  86. if request.form['shortname']:
  87. if query_db('select * from fai where name=? or shortname=?', [request.form['name'], request.form['shortname']], one=True) is None:
  88. g.db.execute('INSERT INTO fai (name, shortname, description, website, email, irc_channel, irc_server, zone, gps, step) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)',
  89. [request.form['name'], request.form['shortname'], request.form['description'], request.form['website'], request.form['email'], request.form['irc_channel'], request.form['irc_server'], request.form['zone'], request.form['gps1'] + ':' + request.form['gps2'], request.form['step'][:1]])
  90. g.db.commit()
  91. flash(u"Le projet a bien été créé. Merci pour votre contribution !", "success")
  92. project = query_db('select * from fai where name = ?', [request.form['name']], one=True)
  93. if project is not None:
  94. return redirect(url_for('project', projectid=project['id']))
  95. else:
  96. flash(u'Hum… il semble que le projet n\'a pas été créé… vous voulez-bien réessayer ?', 'error')
  97. else:
  98. flash(u'Le nom complet ou le nom court que vous avez choisi est déjà pris.', 'error')
  99. else:
  100. flash(u'Vous devez spécifier un nom court (éventuellement, le même que le nom complet).', 'error')
  101. else:
  102. flash(u'Vous devez spécifier un nom.', 'error')
  103. return render_template('create_project.html')
  104. @app.route('/create', methods=['GET', 'POST'])
  105. def create_project():
  106. form = forms.ProjectForm()
  107. if form.validate_on_submit():
  108. flash(_(u'Thanks !'))
  109. return redirect('/')
  110. return render_template('project_form.html', form=form)
  111. @app.route('/search', methods=['GET', 'POST'])
  112. def search():
  113. if request.method == 'POST':
  114. pass
  115. return render_template('search.html')
  116. @app.route('/api/<projects>.json')
  117. def projects_json(projects):
  118. if projects == 'projects':
  119. query = 'select * from fai'
  120. elif projects == 'members':
  121. query = 'select * from fai where is_member = 1'
  122. else:
  123. abort(404)
  124. fais = dict()
  125. for fai in query_db(query):
  126. fais[fai['name']] = fai
  127. return jsonify(fais)
  128. @app.route('/api/members_drupal')
  129. def members_drupal():
  130. members = query_db('select * from fai where is_member = 1 order by shortname')
  131. return render_template('members_drupal.html', members=members)
  132. #------
  133. # Filters
  134. @app.template_filter('step_to_label')
  135. def step_to_label(step):
  136. return u"<a href='#' rel='tooltip' data-placement='right' title='" + STEPS[step] + "'><span class='badge badge-" + STEPS_LABELS[step] + "'>" + str(step) + "</span></a>"
  137. @app.template_filter('member_to_label')
  138. def member_to_label(is_member):
  139. if is_member:
  140. return u'<a href="#" rel="tooltip" data-placement="right" title="Membre de la Fédération FDN"><span class="label label-success">FFDN</span></a>'
  141. return ''
  142. @app.template_filter('stepname')
  143. def stepname(step):
  144. return STEPS[step]
  145. @app.template_filter('gpspart')
  146. def gpspart(gps, part):
  147. parts = gps.split(':');
  148. if part == 1:
  149. return parts[0]
  150. elif part == 2:
  151. return parts[1]
  152. return "";
  153. #------
  154. # Main
  155. if __name__ == '__main__':
  156. app.run()