Skip to content

Latest commit

 

History

History
192 lines (138 loc) · 9.43 KB

development.md

File metadata and controls

192 lines (138 loc) · 9.43 KB

Guía de instalación

Docker

La forma más fácil de correr Consultas Digitales es con Docker y Docker compose. Se probó exitósamente con las versiones 19.03.5 y 1.24.0 de las mismas, sobre un Ubuntu 18.04. Si quiere instalar localmente, sin Docker, puede ver el apartado Instalación directa.

Variables de entorno

En primer lugar debemos adecuar el docker-compose.yml

La aplicación utiliza las imagenes de Node 6 y Mongo 3.2

En el repositorio encontrará la plantilla docker-compose.example.yml. Copie la plantilla a un nuevo archivo con el nombre docker-compose.override.yml en su copia local del proyecto; este archivo será tomado automáticamente por el comando docker-compose (pisará lo ya definido en docker-compose.yml), y no molestará en git ya que se encuentra ignorado (en .gitignore).

Notas
  • Es muy importante que en STAFF agregues el email del admin o el de los administradores. Puede hacerlo incluso antes de haber creado las respectivas cuentas en la plataforma.
  • Podés comentar las variables NOTIFICATION_* si todavía no tenés un servidor de correo definido.
  • Podés configurar DemocracyOS con cualquiera de las variables de entorno listadas acá: http://docs.democracyos.org/configuration.html
  • Por defecto la aplicación se monta en el puerto 3000. Puede cambiar este puerto editando el número de la derecha bajo la llave ports (p. ej.: 3000:9999)
  • Si se prefiere conectar a una base de datos local, fuera del entorno, vea el apartado Conectar a una base de datos mongo local
  • El puerto 27017 está expuesto para que puedas administrar la base de datos con algún cliente de MongoDB, por ejemplo con Robomongo.
  • Hay muchas vistas personalizadas de Consultas Digitales que se encuentran en /ext. Siguiendo el mismo patrón de carpetas que DemocracyOS/democracyos.
  • Las variables de entorno se traducen a variables en código siguiendo la serialización descripta en DemocracyOS/config.

Luego de que todo este definido, podemos arrancar el servidor ejecutando:

docker-compose up --build

Puede tardar un rato largo en buildear. Cuando haya terminado y si todo sale bien, el servidor y container estarán correctamente levantados y listos para poder trabajar.

Para entrar a la aplicacion a http://localhost:3000

Comandos utiles

Para abrir el server local

docker-compose up

Si cambia alguna dependencia del /ext/package.json, tiene que volver a buildear la imagen de Docker

docker-compose up --build

Si desea utilizar otro archivo de compose:

docker-compose -f docker-compose-otro.yml up

Para poder entrar al container de DemocracyOS:

docker exec -it miconsultapublica bash

Para entrar a la base de datos (acá nombrada mi-consultapublica pero puede cambiar)

docker exec -it miconsultapublica-mongo mongo mi-consultapublica

Para inspeccionar rápidamente la base de datos (dentro de la consola de mongo):

# enumerar tablas
show tables
# volcar tabla forums
db.forums.find()
# volcar solo ids, names y titles
db.forums.find({}, {name:1, title:1})
# buscar por id
db.forums.find(ObjectId("5dbc5619a035c3000f2f1f45"))
# buscar por nombre
db.forums.find({name: 'un nombre'})
# borrar 1 usuario por mail
db.users.deleteOne({"email":"[email protected]"})
# borrar todos los usuarios
db.users.remove({})

Conectar a una base de dato Mongo local

Si lo prefiere, puede conectar la aplicacion a su mongo local. En primer lugar aseguresé que sea Mongo 3.2, si no, procure utilizar el container que se construye en el build del docker-compose.

Suponiendo que la base de datos esta en localhost:27017 cambiar el valor de la variable MONGO_URL

  app: 
    [...]
    environment:
      [...]
      - MONGO_URL=mongodb://localhost:27017/mi-consultapublica

Luego, debe comentar:

  app: 
    [...]
    # links:
    #  - mongo 
    [...]

Y agregar:

  app: 
    [...]
    network_mode: "host"
    [...]

Por ultimo debemos comentar el servicio de mongo, para que no se construya el container

  # mongo:
  #   container_name: miconsultapublica-mongo
  #   image: mongo:3.2
  #   ports:
  #     - 27017:27017
  #   volumes:
  #     - ./tmp/db:/data/db

Conectar a un servidor SMTP local

Para esto podemos usar la imagen namshi/smtp.

Por ejemplo, si usamos una cuenta de Gmail de prueba, agregar en su compose:

  mailserver:
    image: namshi/smtp
    environment:
      - [email protected]
      - GMAIL_PASSWORD=mi-contraseña-que-no-debo-publicar

Posteriormente, cambiar las variables de entorno correspondientes del contenedor app:

      - [email protected]
      - NOTIFICATIONS_NODEMAILER={"host":"mailserver","port":25,"secure":false}

Notar que si bien la conexión a este servidor SMTP no está cifrada, la conexión del servidor SMTP a Gmail sí lo está.

Instalación directa

Para esto debe seguir las guías oficiales de DemocracyOS sobre instalación y desarrollo.

De forma breve se puede resumir en:

  • Asegurarse de tener la versión 6 de Node mirando lo que devuelve node -v. Si no, puede cambiar fácilmente entre versiones de node.
  • Asegurarse de tener una versión >=3 y <5 de Npm mirando lo que devuelve npm -v. Si no, puede cambiar fácilmente entre versiones de npm.
  • Ubicarse dentro de la carpeta raíz del proyecto
  • Hacer make packages
  • Agregar algún mail de staff que será lx admin. Para esto crear el archivo config/development.json con contenido:
    { "staff": ["[email protected]"] }
  • Levantar una base de datos mongo que escuche en localhost:27017. Por ejemplo con docker: docker run -p 27017:27017 --name mongodb-dos mongo:3.2. De ser necesario puede cambiar la url del servidor mongo agregando la opción mongoUrl dentro de config/development.json
  • Correr el script build-watch-serve de gulp (debe estar instalado) haciendo NODE_PATH=. DEBUG=democracyos* gulp bws. Si esto no funciona pueden intentar correr make run
  • Ir a http://localhost:3000, registrar su cuenta con el mail de staff y entrar (no hace falta validar el mail)
Cambiando de versiones de Node

Se requiere la versión de node 6.x.x para correr la plataforma. Recomendamos usar nvm para cambiar fácilmente entre una versión y otra de node. Su instalación es ultrasimple, mirar su documentación. Si tenemos esta herramienta instalada, haríamos nvm install lts/boron (que es la versión 6.17.1) para cambiar a la versión válida. Una vez instalada, ya podemos hacer directamente nvm use lts/boron. Si no les gusta nvm puede intentar usar n.

Cambiando de versiones de Npm

Una vez cambiada la version de Node como explicado en el punto anterior puede ejecutar npm install -g 'npm@>=3 <5'. Esto solo afectará a la versión de Node que esté activa.

Instalar Gulp

Una vez cambiada la version de Node como explicado en el punto anterior, al anterior, puede ejecutar npm install -g gulp para instalar Gulp. Esto solo afectará a la versión de Node que esté activa.

Configuración

La configuración de la instancia local se hace en el archivo config/development.json. Los valores por defecto se pueden ver en config/defaults.json. Hay un ejemplo de configuración en config/development.json.example. Estas opciones son las mismas que para docker-compose.yml salvo que hay un proceso de renombramiento, como se explica en DemocracyOS/config, que básicamente es renombrar UNA_VARIABLE_X a unaVariableX accesible desde el código.

El frontend no tiene acceso a todas las variables de configuración, sino solo a las que están enumeradas dentro de la opción "client" dentro del archivo de configuración.

Sistemas de builds

La plataforma cuenta con diversas formas de buildearse y correr.

Una es con make. Esta utiliza el archivo Makefile para correr scripts de npm como se puede ver en su código. Notar como desde un script se salta a otro (p.ej. de run salta a built y de build a packages).

Otra forma es con gulp. Este utiliza gulpfile.js que simplemente importa el archivo lib/build/index.js. Allí, se asignan todos los posibles scripts de gulp con el comando .task(...). Siempre que se llame a un script de gulp directamente deben suministrar la variable de entorno NODE_PATH=. así encuentra los modulos, sino les saldrán errores del tipo Error: Cannot find module.

Finalmente está la forma clásica con scripts de npm definidos en el archivo package.json bajo la llave scripts. Estos, se corren haciendo npm run <nombre_del_script>, p. ej. npm run serve. Como verán, muchos de estos utilizan gulp.

El único comando indispensable para buildear el sistema es gulp build ya que compila todos los archivos js y css a la carpeta public, y también copia los assets (imágenes, fonts, etc.).