Cabina de votaciones - 17 18 - G2

De Wiki de EGC
Revisión del 11:49 8 dic 2017 de Ignalelop (discusión | contribuciones) (Decisiones de diseño: Cambiado el formato del voto cifrado para que sea consistente con los últimos cambios de la API)
Saltar a: navegación, buscar

Objetivo del subsistema

Permitir la votación para las distintas votaciones disponibles en el sistema.

Consideraciones

Resumen del trabajo

Nuestro trabajo consistirá en realizar el apartado de cabina de votación que consiste en permitir mediante el uso de un conjunto de métodos la posibilidad de que los usuarios puedan votar anónimamente teniendo en cuenta las restricciones posibles que puedan existir.

Objetivo del subsistema

Nuestro trabajo consistirá en realizar el apartado de cabina de votación que consiste en permitir mediante el uso de un conjunto de métodos la posibilidad de que los usuarios puedan votar anónimamente teniendo en cuenta las restricciones posibles que puedan existir.

Tecnologías que se usarán: Subsistema: Cabina de votación
Lenguaje/Herramienta: Node.js 9.2 (Javascript v8)
Bibliotecas:
- restify: 6.3.4
- rest: 2.0.0
- lodash: 4.17.4
- async: 2.6.0
- js-base64: 2.4.0
Sistema de gestión de bibliotecas: npm
Base de datos: No (Aunque es necesaria alguna forma de verificar los votos a partir del usuario encriptado).

APIs y datos que se usarán y devolverán

Estructura de un voto:

id_user: (int) identificador del usuario que ha votado, es única y es posible verificar el voto [unique, not null]
id_election: (int) identificador de la votación [fk, not null]
encrypted_answers: (string) es un string con el contenido de la votación cifrado.

Consulta de permisos de voto Tipo: GET
URL: http://egc-cabina.es/api/check/vote.json?user=x&election=y
Parámetros:

           user: Nombre de usuario al que comprobar si puede votar
           election: Identificador de la votación a comprobar

Formato JSON Ejemplo, usuario "user" puede votar en "election":

   {
       "result": true,
       "reason": "can_vote"
   }

Otras consideraciones: "reason" determina la razón de por qué no puede votar y pueden ser alguno de los siguientes:

- "can_vote" El usuario puede votar.
- "already_voted" El usuario ha realizado su voto y la votación es de un sólo voto, por lo tanto no podrá votar.
- "cant_vote" El usuario no pertenece a un grupo de votación.
- "user_not_found" El usuario introducido no existe.
- "election_not_found" La votación introducida no existe.
- "election_not_open" La votación no ha abierto todavía el plazo de votación.

Creación de voto: Tipo: POST URL: http://egc-cabina.es/api/create/vote.json Parámetros:

           id_user: (int) Identificador del usuario (sin encriptar)
           id_election: (int) Identificador de la votación
           answers: (list[(int,string)]) Lista que contendrá el par question_id, que es el identificador de la pregunta como int, y answer, que es la respuesta del usuario. La representación de cada par sería la siguiente:
           {
               "question_id": 0,
               "answer": "..."
           }

Formato JSON Ejemplo: Creando un voto por el usuario 23, la votación 34, el grupo de usuarios 13. Se debe enviar:

   {
       "id_user": 23,
       "id_election": 34,
       "answers": [
           {
               "question_id": 0,
               "answer": "Algo"
           },
           {
               "question_id": 1,
               "answer": "Sí"
           }
        ]
   }

La respuesta a esta petición será:

   {
       "result": true,
       "vote": {
           "id_user": 23,
           "id_election": 34,
           "encrypted_answers": "ot7yfg913..."
       }
   }

Plantillas HTML

Se tiene pensado que el formato de la cabina de votación sea el siguiente:

Votación de la pregunta X

   {% block body %}
   <hX>{% election.nombre %}</hX>
<\hr/>
<\p>{% election.descripcion %}<\/p>
<\hr/>
{% for question in election.preguntas %} <\p>Pregunta {% question.nombre %}<\/p>
<\span>{% question.descripcion %}<\/span>
{% if question.tipo_pregunta == "Cerrada"
{% for answer in question.respuestas %}
<select>
<option value="{% answer.seleccionada %}">{% answer.texto_pregunta %}
</select>
{% endfor %} {% if question.tipo_pregunta == "Abierta" %}
<label...>{% question.texto_pregunta %}</label>
<input value="{% question.answers[0].texto_respuesta" />
{% endif %} {% endif %} {% endfor %} <\hr/>
<button>Siguiente pregunta</button>

Final de la votación de la encuesta

   {% block body %}
   <hX>{% election.nombre %}</hX>
<\hr/>
<\p>{% election.descripcion %}<\/p>
<\hr/>
<\p>Gracias por responder a {% election.nombre %}<\/p>
<button>Finalizar</button>

Código de respuesta del servidor HTTP

Para nuestra API, hemos definido los siguientes códigos de respuestas del servidor HTTP:

Código Valor result Valor msg Posible motivo
200 true Successfull El usuario ha realizado correctamente el voto
404 false User not found El usuario no ha realizado correctamente el voto
403 false Don't have access El usuario ha realizado correctamente el voto pero no tiene los permisos necesarios para el procesamiento de su voto

Decisiones de diseño

Cifrado de los votos Para el cifrado de los votos, se seguirá el siguiente criptosistema. Primero, se recogerá la representación en JSON del voto, siguiendo el siguiente formato:

[ 
    {
        "question_id": <id_de_la_pregunta>,
        "answer": "<respuesta_a_la_pregunta>" 
    },
    { 
        ... 
    }
]

Después, se cifrará el contenido de éste JSON a base64, usando como encodificado UTF-8. Finalmente, se recogerá la clave de cifrado de la votación y se aplicará el cifrado XOR, aplicando XOR a la clave y el string en base64 antes mencionado.