https://github.com/assafelovic/echo-at-time
Science Score: 13.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
○.zenodo.json file
-
○DOI references
-
○Academic publication links
-
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (8.9%) to scientific vocabulary
Repository
Basic Info
- Host: GitHub
- Owner: assafelovic
- Default Branch: master
- Size: 17.6 KB
Statistics
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
- Releases: 0
Metadata Files
README.md
echo-at-time
Your task is to write a simple application server that prints a message at a given time in the future. The server has only 1 API:
echoAtTime - which receives two parameters, time and message, and writes that message to the server console at the given time.
Since we want the server to be able to withstand restarts it will use redis to persist the messages and the time they should be sent at. You should also assume that there might be more than one server running behind a load balancer (load balancing implementation itself does not need to be provided as part of the answer)
In case the server was down when a message should have been printed, it should print it out when going back online.
The application should preferably be written in node.js. The focus of the exercise is the efficient use of redis and its data types as well as seeing your code in action.
Main logic:
Client sends post request with date to /messages/schedule
POST /messages/schedule
{
"time": "2019-01-01T00:00:00.000Z",
"message": "Happy New YEAR!!!"
}
and server responds with:
{
"id": "4bbb0800-5204-4bfe-8dfe-332d270a55c0",
"date": "2019-01-01T00:00:00.000Z",
"message": "Happy New YEAR!!!"
}
EXTRA: /messages/schedule/now will push message to be scheduled at current time (almost immediately)
POST /messages/schedule/now
{
"message": "Some message"
}
and server responds with:
{
"id": "4bbb0800-5204-4bfe-8dfe-332d270a55c0",
"date": "Current iso date time",
"message": "Some message"
}
MessagesController.schedule creates following records in redis storage:
``` 127.0.0.1:6379> keys * 1) "scheduledMessages:2019-01-01" 2) "scheduledMessage:4bbb0800-5204-4bfe-8dfe-332d270a55c0" 3) "scheduledMessagesLists"
127.0.0.1:6379> LRANGE scheduledMessagesLists 0 0 1) "2019-01-01"
127.0.0.1:6379> LRANGE scheduledMessages:2019-01-01 0 0 1) "2019-01-01T00:00:00.000Z,4bbb0800-5204-4bfe-8dfe-332d270a55c0"
127.0.0.1:6379> GET scheduledMessage:4bbb0800-5204-4bfe-8dfe-332d270a55c0 "2019-01-01T00:00:00.000Z,Happy New YEAR!!!" ```
Background scheduler task: tasks/echo-scheduled-messages.js:
Installing requirements:
npm i -g forever
Running:
npm run echo-scheduled-messages
or as forever process:
npm run task-echo-scheduled-messages
Logic:
On load:
1) Gets scheduledMessagesLists and filters by date and keeps dates that is today or previous days.
2) Finds outdated messages from lists: scheduledMessages:{date-here} and pops it out
3) Pushes outdated message by key: scheduledMessage:{id} to scheduledMessagesQueue
Looping:
1) Pops messages from : scheduledMessagesQueue
2) Logs it to console
3) Pushes it to processedMessages list
Owner
- Name: Assaf Elovic
- Login: assafelovic
- Kind: user
- Location: Israel
- Website: www.assafelovic.com
- Repositories: 2
- Profile: https://github.com/assafelovic
Tech enthusiast and Full Stack software engineer.
GitHub Events
Total
Last Year
Dependencies
- node alpine build
- eslint ^5.10.0 development
- eslint-config-standard ^12.0.0 development
- eslint-plugin-import ^2.14.0 development
- eslint-plugin-node ^8.0.0 development
- eslint-plugin-promise ^4.0.1 development
- eslint-plugin-standard ^4.0.0 development
- husky ^1.2.1 development
- jasmine ^3.3.1 development
- jasmine-console-reporter ^3.1.0 development
- async ^2.6.1
- body-parser ^1.18.3
- cors ^2.8.5
- cross-env ^5.2.0
- express ^4.16.4
- joi ^14.3.0
- moment ^2.23.0
- morgan ^1.9.1
- nconf ^0.10.0
- redis ^2.8.0
- winston ^3.1.0
- winston-sentry ^0.2.1