f32b528979
Feature use firebase to host instance See merge request ondrejsynacek/facebook-events-ical-converter!1 |
||
---|---|---|
.ebextensions | ||
.firebase | ||
docs | ||
functions | ||
lib | ||
logs | ||
mocks | ||
test | ||
.firebaserc | ||
.gitignore | ||
.travis.yml | ||
firebase.json | ||
package-lock.json | ||
package.json | ||
readme.MD | ||
webpack.config.js |
readme.MD
fb2iCal
This app allows you to download iCal calendar files from Facebook URL / event number.
You can use it as a service at https://fb2ical.com or use this repository to launch your own instance.
The page that is served by the app uses a service worker and can be used offline and installed as PWA (Progressive Web App).
The site can run and download ICS file without JavaScript just fine. When JS is enabled, the server only downloads HTML file, parsing and creation of iCal file is performed inside the browser. The results will be same for both JS-enabed / disabled approach as the parser code is actually shared between browser and server.
Development
It can run in environment with NodeJS 10 installed. It does not use Facebook API for retrieving information, instead it relies on crawling and scraping event URL. This means that it can stop working or the results might not be reliable so use this at your own risk.
Run development server: npm run start:dev
.
Run development server with debugger npm run start:dev:inspect
.
Static assets
The frontend / assets are built by webpack and put into dist/
folder. These assets are then served statically.
Deployment
The command npm run start
will build the assets and start the server in production mode.
The app is stateless and does not need any persistent storage.
The app is automatically set up to create logs in logs/
directory each day but it's up to your environment if the file system is persisted.
HTTPS
App contains middleware that will redirect all traffic to HTTPS if the requests contain header X-FORWARDED-PROTO
. For this to work, the middleware has to be enabled by setting environment variable ENFORCE_HTTPS
to value 1
.
There are environment variables for setting pu SSL certificate from Let's Encrypt (acme challenge):
CERT_ENDPOINT
: endpoint without leading slash such as.well-known/acme-challenge
CERT_SECRET
This way you can set up the endpoint that will reply with secret and this should allow you to generate key pairs.