Diferencia entre revisiones de «Administración de censos - 17 18 - G2»
Línea 31: | Línea 31: | ||
− | === | + | === Obtención de un censo === |
---- | ---- | ||
− | Se hace una petición | + | Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información. |
+ | |||
+ | '''URL:''' | ||
+ | http://egc-censos1718.es/api/get/censo.json | ||
+ | |||
+ | '''Parámetros:''' | ||
+ | * id: Identificador del censo a obtener. | ||
+ | |||
+ | '''Ejemplo:''' | ||
+ | GET http://egc-censos1718.es/api/create/censo.json?id=1 | ||
+ | |||
+ | '''Formato JSON:''' | ||
+ | { | ||
+ | "censo": { | ||
+ | "id": "1", | ||
+ | "id_votacion": "314", | ||
+ | "id_grupo": "3", | ||
+ | "nombre": "Censo_de_prueba", | ||
+ | "fecha_ini": "24/11/2017 16:00", | ||
+ | "fecha_fin": "30/11/2017 23:59" | ||
+ | } | ||
+ | } | ||
+ | |||
+ | |||
+ | === Obtención de un censo === | ||
+ | |||
+ | ---- | ||
+ | |||
+ | Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información. | ||
'''URL:''' | '''URL:''' | ||
− | http://egc-censos1718.es/api/ | + | http://egc-censos1718.es/api/get/censo.json |
'''Parámetros:''' | '''Parámetros:''' | ||
− | * | + | * id: Identificador del censo a obtener. |
− | + | ||
− | |||
− | |||
− | |||
− | |||
'''Ejemplo:''' | '''Ejemplo:''' | ||
− | + | GET http://egc-censos1718.es/api/get/censo.json?id=1 | |
'''Formato JSON:''' | '''Formato JSON:''' | ||
{ | { | ||
− | + | "censo": { | |
− | |||
− | |||
"id": "1", | "id": "1", | ||
"id_votacion": "314", | "id_votacion": "314", | ||
Línea 61: | Línea 83: | ||
"fecha_ini": "24/11/2017 16:00", | "fecha_ini": "24/11/2017 16:00", | ||
"fecha_fin": "30/11/2017 23:59" | "fecha_fin": "30/11/2017 23:59" | ||
+ | } | ||
+ | } | ||
+ | |||
+ | |||
+ | |||
+ | === Consulta de censos === | ||
+ | |||
+ | ---- | ||
+ | |||
+ | Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información. | ||
+ | Funcionalidad más útil para los otros subsistemas que componen el sistema de votación, pues permitirá obtener resultados a partir de parámetros (si un usuario perteneciente a un grupo puede votar en x votación, qué grupos pueden votar en x votación, etc) | ||
+ | |||
+ | '''URL:''' | ||
+ | http://egc-censos1718.es/api/filter/result.json | ||
+ | |||
+ | '''Parámetros:''' | ||
+ | * id_votacion (opcional): Identificador de la votación de los censos a consultar. | ||
+ | * id_grupo (opcional): Identificador del grupo de usuarios con acceso al censo. | ||
+ | * nombre (opcional): Nombre del censo. | ||
+ | * fecha_ini (opcional): dd/mm/yyyy hh:mm Fecha de inicio del censo a filtrar. | ||
+ | * fecha_fin (opcional): dd/mm/yyyy hh:mm Fecha de fin del censo a filtrar | ||
+ | Todos los parámetros deberán ir '''correctamente parseados en el formato URL''' (ya que así será traducido e interpretado) | ||
+ | |||
+ | '''Ejemplo:''' | ||
+ | GET http://egc-censos1718.es/api/filter/censos.json?id_votacion=314 | ||
+ | |||
+ | '''Formato JSON:''' | ||
+ | { | ||
+ | "censos": { | ||
+ | "censo1": { | ||
+ | "id": "1", | ||
+ | "id_votacion": "314", | ||
+ | "id_grupo": "3", | ||
+ | "fecha_ini": "24/11/2017 16:00", | ||
+ | "fecha_fin": "30/11/2017 23:59" | ||
+ | }, | ||
+ | "censo2": { | ||
+ | "id": "2", | ||
+ | "id_votacion": "314", | ||
+ | "id_grupo": "25", | ||
+ | "fecha_ini": "19/12/2017 16:00", | ||
+ | "fecha_fin": "30/01/2018 23:59" | ||
+ | } | ||
} | } | ||
} | } | ||
Línea 71: | Línea 136: | ||
'''URL:''' | '''URL:''' | ||
− | http://egc-censos1718.es/api/update/ | + | http://egc-censos1718.es/api/update/result.json |
'''Parámetros:''' | '''Parámetros:''' | ||
Línea 84: | Línea 149: | ||
'''Ejemplo:''' | '''Ejemplo:''' | ||
− | POST http://egc-censos1718.es/api/update/ | + | POST http://egc-censos1718.es/api/update/result.json?id=1&nombre=Censo_de_prueba_editado |
'''Formato JSON:''' | '''Formato JSON:''' |
Revisión del 18:17 24 nov 2017
Contenido
Objetivo del subsistema
- Gestionar lista de usuarios agrupados en quienes pueden votar o no en una determinada votación.
- Crear nuevos censos cada vez que se genere una determinada votación.
Consideraciones
- Repositorio del proyecto del año pasado: https://github.com/AgoraUS-G1-1617/CensoEGC
- Repositorio del proyecto actual: https://github.com/EGC-G2-Trabajo-1718/egc-censos
- Wiki del proyecto actual (wiki interna de github para uso interno del grupo): https://github.com/EGC-G2-Trabajo-1718/egc-censos/wiki
- ¿Dependencias con el grupo de autenticación / registro / administración de votaciones?
Tecnología usada
Subsistema: Administración de Censos Lenguaje/Herramienta: Django 1.11 -> Python 3.6 Sistema de gestión de bibliotecas: pip Bibliotecas: Django REST framework (djangorestframework): versión 3 Necesita Base de datos: Sí (Ninguna empleada actualmente, a la espera de directrices)
Hemos decidido hacer uso del framework Django en su versión 1.11 y que trabaja con Python 3.6 por su facilidad de trabajo con JSON, que será el formato de datos en el que se proveerán las funcionalidades de la API. Haremos uso de la librería de funcionalidades djangorestframework que nos provee utilidades para trabajar y crear una API.
Como IDE desarrollaremos sobre PyCharm (en su versión Community), corriendo sobre Ubuntu 16.04 (o una máquina virtual en la máquina de cada desarrollador).
Funcionalidades
Por detallar. Actualmente, ver los objetivos
API
Las funcionalidades aquí descritas y especificadas no son finales. Debido a la diversidad de funcionalidades y necesidades de los otros grupos, éstas pueden variar a lo largo del desarrollo (sea debido al despliege, conflictos, etc).
Obtención de un censo
Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información.
URL:
http://egc-censos1718.es/api/get/censo.json
Parámetros:
* id: Identificador del censo a obtener.
Ejemplo:
GET http://egc-censos1718.es/api/create/censo.json?id=1
Formato JSON:
{ "censo": { "id": "1", "id_votacion": "314", "id_grupo": "3", "nombre": "Censo_de_prueba", "fecha_ini": "24/11/2017 16:00", "fecha_fin": "30/11/2017 23:59" } }
Obtención de un censo
Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información.
URL:
http://egc-censos1718.es/api/get/censo.json
Parámetros:
* id: Identificador del censo a obtener.
Ejemplo:
GET http://egc-censos1718.es/api/get/censo.json?id=1
Formato JSON:
{ "censo": { "id": "1", "id_votacion": "314", "id_grupo": "3", "nombre": "Censo_de_prueba", "fecha_ini": "24/11/2017 16:00", "fecha_fin": "30/11/2017 23:59" } }
Consulta de censos
Se hace una petición GET con los parámetros siguientes y se devolverá un JSON con la siguiente información. Funcionalidad más útil para los otros subsistemas que componen el sistema de votación, pues permitirá obtener resultados a partir de parámetros (si un usuario perteneciente a un grupo puede votar en x votación, qué grupos pueden votar en x votación, etc)
URL:
http://egc-censos1718.es/api/filter/result.json
Parámetros:
* id_votacion (opcional): Identificador de la votación de los censos a consultar. * id_grupo (opcional): Identificador del grupo de usuarios con acceso al censo. * nombre (opcional): Nombre del censo. * fecha_ini (opcional): dd/mm/yyyy hh:mm Fecha de inicio del censo a filtrar. * fecha_fin (opcional): dd/mm/yyyy hh:mm Fecha de fin del censo a filtrar Todos los parámetros deberán ir correctamente parseados en el formato URL (ya que así será traducido e interpretado)
Ejemplo:
GET http://egc-censos1718.es/api/filter/censos.json?id_votacion=314
Formato JSON:
{ "censos": { "censo1": { "id": "1", "id_votacion": "314", "id_grupo": "3", "fecha_ini": "24/11/2017 16:00", "fecha_fin": "30/11/2017 23:59" }, "censo2": { "id": "2", "id_votacion": "314", "id_grupo": "25", "fecha_ini": "19/12/2017 16:00", "fecha_fin": "30/01/2018 23:59" } } }
Edición de un censo
Se hace una petición POST (a través del formulario descrito en su correspondiente vista) con los parámetros siguientes y se devolverá un JSON con la siguiente información.
URL:
http://egc-censos1718.es/api/update/result.json
Parámetros:
* id: Identificador del censo a editar. * id_votacion (opcional): Identificador nuevo de la votación a la que quiere enlazar el censo. * id_grupo (opcional): Identificador nuevo del grupo de usuarios al que quiere cambiar el acceso a voto. * nombre (opcional): Nombre nuevo para el censo. * fecha_ini (opcional): dd/mm/yyyy hh:mm Fecha nueva en la que quiere iniciar la validez del censo. * fecha_fin (opcional): dd/mm/yyyy hh:mm Fecha nueva en la que quiere finalizar la validez del censo. Todos los parámetros deberán ir correctamente parseados en el formato URL (ya que así será traducido e interpretado) Si no se establece algún parámetro, dicho atributo no será editado.
Ejemplo:
POST http://egc-censos1718.es/api/update/result.json?id=1&nombre=Censo_de_prueba_editado
Formato JSON:
{ "exito": true, "mensaje": "Editado con éxito", "censo": { "id": "1", "id_votacion": "314", "id_grupo": "3", "nombre": "Censo_de_prueba_editado", "fecha_ini": "24/11/2017 16:00", "fecha_fin": "30/11/2017 23:59" } }
Eliminación de un censo
Se hace una petición GET (a través del formulario descrito en su correspondiente vista) con los parámetros siguientes y se devolverá un JSON con la siguiente información.
URL:
http://egc-censos1718.es/api/delete/result.json
Parámetros:
* id: Identificador del censo a eliminar.
Ejemplo:
GET http://egc-censos1718.es/api/create/censo.json?id=1
Formato JSON:
{ "exito": true, "mensaje": "Eliminado con éxito" }
Miembros y contacto
- Fco. Javier García, fjgparrales@gmail.com Coordinador
- Miguel Ternero Algarín
- Daniel Lozano Portillo
- María Ruiz Gutiérrez
- Laura Vera Recacha