Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thealphadollar/salvator
Salvator: The Saviour, When You Forget Birthdays
https://github.com/thealphadollar/salvator
automation birthdays bot forget-birthdays hacktoberfest headless-chrome javascript messenger puppeteer
Last synced: 4 months ago
JSON representation
Salvator: The Saviour, When You Forget Birthdays
- Host: GitHub
- URL: https://github.com/thealphadollar/salvator
- Owner: thealphadollar
- License: mit
- Created: 2018-06-14T21:00:52.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T14:21:32.000Z (about 2 years ago)
- Last Synced: 2024-09-30T15:36:56.140Z (4 months ago)
- Topics: automation, birthdays, bot, forget-birthdays, hacktoberfest, headless-chrome, javascript, messenger, puppeteer
- Language: JavaScript
- Homepage:
- Size: 418 KB
- Stars: 10
- Watchers: 3
- Forks: 9
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Salvator: The Saviour, When You Forget Birthdays
[![Join the chat at https://gitter.im/salvator_/Lobby](https://badges.gitter.im/salvator_/Lobby.svg)](https://gitter.im/salvator_/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
## What is Salvator?
Salvator is a bot which uses puppeteer to scrape the list of birthdays from facebook and sends them a personal
message.It also sends the user an email notification with the list of birthdays and their profile link.
![puppeteer-salvator cli in action!!](screenshots/salvator.gif)
## How does it work?
Puppeteer uses a headless browser to navigate to `facebook.com/login` and using the credentials from the `.env` file,
logs in. There after it navigates to the birthday events page, scrapes the profile links for birthday people, forms
the messenger link using it and sends them a personalised message.
E.g `Hey thealphadollar! Happy Birthday :D`, if user's first name is "thealphadollar".The message is randomized from a stored list.To avoid sending multiple wishes, the program creates a json file with a timestamp and a list with the links already wished. When the file is read, if the timestamp matches the day, the redundancies are avoided.
## Install
Salvator can be installed using npm or source.**NOTE: puppeteer-salvator installs Chromium(102 MB) along with it. If you have already Chromium installed, use the `--ignore-scripts` option.**
* ### Install using npm
1. [Install npm](https://www.npmjs.com/get-npm)
2. `npm install -g puppeteer-salvator`
***OR***
`npm install -g puppeteer-salvator --ignore-scripts` *(without Chromium)** ### Build using source (**RECOMMENDED**)
1. `git clone https://www.github.com/thealphadollar/salvator`
2. `cd salvator`
3. [Install npm](https://www.npmjs.com/get-npm)
4. `npm install` (this step installs all the dependencies)
5. `npm link` - to link the CLI tool so that it can be used globally in your system.## Using CLI tool locally
Follow the steps given below in order to run the **puppeteer-salvator** tool globally in your terminal:1. Go to the project folder and run `npm link` in your terminal. Creates a *symlink* in the global folder `{prefix}/lib/node_modules/` to your project.
2. Open a new terminal and run `puppeteer-salvator` from anywhere(not necessarily the project folder).
3. In-case you are done testing and want to remove the *symlink* from the global folder, run `npm unlink`.**NOTE: In case of any errors related to launching headless chrome, [install google-chrome-stable](https://www.linuxbabe.com/ubuntu/install-google-chrome-ubuntu-16-04-lts).
It'll resolve all the dependency issues.**## Using Salvator
Before running Salvator, the following environment variables must be set to avail full functionality of the client:
```$xslt
FB_ID=
FB_PASS=
EMAIL=
EMAIL_PASS=
MAILTO=
```
**RECOMMENDED** : Create a `.env` file in the `salvator` folder with the above mentioned environment variables. Or you can do it using our CLI tool **puppeteer-salvator** by running the command `puppeteer-salvator env`.**NOTE** : You also need to [enable access to less secure apps](https://support.google.com/a/answer/6260879?hl=en) in your GMail account (the
client only supports sending from gmail accounts).After you are done with *installation*, Salvator can be launched manually using the commands :
- `puppeteer-salvator run`, if installed from npm
- `node index.js`, from source directoryHowever, it is recommended to [add a cronjob](https://www.cyberciti.biz/faq/how-do-i-add-jobs-to-cron-under-linux-or-unix-oses/) to automatically launch the client at the desired time,
favorable 00:05 hours. By this time facebook updates the list of birthdays and hence you could be among the first to
wish.For example, the below cronjob launches the script everyday at 00:05 (local system timezone is followed) and logs the sys.stdout into cron.log
```
5 0 * * * nodejs /path/to/salvator/index.js >> ~/cron.log
```The cronjob can be added by executing the file cron.sh
Make sure the file has appropriate permissions and if not run the following
```
chmod a+x cron.sh
```
## Puppetter Salvator CLI toolThe CLI tool provides an interface to interact with the CLI tool and utilize its functionality. The following set of commands are provided by the tool:
* `puppeteer-salvator run` : Run the automated Birthday wish script
* `puppeteer-salvator env` : Load environment variables in .env file(fb_id, fb_pass, email, ..)
* `puppeteer-salvator cron` : Add a cronjob delete a cronjob, view all cronjobs
* `puppeteer-salvator bth` : Show all the birthdays for the current## Contributing
Contributions are welcome, please look in the issues tab to contribute.
* VSCode is recommended as the editor for this project.
* Install eslint plugin for vscode. Use this [video][1] to setup eslint-prettier for vscode.
* Please follow [JSDoc][3] for your submitted code. Use [DocumentThis][2] plugin if required.
* Please read CONTRIBUTING.md guide to know more.
* Write tests for complicated components and modules.[1]: https://www.youtube.com/watch?v=YIvjKId9m2c
[2]: https://marketplace.visualstudio.com/items?itemName=joelday.docthis
[3]: http://usejsdoc.org/