X-Git-Url: http://git.cyclocoop.org/?a=blobdiff_plain;f=main.py;h=bdbd032ed78544c505ebc4af3b0ba0cd027cb8c8;hb=c99b9d04a42f493cf7b8bf1e81022bb65e2b939b;hp=4662b59beecf0db8685d075335176b61189f01a5;hpb=4517694972e64e0b3a26b6bc9a7fc39d7ac8af38;p=cavote.git diff --git a/main.py b/main.py index 4662b59..bdbd032 100755 --- a/main.py +++ b/main.py @@ -201,14 +201,94 @@ def add_vote(): public = 1 if 'multiplechoice' in request.form.keys(): multiplechoice = 1 - g.db.execute('insert into votes (title, description, date_begin, date_end, is_transparent, is_public, is_multiplechoice) values (?, ?, ?, ?, ?, ?, ?)', - [request.form['title'], request.form['description'], date_begin, date_end, transparent, public, multiplechoice]) + role = query_db('select id from roles where name = ?', [request.form['role']], one=True) + if role is None: + role[id] = 1 + g.db.execute('insert into votes (title, description, category, date_begin, date_end, is_transparent, is_public, is_multiplechoice, id_role, id_author) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', + [request.form['title'], request.form['description'], request.form['category'], date_begin, date_end, transparent, public, multiplechoice, role['id'], session['user']['id']]) g.db.commit() - flash('New entry was successfully posted', 'info') - return redirect(url_for('home')) + vote = query_db('select * from votes where title = ? and date_begin = ? order by id desc', + [request.form['title'], date_begin], one=True) # :DEBUG:maethor:20120528: Bug possible car le titre n'est pas unique + if vote is None: + flash(u'Une erreur est survenue !', 'error') + return redirect(url_for('home')) + else: + flash(u"Le vote a été créé", 'info') + return redirect(url_for('edit_vote', voteid=vote['id'])) + else: + flash(u'Vous devez spécifier un titre.', 'error') + groups = query_db('select * from roles') + return render_template('new_vote.html', groups=groups) + +@app.route('/votes/admin/edit/', methods=['GET', 'POST']) +def edit_vote(voteid): + if not session.get('user').get('is_admin'): + abort(401) + vote = query_db('select * from votes where id = ?', [voteid], one=True) + if vote is None: + abort(404) + if request.method == 'POST': + if request.form['title']: + # :TODO:maethor:120529: Calculer date_begin pour pouvoir y ajouter duration et obtenir date_end + transparent = 0 + public = 0 + if 'transparent' in request.form.keys(): + transparent = 1 + if 'public' in request.form.keys(): + public = 1 + isopen = 0 + if request.form['status'] == 'Ouvert': + isopen = 1 + g.db.execute('update votes set title = ?, description = ?, category = ?, is_transparent = ?, is_public = ?, is_open = ? where id = ?', + [request.form['title'], request.form['description'], request.form['category'], transparent, public, isopen, voteid]) + g.db.commit() + vote = query_db('select * from votes where id = ?', [voteid], one=True) + flash(u"Le vote a bien été mis à jour.", "success") else: flash(u'Vous devez spécifier un titre.', 'error') - return render_template('new_vote.html') + + # :TODO:maethor:20120529: Calculer la durée du vote (différence date_end - date_begin) + vote['duration'] = 15 + group = query_db('select name from roles where id = ?', [vote['id_role']], one=True) + choices = query_db('select * from choices where id_vote = ?', [voteid]) + return render_template('edit_vote.html', vote=vote, group=group, choices=choices) + +@app.route('/votes/admin/addchoice/', methods=['POST']) +def add_choice(voteid): + if not session.get('user').get('is_admin'): + abort(401) + vote = query_db('select * from votes where id = ?', [voteid], one=True) + if vote is None: + abort(404) + g.db.execute('insert into choices (name, id_vote) values (?, ?)', [request.form['title'], voteid]) + g.db.commit() + return redirect(url_for('edit_vote', voteid=voteid)) + +@app.route('/votes/admin/editchoice//', methods=['POST', 'DELETE']) +def edit_choice(voteid, choiceid): + if not session.get('user').get('is_admin'): + abort(401) + choice = query_db('select * from choices where id = ? and id_vote = ?', [choiceid, voteid], one=True) + if choice is None: + abort(404) + if request.method == 'POST': + g.db.execute('update choices set name=? where id = ? and id_vote = ?', [request.form['title'], choiceid, voteid]) + g.db.commit() + elif request.method == 'DELETE': # :COMMENT:maethor:20120528: I can't find how to use it from template + g.db.execute('delete from choices where id = ? and id_vote = ?', [choiceid, voteid]) + g.db.commt() + return redirect(url_for('edit_vote', voteid=voteid)) + +@app.route('/votes/admin/deletechoice//') +def delete_choice(voteid, choiceid): + if not session.get('user').get('is_admin'): + abort(401) + choice = query_db('select * from choices where id = ? and id_vote = ?', [choiceid, voteid], one=True) + if choice is None: + abort(404) + g.db.execute('delete from choices where id = ? and id_vote = ?', [choiceid, voteid]) + g.db.commit() + return redirect(url_for('edit_vote', voteid=voteid)) #------ # Main