First we take Manhattan, then we take Berlin.
Manhattan es una aplicación web para gestionar los proyectos de Innovación Docente.
Está desarrollada con Django 5, mucho ♥, bastante ☕
y un poco de magia 🧙.
Hay una réplica pública del repositorio en https://github.com/Servicio-Informatica-Comunicaciones-UZ/manhattan.
-
Crear una base de datos.
En MariaDB/MySQL sería algo así:sudo mysql -u root
CREATE DATABASE nombre CHARACTER SET='utf8mb4' COLLATE utf8mb4_unicode_ci; GRANT ALL PRIVILEGES ON nombre.* TO usuario@localhost IDENTIFIED BY 'abretesesamo'; quit
Si el servidor en que se encuentra la base de datos es distinto a donde se alojará la aplicación, comprobar que desde la máquina de la aplicación se pueda acceder a la BD.
-
Clonar el repositorio Git.
git clone https://gitlab.unizar.es/InnovacionDocente/manhattan.git .
-
Copiar el fichero de ejemplo
.env-sample
a.env
. -
En el fichero
.env
configurar la clave secreta de Django, la conexión con la base de datos, la URL del sitio (SITE_URL
), los datos para el correo electrónico, los datos para el Single Sign On (SAML, los web services de Gestión de Identidades, etc.
Si se está detrás de un proxy o balanceador, habilitar la opciónUSE_X_FORWARDED_PORT
.
Si se usa SSL, habilitar las opcionesSESSION_COOKIE_SECURE
yCSRF_COOKIE_SECURE
. -
En el fichero
Dockerfile
cambiarUWSGI_UID
yUWSGI_GID
al usuario y grupo que se desee. En el ficherodocker-compose.yml
cambiar el puertopublished
al que se desee. -
Construir y levantar los contenedores:
docker-compose build && docker-compose up -d
-
Crear el usuario administrador:
docker-compose exec web ./manage.py createsuperuser docker-compose exec web ./manage.py loaddata seed
-
Entrar como administrador en la interfaz web, y añadir usuarios al grupo
Gestores
(incluyendo el superusuario). -
Activar a los usuarios gestores el atributo
is_staff
para que puedan acceder a la interfaz de administración.
-
Python 3.10 o superior. En Debian o Ubuntu:
sudo apt-get install python3-dev python3-distutils
-
uv, gestor de paquetes y entornos virtuales de Python.
curl -LsSf https://astral.sh/uv/install.sh | sh
-
Paquetes
fonts-texgyre
,libxmlsec1-dev
,pandoc
ypkg-config
. -
Un servidor de bases de datos aceptado por Django (vg PostgreSQL o MariaDB).
En Debian/Ubuntu:
apt install postgresql
o
apt install mariadb-server mariadb-client libmariadb-dev
o
apt install mysql-server mysql-client libmysqlclient-dev
En versiones antiguas de MariaDB/MySQL, la configuración deberá incluir, si es necesario:
innodb_file_per_table = On # Default on MariaDB >= 5.5 innodb_file_format = Barracuda # Deprecated in MariaDB 10.2 innodb_large_prefix # Deprecated on MariaDB 10.2, Removed in MariaDB 10.3.1 innodb_default_row_format = dynamic # Default on MariaDB >= 10.2.2
git clone https://github.com/Servicio-Informatica-Comunicaciones-UZ/manhattan.git # Usar la dirección git@gitlab... interna
cd manhattan
uv sync
Si nuestro sistema usa gcc
y se produce un error de que no encuentra clang
, ejecutar antes
export CC=gcc; export CXX=g++
-
Crear una base de datos.
En MariaDB/MySQL sería algo así:sudo mysql -u root
CREATE DATABASE nombre CHARACTER SET='utf8mb4' COLLATE utf8mb4_unicode_ci; GRANT ALL PRIVILEGES ON nombre.* TO usuario@localhost IDENTIFIED BY 'abretesesamo'; quit
-
Copiar el fichero de ejemplo
.env-sample
a.env
. -
En el fichero
.env
configurar la clave secreta de Django, la conexión con la base de datos, la URL del sitio (SITE_URL
), los datos para el correo electrónico, los datos para el Single Sign On (SAML, los web services de Gestión de Identidades, etc.
Si se está detrás de un proxy o balanceador, habilitar la opciónUSE_X_FORWARDED_PORT
.
Si se usa SSL, habilitar las opcionesSESSION_COOKIE_SECURE
yCSRF_COOKIE_SECURE
. -
Si ya disponemos de un volcado de una base de datos de una instalación anterior, simplemente lo importamos, con lo que finaliza la configuración.
En caso contrario, seguimos con los siguientes pasos.
export UV_ENV_FILE=".env" uv run ./manage.py migrate uv run ./manage.py createsuperuser uv run ./manage.py loaddata seed
-
Abrir la URL con el navegador web, autenticarse como superusuario y, en la interfaz de administración de Django, añadir usuarios al grupo
Gestores
(incluyendo al superusuario). -
Activar a los usuarios gestores el atributo
is_staff
para que puedan acceder a la interfaz de administración.
export UV_ENV_FILE=".env"
nohup uv run ./manage.py run_huey &
uv run ./manage.py runserver [<IP>[:<puerto>]]
Podemos indicar que el superusuario pertenece al colectivo PAS, para que pueda crear proyectos.
- Puede dar error si no al acceder a Mis Proyectos en la carga inicial, verificar campos numero_documento, first_name, last_name:
UPDATE accounts_customuser
SET colectivos = '["PAS"]'
WHERE is_superuser = 1;
Para generar el fichero requirements.txt
:
uv export --format requirements-txt --no-dev > requirements.txt
Se puede crear una nueva convocatoria desde la interfaz de administración
(los usuarios gestores, además de pertenecer al grupo Gestores
deben tener activado
el atributo is_staff
para que puedan acceder a esta interfaz).
Se pueden clonar los maestros de la convocatoria anterior con estas órdenes SQL:
-- Programas
INSERT INTO indo_programa (nombre_corto, nombre_largo, max_ayuda, max_estudiantes,
campos, requiere_visto_bueno_centro, convocatoria_id, requiere_visto_bueno_estudio)
SELECT nombre_corto, nombre_largo, max_ayuda, max_estudiantes, campos,
requiere_visto_bueno_centro, convocatoria_id + 1, requiere_visto_bueno_estudio
FROM indo_programa
WHERE convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
ORDER BY id;
-- WARNING: Si se añaden nuevos programas, hay que actualizar el método `Proyecto.get_unidad_planificacion()`.
-- Líneas
INSERT INTO indo_linea (nombre, programa_id)
SELECT l.nombre, p2.id
FROM indo_linea l
JOIN indo_programa p ON l.programa_id = p.id
JOIN indo_programa p2 ON p.nombre_corto = p2.nombre_corto
WHERE p.convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
AND p2.convocatoria_id = p.convocatoria_id + 1
ORDER BY p2.id, l.id;
-- Rúbrica evaluación ACPUA
-- Si se añaden o quitan programas de la convocatoria, actualizar manualmente el campo `programas`
INSERT INTO indo_criterio (parte, peso, descripcion, tipo, convocatoria_id, programas)
SELECT parte, peso, descripcion, tipo, convocatoria_id + 1, programas
FROM indo_criterio
WHERE convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
ORDER BY parte, peso;
-- Opciones de la rúbrica
INSERT INTO indo_opcion (puntuacion, descripcion, criterio_id)
SELECT o.puntuacion, o.descripcion, c2.id
FROM indo_opcion o
JOIN indo_criterio c1 ON o.criterio_id = c1.id
JOIN indo_criterio c2 ON c1.parte = c2.parte AND c1.peso = c2.peso
WHERE c1.convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
AND c2.convocatoria_id = c1.convocatoria_id + 1
ORDER BY c2.id, o.puntuacion;
-- Apartados memoria
INSERT INTO indo_memoriaapartado (numero, descripcion, convocatoria_id)
SELECT numero, descripcion, convocatoria_id + 1
FROM indo_memoriaapartado
WHERE convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
ORDER BY numero;
-- Subapartados memoria
INSERT INTO indo_memoriasubapartado (peso, descripcion, ayuda, tipo, apartado_id)
SELECT peso, s.descripcion, ayuda, tipo, a2.id
FROM indo_memoriasubapartado s
JOIN indo_memoriaapartado a1 ON s.apartado_id = a1.id
JOIN indo_memoriaapartado a2 ON a1.numero = a2.numero
WHERE a1.convocatoria_id = 2023 -- Reemplazar 2023 por la última convocatoria.
AND a2.convocatoria_id = a1.convocatoria_id + 1
ORDER BY a2.id, peso;