+@app.route('/admin/votes/list')
+def admin_votes():
+ if not session.get('user').get('is_admin'):
+ abort(401)
+ votes = query_db('select *, votes.id as voteid, groups.name as groupname from votes \
+ join groups on groups.id=votes.id_group \
+ where is_hidden=0 order by id desc')
+ return render_template('admin_votes.html', votes=votes
+ , today=date.today().strftime("%Y-%m-%d")
+ , can_delete_votes=CAN_DELETE_VOTES
+ )
+
+@app.route('/admin/votes/add', methods=['GET', 'POST'])
+def admin_vote_add():
+ if not session.get('user').get('is_admin'):
+ abort(401)
+ cardinals= OrderedDict([(len(values), {'name':name,'values':values,'first':first}) for (name, first, values) in CARDINALS])
+ if request.method == 'POST':
+ if request.form['title']:
+ if query_db('select * from votes where title = ?', [request.form['title']], one=True) is None:
+ date_begin = date.today()
+ date_end = date.today() + timedelta(days=int(request.form['days']))
+ transparent = 0
+ public = 0
+ anonymous = 0
+ if 'transparent' in request.form:
+ transparent = 1
+ if 'public' in request.form:
+ public = 1
+ if 'anonymous' in request.form:
+ anonymous = 1
+ try: quorum = float(request.form.get('quorum'))
+ except ValueError:
+ quorum = 0
+ if not (0 <= quorum and quorum <= 1):
+ flash(u'Une erreur est survenue !', 'error')
+ group = query_db('select id from groups where name = ?', [request.form['group']], one=True)
+ if group is None:
+ group[id] = 1
+ try: cardinal = int(request.form.get('cardinal'))
+ except ValueError:
+ cardinal = None
+ if cardinal in cardinals:
+ cardinal_name = cardinals[cardinal]['name']
+ cardinal_values = cardinals[cardinal]['values']
+ weight = cardinals[cardinal]['first'] if not cardinals[cardinal]['first'] is None else -(cardinal/2)
+ if query_db('select * from cardinals where id = ?', [cardinal], one=True) is None:
+ g.db.execute('insert into cardinals (id, name, first) values (?, ?, ?)', [len(cardinal_values), cardinal_name, weight])
+ g.db.commit()
+ for name in cardinal_values:
+ g.db.execute('insert into values_ (id_cardinal, name, weight) values (?, ?, ?)'
+ , [cardinal, name, weight])
+ g.db.commit()
+ weight += 1
+ g.db.execute('insert into votes (title, description, category, \
+ date_begin, date_end, quorum, is_transparent, is_public, \
+ is_anonymous, id_group, id_author, id_cardinal) \
+ values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)',
+ [ request.form['title'], request.form['description'], request.form['category']
+ , date_begin, date_end, quorum, transparent, public, anonymous
+ , group['id'], session['user']['id'], cardinal ])
+ g.db.commit()
+ vote = query_db('select * from votes where title = ? and date_begin = ? order by id desc'
+ , [request.form['title'], date_begin], one=True)
+ if vote is None:
+ flash(u'Une erreur est survenue !', 'error')
+ return redirect(url_for('home'))
+ else:
+ if request.form['pattern'] in PATTERNS:
+ pattern = PATTERNS[request.form['pattern']]
+ for choice in pattern:
+ g.db.execute('insert into choices (name, id_vote) values (?, ?)', [choice, vote['id']])
+ g.db.commit()
+ flash(u"Le vote a été créé", 'info')
+ return redirect(url_for('admin_vote_edit', voteid=vote['id']))
+ else:
+ flash(u'Le titre que vous avez choisi est déjà pris.', 'error')
+ else:
+ flash(u'Vous devez spécifier un titre.', 'error')
+ groups = query_db('select * from groups')
+ return render_template('admin_vote_new.html', groups=groups, cardinals=cardinals
+ , quorums=QUORUMS, patterns=PATTERNS)
+
+@app.route('/admin/votes/edit/<voteid>', methods=['GET', 'POST'])
+def admin_vote_edit(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']:
+ if request.form['days'] > 0:
+ date_end = datetime.strptime(vote['date_begin'], "%Y-%m-%d") + timedelta(days=int(request.form['days']))
+ date_end = date_end.strftime("%Y-%m-%d")
+ transparent = 0
+ public = 0
+ if 'transparent' in request.form:
+ transparent = 1
+ if 'public' in request.form:
+ public = 1
+ isopen = 0
+ isterminated = 0
+ print "POST"
+ if request.form['status'] == 'Ouvert':
+ choices = query_db('select id_vote, count(*) as nb, groups.name as group_name \
+ from choices \
+ join votes on votes.id = choices.id_vote \
+ join groups on groups.id = votes.id_group \
+ where id_vote = ? \
+ group by id_vote', [voteid], one=True)
+ if choices is not None and choices['nb'] >= 1:
+ isopen = 1
+ previousvote = query_db('select id, is_open, id_group from votes where id = ?', [voteid], one=True)
+ if (previousvote is None or previousvote['is_open'] == 0) and 'mail_notice' in request.form:
+ users_to_vote = query_db('select users.email, users.name from users \
+ join user_group on users.id=user_group.id_user \
+ where user_group.id_group = ?', [previousvote['id_group']])
+ for user in users_to_vote:
+ link = request.url_root + url_for('vote', idvote=voteid)
+ BODY = string.join((
+ u"From: %s" % EMAIL,
+ u"To: %s" % user['email'],
+ u"Subject: [vote] [%s] %s" % (choices['group_name'], request.form['title']),
+ u"Date: %s" % time.strftime("%a, %d %b %Y %H:%M:%S +0000", time.gmtime()).decode('utf-8'),
+ u"Content-type: text/plain; charset=utf-8",
+ u"X-Mailer: %s" % VERSION,
+ "",
+ u"%(text0)s%(group)s" % \
+ { "text0":gettext(u"A new vote concerns you within the group: ") \
+ , "group":choices['group_name'] }, \
+ link,
+ "",
+ gettext(u"If you think this mail is not for you, please ignore and delete it."),
+ gettext(u"For more informations, you can contact:"),
+ EMAIL
+ ), "\r\n")
+ server = smtplib.SMTP(SMTP_SERVER)
+ server.sendmail(EMAIL, [user['email']], BODY.encode('utf-8'))
+ server.quit()
+ else:
+ flash(u'Vous devez proposer au moins un choix pour ouvrir le vote.', 'error')
+ elif request.form['status'] == u'Terminé':
+ isterminated = 1
+ if vote['is_open']:
+ isopen = 1
+ g.db.execute('update votes set title = ?, description = ?, category = ?, quorum = ?, \
+ is_transparent = ?, is_public = ?, is_open = ?, is_terminated = ?, \
+ date_end = ?, reminder_last_days = ? where id = ?',
+ [ request.form['title'], request.form['description'], request.form['category'], request.form['quorum']
+ , transparent, public, isopen, isterminated, date_end, request.form['reminder'], 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')
+ vote['duration'] = (datetime.strptime(vote['date_end'], "%Y-%m-%d") - datetime.strptime(vote['date_begin'], "%Y-%m-%d")).days
+ group = query_db('select name from groups where id = ?', [vote['id_group']], one=True)
+ choices = query_db('select * from choices where id_vote = ?', [voteid])
+ values_ = query_db('select * from cardinals where id = ?', [vote['id_cardinal']], one=True)['name']
+ attachments = query_db('select * from attachments where id_vote = ?', [voteid])
+ if date.today().strftime("%Y-%m-%d") > vote['date_end'] and not vote['is_terminated']:
+ flash(u'La deadline du vote est expirée, vous devriez terminer le vote.')
+ return render_template('admin_vote_edit.html', vote=vote, group=group, values_=values_, choices=choices, attachments=attachments, quorums=QUORUMS)
+
+@app.route('/admin/votes/delete/<idvote>')
+def admin_vote_del(idvote):
+ if not session.get('user').get('is_admin'):
+ abort(401)
+ if not CAN_DELETE_VOTES:
+ flash(u'La configuration interdit la suppression des votes.', 'error')
+ else:
+ if vote is None:
+ abort(404)
+ g.db.execute('update votes set is_hidden=1 where id = ?', [idvote])
+ g.db.commit()
+ return redirect(url_for('admin_votes'))
+
+@app.route('/admin/votes/addchoice/<voteid>', methods=['POST'])
+def admin_vote_addchoice(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])