mirror of
https://framagit.org/tykayn/date-poll-api
synced 2023-08-25 08:23:11 +02:00
Compare commits
6 Commits
f5a154b20e
...
f2edaa49f0
Author | SHA1 | Date | |
---|---|---|---|
f2edaa49f0 | |||
5716642c09 | |||
afef8edd0b | |||
623b16a046 | |||
9a1b8c90a4 | |||
03cba297d5 |
8
config/packages/dev/mailer.yaml
Normal file
8
config/packages/dev/mailer.yaml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# config/packages/dev/mailer.yaml
|
||||||
|
framework:
|
||||||
|
mailer:
|
||||||
|
envelope:
|
||||||
|
sender: 'noreply@tktest.com'
|
||||||
|
recipients: ['tykayn@pm.me']
|
||||||
|
headers:
|
||||||
|
from: 'dev framadate funky <noreply@tktest.com>'
|
@ -1,6 +1,6 @@
|
|||||||
# see https://symfony.com/doc/current/reference/configuration/framework.html
|
# see https://symfony.com/doc/current/reference/configuration/framework.html
|
||||||
framework:
|
framework:
|
||||||
trusted_hosts: ['localhost:4200', 'localhost', 'tktest.lan', 'framadate-api.cipherbliss.com']
|
trusted_hosts: ['localhost:4200', 'localhost', 'tktest.lan', '127.0.0.1', 'framadate-api.cipherbliss.com']
|
||||||
secret: '%env(APP_SECRET)%'
|
secret: '%env(APP_SECRET)%'
|
||||||
#csrf_protection: true
|
#csrf_protection: true
|
||||||
#http_method_override: true
|
#http_method_override: true
|
||||||
|
31
migrations/Version20210518212646.php
Normal file
31
migrations/Version20210518212646.php
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace DoctrineMigrations;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Schema\Schema;
|
||||||
|
use Doctrine\Migrations\AbstractMigration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Auto-generated Migration: Please modify to your needs!
|
||||||
|
*/
|
||||||
|
final class Version20210518212646 extends AbstractMigration
|
||||||
|
{
|
||||||
|
public function getDescription() : string
|
||||||
|
{
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function up(Schema $schema) : void
|
||||||
|
{
|
||||||
|
// this up() migration is auto-generated, please modify it to your needs
|
||||||
|
$this->addSql('ALTER TABLE poll ADD is_zero_knowledge TINYINT(1) DEFAULT NULL');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function down(Schema $schema) : void
|
||||||
|
{
|
||||||
|
// this down() migration is auto-generated, please modify it to your needs
|
||||||
|
$this->addSql('ALTER TABLE poll DROP is_zero_knowledge');
|
||||||
|
}
|
||||||
|
}
|
@ -9,7 +9,6 @@ use Swift_Mailer;
|
|||||||
use Swift_Message;
|
use Swift_Message;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\Mailer\Exception\TransportExceptionInterface;
|
use Symfony\Component\Mailer\Exception\TransportExceptionInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* sending emails controller
|
* sending emails controller
|
||||||
*
|
*
|
||||||
@ -83,7 +82,7 @@ class EmailsController extends AbstractController {
|
|||||||
$message = ( new Swift_Message( $config[ 'title' ] ) )
|
$message = ( new Swift_Message( $config[ 'title' ] ) )
|
||||||
->setContentType( "text/html" )
|
->setContentType( "text/html" )
|
||||||
->setCharset( 'UTF-8' )
|
->setCharset( 'UTF-8' )
|
||||||
->setFrom( [ 'ne-pas-repondre@framadate-api.cipherbliss.com' ] )
|
->setFrom( [ 'ne-pas-repondre@framadate-api.cipherbliss.com'] )
|
||||||
->setTo( [ $config[ 'owner' ]->getEmail() ] )
|
->setTo( [ $config[ 'owner' ]->getEmail() ] )
|
||||||
->setBody( $htmlbody, 'text/html' );
|
->setBody( $htmlbody, 'text/html' );
|
||||||
|
|
||||||
|
@ -97,10 +97,10 @@ class MigrationController extends EmailsController {
|
|||||||
$moments = explode( ',', $d->moments );
|
$moments = explode( ',', $d->moments );
|
||||||
foreach ( $moments as $moment ) {
|
foreach ( $moments as $moment ) {
|
||||||
$newChoice = new Choice();
|
$newChoice = new Choice();
|
||||||
|
$dateOfDay = date_create( strtotime( $d->title ) );
|
||||||
$newChoice
|
$newChoice
|
||||||
->setPoll( $poll )
|
->setPoll( $poll )
|
||||||
->setDateTime( date_create( strtotime( $d->title ) ) )
|
->setName( $dateOfDay->format('y-m-d'). ' >>> ' . $moment );
|
||||||
->setName( $moment );
|
|
||||||
|
|
||||||
$pollChoicesOrderedBySlug[ $pollSlug ][] = $newChoice;
|
$pollChoicesOrderedBySlug[ $pollSlug ][] = $newChoice;
|
||||||
$poll->addChoice( $newChoice );
|
$poll->addChoice( $newChoice );
|
||||||
|
@ -240,9 +240,17 @@ class PollController extends EmailsController {
|
|||||||
$data = $request->getContent();
|
$data = $request->getContent();
|
||||||
$data = json_decode( $data, true );
|
$data = json_decode( $data, true );
|
||||||
|
|
||||||
|
// search for existing custom url, which must be unique
|
||||||
|
$custom_url = $data[ 'custom_url' ];
|
||||||
|
$repository = $this->getDoctrine()->getRepository( Poll::class );
|
||||||
|
$poll = $repository->findOneByCustomUrl( $custom_url );
|
||||||
|
if ( $poll ) {
|
||||||
|
throw new \JsonException( 'NOPE, ce sondage existe déjà: ' . $custom_url );
|
||||||
|
}
|
||||||
|
|
||||||
$newpoll = new Poll();
|
$newpoll = new Poll();
|
||||||
$newpoll
|
$newpoll
|
||||||
->setModificationPolicy( $data[ 'modification_policy' ] )
|
->setModificationPolicy( isset( $data[ 'modification_policy' ] ) ? $data[ 'modification_policy' ] : 'everybody' )
|
||||||
->setTitle( $data[ 'title' ] )
|
->setTitle( $data[ 'title' ] )
|
||||||
->setKind( $data[ 'kind' ] )
|
->setKind( $data[ 'kind' ] )
|
||||||
->setCustomUrl( $data[ 'custom_url' ] );
|
->setCustomUrl( $data[ 'custom_url' ] );
|
||||||
@ -294,17 +302,18 @@ class PollController extends EmailsController {
|
|||||||
if ( $data[ 'password' ] ) {
|
if ( $data[ 'password' ] ) {
|
||||||
$newpoll->setPassword( $data[ 'password' ] );
|
$newpoll->setPassword( $data[ 'password' ] );
|
||||||
}
|
}
|
||||||
// manage choices
|
|
||||||
// text kind of answers, dates are below
|
// text kind of answers, dates are below
|
||||||
if ( $data[ 'kind' ] == 'text' ) {
|
if ( $data[ 'kind' ] == 'text' ) {
|
||||||
|
// manage choices
|
||||||
$choices = $data[ 'dateChoices' ];
|
$choices = $data[ 'choices' ];
|
||||||
foreach ( $choices as $c ) {
|
foreach ( $choices as $c ) {
|
||||||
$newChoice = new Choice();
|
$newChoice = new Choice();
|
||||||
$newChoice
|
$newChoice
|
||||||
->setPoll( $newpoll )
|
->setPoll( $newpoll )
|
||||||
->setName( $c[ 'literal' ] );
|
->setName( $c[ 'literal' ] );
|
||||||
$em->persist( $newChoice );
|
$em->persist( $newChoice );
|
||||||
|
$newpoll->addChoice( $newChoice );
|
||||||
}
|
}
|
||||||
} // date kind of poll
|
} // date kind of poll
|
||||||
elseif ( $data[ 'kind' ] == 'date' ) {
|
elseif ( $data[ 'kind' ] == 'date' ) {
|
||||||
@ -316,7 +325,7 @@ class PollController extends EmailsController {
|
|||||||
foreach ( $choices as $c ) {
|
foreach ( $choices as $c ) {
|
||||||
$currentDate = $c[ 'literal' ];
|
$currentDate = $c[ 'literal' ];
|
||||||
|
|
||||||
$timeSlicesOfThisChoice = $c[ 'timeList' ];
|
$timeSlicesOfThisChoice = $c[ 'timeSlices' ];
|
||||||
foreach ( $timeSlicesOfThisChoice as $t ) {
|
foreach ( $timeSlicesOfThisChoice as $t ) {
|
||||||
|
|
||||||
$newChoice = new Choice();
|
$newChoice = new Choice();
|
||||||
@ -324,14 +333,16 @@ class PollController extends EmailsController {
|
|||||||
->setPoll( $newpoll )
|
->setPoll( $newpoll )
|
||||||
->setName( $currentDate . ' >>> ' . $t[ 'literal' ] );
|
->setName( $currentDate . ' >>> ' . $t[ 'literal' ] );
|
||||||
$em->persist( $newChoice );
|
$em->persist( $newChoice );
|
||||||
|
$newpoll->addChoice( $newChoice );
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// all choices will be having the same time slices from timeSlices
|
// all choices will be having the same time slices from timeSlices
|
||||||
$timeSlicesForAllChoices = $data[ 'timeSlices' ];
|
$timeSlicesForAllChoices = $data[ 'timeSlices' ];
|
||||||
foreach ( $choices as $c ) {
|
foreach ( $choices as $c ) {
|
||||||
$currentDate = $c[ 'literal' ];
|
$currentDate = $c[ 'date_object' ];
|
||||||
|
|
||||||
foreach ( $timeSlicesForAllChoices as $t ) {
|
foreach ( $timeSlicesForAllChoices as $t ) {
|
||||||
|
|
||||||
@ -340,6 +351,7 @@ class PollController extends EmailsController {
|
|||||||
->setPoll( $newpoll )
|
->setPoll( $newpoll )
|
||||||
->setName( $currentDate . ' >>> ' . $t[ 'literal' ] );
|
->setName( $currentDate . ' >>> ' . $t[ 'literal' ] );
|
||||||
$em->persist( $newChoice );
|
$em->persist( $newChoice );
|
||||||
|
$newpoll->addChoice( $newChoice );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -347,7 +359,6 @@ class PollController extends EmailsController {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$em->persist( $newpoll );
|
$em->persist( $newpoll );
|
||||||
@ -359,8 +370,11 @@ class PollController extends EmailsController {
|
|||||||
|
|
||||||
$this->sendCreationMailAction( $foundOwner, $newpoll );
|
$this->sendCreationMailAction( $foundOwner, $newpoll );
|
||||||
|
|
||||||
|
$newChoices = $newpoll->display()[ 'choices' ];
|
||||||
|
|
||||||
return $this->json( [
|
return $this->json( [
|
||||||
'message' => 'you created a poll ' . $precision,
|
'message' => 'you created the poll ' . $newpoll->getCustomUrl() . $precision,
|
||||||
|
'id' => $newpoll->getId(),
|
||||||
'poll' => $newpoll->displayForAdmin(),
|
'poll' => $newpoll->displayForAdmin(),
|
||||||
'password_protected' => is_string( $newpoll->getPassword() ),
|
'password_protected' => is_string( $newpoll->getPassword() ),
|
||||||
|
|
||||||
@ -388,19 +402,34 @@ class PollController extends EmailsController {
|
|||||||
public function testSendCreationMailAction(
|
public function testSendCreationMailAction(
|
||||||
$emailChoice = 'tktest_commentateur@tktest.com'
|
$emailChoice = 'tktest_commentateur@tktest.com'
|
||||||
) {
|
) {
|
||||||
|
$em = $this->getDoctrine()->getRepository( Poll::class );
|
||||||
|
$foundPoll = $em->findOneByCustomUrl( 'dessin-anime' );
|
||||||
$em = $this->getDoctrine()->getRepository( Owner::class );
|
$em = $this->getDoctrine()->getRepository( Owner::class );
|
||||||
$foundOwner = $em->findOneByEmail( $emailChoice );
|
$foundOwner = $em->findOneByEmail( $emailChoice );
|
||||||
if ( $foundOwner ) {
|
|
||||||
$poll = $foundOwner->getPolls()[ 0 ];
|
|
||||||
$comment = $foundOwner->getComments()[ 0 ];
|
|
||||||
|
|
||||||
$sent = $this->sendOwnerPollsAction( $foundOwner );
|
return $this->render( 'emails/creation-mail.html.twig',
|
||||||
if ( $sent ) {
|
[ 'poll' => $foundPoll, 'owner' => $foundPoll->getOwner() ] );
|
||||||
return $this->json( [ "message" => "test email sent to " . $foundOwner->getEmail() . "!" ], 200 );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->json( [ "message" => "user with this email was not found" ], 400 );
|
|
||||||
|
// if ( $foundOwner ) {
|
||||||
|
// $sent = $this->sendOwnerPollsAction( $foundOwner );
|
||||||
|
// if ( $sent ) {
|
||||||
|
// $config = [
|
||||||
|
// 'owner' => $foundOwner,
|
||||||
|
// 'title' => $this->getParameter( 'WEBSITE_NAME' ) . ' | Mes sondages',
|
||||||
|
// 'email_template' => 'emails/owner-list.html.twig',
|
||||||
|
// ];
|
||||||
|
// return $this->render( 'emails/owner-list.html.twig', $config );
|
||||||
|
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// return $this->json( [ "message" => "test email sent to " . $foundOwner->getEmail() . "!" ], 200 );
|
||||||
|
|
||||||
|
// $this->sendMailWithVars( $config );
|
||||||
|
|
||||||
|
|
||||||
|
// return $this->json( [ "message" => "user with this email was not found" ], 400 );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,17 +44,25 @@ class VoteController extends EmailsController {
|
|||||||
string $custom_url,
|
string $custom_url,
|
||||||
Request $request,
|
Request $request,
|
||||||
ChoiceRepository $choice_repository
|
ChoiceRepository $choice_repository
|
||||||
) {
|
) {
|
||||||
|
|
||||||
|
|
||||||
|
/***
|
||||||
|
* checks before persisting
|
||||||
|
*/
|
||||||
$em = $this->getDoctrine()->getManager();
|
$em = $this->getDoctrine()->getManager();
|
||||||
$emPol = $em->getRepository( Poll::class );
|
$emPol = $em->getRepository( Poll::class );
|
||||||
$poll = $emPol->findOneByCustomUrl( $custom_url );
|
$poll = $emPol->findOneByCustomUrl( $custom_url );
|
||||||
|
|
||||||
|
// check : existence of poll
|
||||||
if ( ! $poll ) {
|
if ( ! $poll ) {
|
||||||
return $this->json( [ 'message' => 'poll "' . $custom_url . '" not found' ], 404 );
|
return $this->json( [ 'message' => 'poll "' . $custom_url . '" not found' ], 404 );
|
||||||
}
|
}
|
||||||
|
// check : limit of number of participation max
|
||||||
|
if ( count( $poll->getStacksOfVotes() ) == $poll->getVotesMax() ) {
|
||||||
|
return $this->json( [ 'message' => 'poll "' . $custom_url . '" not allowed to have more stack of votes than ' . $poll->getVotesMax() ],
|
||||||
|
403 );
|
||||||
|
}
|
||||||
$data = $request->getContent();
|
$data = $request->getContent();
|
||||||
$data = json_decode( $data, true );
|
$data = json_decode( $data, true );
|
||||||
|
|
||||||
@ -63,32 +71,30 @@ class VoteController extends EmailsController {
|
|||||||
|
|
||||||
$owner = new Owner();
|
$owner = new Owner();
|
||||||
$owner
|
$owner
|
||||||
->addPoll( $poll )
|
->addPoll( $poll );
|
||||||
|
|
||||||
;
|
|
||||||
$newStack = new StackOfVotes();
|
$newStack = new StackOfVotes();
|
||||||
$newStack
|
$newStack
|
||||||
->setPoll($poll)
|
->setPoll( $poll )
|
||||||
->setIp( $_SERVER[ 'REMOTE_ADDR' ] )
|
->setIp( $_SERVER[ 'REMOTE_ADDR' ] )
|
||||||
->setPseudo( $data[ "pseudo" ] )
|
->setPseudo( $data[ "pseudo" ] )
|
||||||
->setOwner( $owner );
|
->setOwner( $owner );
|
||||||
$owner
|
$owner
|
||||||
->setPseudo($data['owner'][ "pseudo" ])
|
->setPseudo( $data[ 'owner' ][ "pseudo" ] )
|
||||||
->setPseudo($data['owner'][ "email" ])
|
->setPseudo( $data[ 'owner' ][ "email" ] )
|
||||||
->addStackOfVote($newStack);
|
->addStackOfVote( $newStack );
|
||||||
|
|
||||||
// TODO manage new comment
|
// TODO manage new comment
|
||||||
$emChoice = $choice_repository;
|
$emChoice = $choice_repository;
|
||||||
$newComment = new Comment();
|
$newComment = new Comment();
|
||||||
$newComment->setPseudo($data ['pseudo'])
|
$newComment->setPseudo( $data [ 'pseudo' ] )
|
||||||
->setPoll($poll)
|
->setPoll( $poll )
|
||||||
->setText($data['comment']);
|
->setText( $data[ 'comment' ] );
|
||||||
$owner->addComment($newComment);
|
$owner->addComment( $newComment );
|
||||||
|
|
||||||
$em->persist($newComment);
|
$em->persist( $newComment );
|
||||||
|
|
||||||
foreach ( $data[ 'votes' ] as $vote ) {
|
foreach ( $data[ 'votes' ] as $vote ) {
|
||||||
if(!$vote[ 'value' ]){
|
if ( ! $vote[ 'value' ] ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$newVote = new Vote();
|
$newVote = new Vote();
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -9,9 +9,9 @@
|
|||||||
<header>
|
<header>
|
||||||
{% block title %}
|
{% block title %}
|
||||||
{% if title is defined %}
|
{% if title is defined %}
|
||||||
<h1>{{ title }}</h1>
|
<h1 class="text-center">{{ title }}</h1>
|
||||||
{% else %}
|
{% else %}
|
||||||
<h1>Framadate - email</h1>
|
<h1 class="text-center">Framadate</h1>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<hr>
|
<hr>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
@ -30,6 +30,9 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
<style type="text/css">
|
<style type="text/css">
|
||||||
|
.text-center{
|
||||||
|
text-align:center;
|
||||||
|
}
|
||||||
html, body, main, header, footer, div {
|
html, body, main, header, footer, div {
|
||||||
font-family: "Open Sans", "Helvetica Neue", sans-serif;
|
font-family: "Open Sans", "Helvetica Neue", sans-serif;
|
||||||
}
|
}
|
||||||
|
@ -2,12 +2,12 @@
|
|||||||
{% extends 'email-base.html.twig' %}
|
{% extends 'email-base.html.twig' %}
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
|
||||||
|
<h1>✨ Création de votre sondage {{ poll.title }} </h1>
|
||||||
Suite à la création de votre sondage {{ title }} vous recevez deux emails afin de ne pas transmettre par erreur aux sondés le lien d'administration de votre sondage.
|
Suite à la création de votre sondage <strong>{{ poll.title }}</strong> vous recevez deux emails afin de ne pas transmettre par erreur aux sondés le lien d'administration de votre sondage.
|
||||||
<br>
|
<br>
|
||||||
Ce mail est le premier, comportant le message qui doit être envoyé aux sondés.<br>
|
Ce mail est le premier, comportant le message qui doit être envoyé aux sondés.<br>
|
||||||
|
|
||||||
Vous pouvez maintenant transmettre ce message à toutes les personnes susceptibles de participer au vote.<br>
|
Vous pouvez maintenant transmettre ce message à toutes les personnes susceptibles de participer au vote. ✔️ <br>
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
@ -15,7 +15,7 @@
|
|||||||
<blockquote>
|
<blockquote>
|
||||||
<i>
|
<i>
|
||||||
|
|
||||||
{{ owner.pseudo }} ( {{ owner.email }} ) vient de créer un sondage intitulé : " <strong>{{ title }}
|
💡 {{ owner.pseudo }} ( {{ owner.email }} ) vient de créer un sondage intitulé : " <strong>{{ poll.title }}
|
||||||
"</strong>.
|
"</strong>.
|
||||||
<br>
|
<br>
|
||||||
<br>
|
<br>
|
||||||
|
@ -3,13 +3,17 @@
|
|||||||
{% block content %}
|
{% block content %}
|
||||||
|
|
||||||
|
|
||||||
Ce sondage va bientôt expirer dans 1 jour, <br>
|
<h1> 🎌 Votre sondage {{ poll.title }} va bientôt expirer dans 1 jour,</h1>
|
||||||
<blockquote>
|
<blockquote>
|
||||||
le {{ poll.expiracyDate | date('D Y-m-d') }}
|
le {{ poll.expiracyDate | date('D Y-m-d') }} :
|
||||||
</blockquote>
|
</blockquote>
|
||||||
il ne sera plus possible d'y voter. <br>
|
il ne sera plus possible d'y voter. <br>
|
||||||
Dans 31 jours il sera supprimé.<br>
|
Dans 31 jours il sera supprimé.<br>
|
||||||
Vous pouvez exporter ses données à tout moment en vous rendant à ce lien pour l'administrer:
|
Vous pouvez exporter ses données à tout moment en vous rendant à ce lien pour l'administrer:
|
||||||
<br>
|
<br>
|
||||||
{% include 'emails/partial/admin_link.html.twig' %}
|
{% include 'emails/partial/admin_link.html.twig' %}
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
Plus de détails sur votre sondage :
|
||||||
|
{% include 'emails/partial/poll.html.twig' %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@ -13,10 +13,10 @@
|
|||||||
<a href="https://framagit.org/framasoft/framadate/funky-framadate-front">
|
<a href="https://framagit.org/framasoft/framadate/funky-framadate-front">
|
||||||
Sources du client Front end,
|
Sources du client Front end,
|
||||||
</a>
|
</a>
|
||||||
<a href="https://framagit.org/framasoft/framadate/framadate">
|
<a href="https://framagit.org/tykayn/date-poll-api">
|
||||||
API back end.
|
API back end.
|
||||||
</a>
|
</a>
|
||||||
<a href="https://framagit.org/framasoft/framadate/funky-framadate-front/-/wikis/home">
|
<a href="https://framagit.org/framasoft/framadate/funky-framadate-front/docs">
|
||||||
Documentation
|
Documentation
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
|
@ -1,2 +1 @@
|
|||||||
<a href="{{ BASE_URL }}/#/poll/{{ poll.id }}/admin/{{ poll.adminKey }}">{{ BASE_URL }}
|
<a href="{{ BASE_URL }}/#/poll/{{ poll.customUrl }}/admin/{{ poll.adminKey }}">{{ BASE_URL }}/#/poll/{{ poll.customUrl }}/admin/{{ poll.adminKey }}</a>
|
||||||
/admin/{{ poll.adminKey }}</a>
|
|
||||||
|
@ -2,11 +2,9 @@
|
|||||||
<h1>
|
<h1>
|
||||||
Sondage {{ poll.title }}
|
Sondage {{ poll.title }}
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<div class="creation">
|
<div class="creation">
|
||||||
créé le {{ poll.creationDate| date('Y m d ') }}
|
créé le {{ poll.createdAt| date('Y m d ') }}
|
||||||
</div>
|
</div>
|
||||||
<div class="creation">
|
<div class="creation">
|
||||||
expirera le {{ poll.expiracyDate| date('Y m d ') }}
|
expirera le {{ poll.expiracyDate| date('Y m d ') }}
|
||||||
@ -18,22 +16,29 @@
|
|||||||
{{ poll.comments |length }} commentaires
|
{{ poll.comments |length }} commentaires
|
||||||
</span>
|
</span>
|
||||||
{% if poll.password |length %}
|
{% if poll.password |length %}
|
||||||
(accès avec mot de passe)
|
<div class="protected">
|
||||||
|
🔐 (accès avec mot de passe)
|
||||||
|
</div>
|
||||||
|
{% else %}
|
||||||
|
{% endif %}
|
||||||
|
{% if poll.isZeroKnowledge |length %}
|
||||||
|
<div class="protected-zero-knoledge">
|
||||||
|
🔐 Ce sondage bénéficie du chiffrement Zéro knowledge, nos administrateurs ne sont pas en mesure de connaître les informations du sondage.
|
||||||
|
</div>
|
||||||
{% else %}
|
{% else %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
<div class="public">
|
<div class="public">
|
||||||
<span>
|
<div>
|
||||||
lien à donner aux votants:
|
lien à donner aux votants:
|
||||||
</span>
|
</div>
|
||||||
{% include 'emails/partial/public_link.html.twig' %}
|
{% include 'emails/partial/public_link.html.twig' %}
|
||||||
</div>
|
</div>
|
||||||
<div class="admin">
|
<div class="admin">
|
||||||
<span>
|
<div>
|
||||||
administration:
|
administration:
|
||||||
</span>
|
</div>
|
||||||
{% include 'emails/partial/admin_link.html.twig' %}
|
{% include 'emails/partial/admin_link.html.twig' %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
<span class="public-link">
|
<span class="public-link">
|
||||||
{% if poll.customUrl |length %}
|
{% if poll.customUrl |length %}
|
||||||
<a href="{{ BASE_URL }}/#/vote/poll/key/{{ poll.customUrl }}">
|
<a href="{{ BASE_URL }}/#/poll/{{ poll.customUrl }}/consultation">
|
||||||
{{ BASE_URL }}/#/vote/poll/key/{{ poll.customUrl }}
|
|
||||||
|
✉️ {{ BASE_URL }}/#/poll/{{ poll.customUrl }}/consultation
|
||||||
</a>
|
</a>
|
||||||
{% else %}
|
{% else %}
|
||||||
<a href="{{ BASE_URL }}/#/vote/poll/id/{{ poll.id }}">
|
erreur, il manque la customUrl de ce sondage.
|
||||||
{{ BASE_URL }}/#/vote/poll/id/{{ poll.id }}
|
|
||||||
</a>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</span>
|
</span>
|
||||||
|
Loading…
Reference in New Issue
Block a user