Esteban Manchado Velázquez
Fix password reset functionality
The password reset functionality was broken for non-admin users, due to a silly JSON response format expectation mismatch on the frontend. In particular, the "role" field for a user is supposed to be a string, but it was null for non-admin users. So force the role field to be a string when returning user information, the same way we already do when we get the list of users.
|1 week ago|
|app||1 week ago|
|config||1 year ago|
|docs||2 years ago|
|html||10 months ago|
|mail-templates||1 year ago|
|migrations||1 year ago|
|public||1 week ago|
|robohydra||3 years ago|
|src||1 week ago|
|tests||1 year ago|
|ux||2 years ago|
|.babelrc||3 years ago|
|.dockerignore||2 years ago|
|.gitignore||2 years ago|
|.jshintrc||3 years ago|
|Dockerfile||2 years ago|
|LICENSE||2 years ago|
|README.md||1 year ago|
|brunch-config.js||10 months ago|
|docker-compose.yaml||2 years ago|
|elm.json||2 weeks ago|
|package.json||10 months ago|
|update-db-migrate-conf.js||2 years ago|
What about the other characters?? There should probably be a dramatis personae. The problem is that the narrator might not have finished all character sheets.
NARROWS is an online storytelling system. The name stands for NARRation On Web System. The easiest way to explain it is to imagine an online Choose Your Own Adventure book with the following differences:
You can also think of it as a way of running ruleless, diceless RPGs online (which is indeed the reason why I wrote it in the first place).
NARROWS is a web application with a backend. As such, it needs a server connected to the internet to be used. To install you need to run the following steps:
npm install -g email@example.com
npm run build
config/local-production.jsand modify any values you need.
NODE_ENV=production npm run dbmigrate
NODE_ENV=production node build/index.js
If all this works you will have to find a way to keep the server running, eg. supervisor.
Every time you update the code you will have to install any new dependencies with:
And run any new migrations with the following command. Note that you
might need to pass the
NODE_ENV variable as in the installation
npm run dbmigrate
Then you will have to recompile the frontend and backend code with:
npm run build
This repo includes a Dockerfile for building a deployable image. It
also contains a
docker-compose.yaml suitable for quickly getting a
local copy running. The Dockerfile and compose file have been used
(with modification) to host a production version of the app.
To get going with docker-compose:
docker-compose create && docker-compose up -d
If you want to host it publicly and setup e-mail, add the appropriate Docker environment variables from below:
PORT: port to listen to.
PUBLIC_ADDRESS: used to generate URLs in e-mails.
DB_HOST: MySQL hostname/IP.
DB_USER: MySQL username.
DB_PASSWORD: MySQL password.
DB_NAME: database name.
FROM_EMAIL: e-mail address to send from. e.g.
NODEMAILER: a nodemailer URI configuration string, e.g.
NODEMAILER URI strings need to URI escape special
characters within username/password. For example, usernames often
@, and AWS SES passwords often contain