Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rossta/serviceworker-rails-sandbox
Service Workers on Rails demo app with the serviceworker-rails gem
https://github.com/rossta/serviceworker-rails-sandbox
rails rails-asset-pipeline service-worker serviceworker-rails
Last synced: 19 days ago
JSON representation
Service Workers on Rails demo app with the serviceworker-rails gem
- Host: GitHub
- URL: https://github.com/rossta/serviceworker-rails-sandbox
- Owner: rossta
- License: mit
- Created: 2016-04-30T15:16:55.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-12-14T02:05:43.000Z (about 2 years ago)
- Last Synced: 2024-12-17T04:11:37.116Z (24 days ago)
- Topics: rails, rails-asset-pipeline, service-worker, serviceworker-rails
- Language: Ruby
- Homepage: https://serviceworker-rails.herokuapp.com
- Size: 1.18 MB
- Stars: 89
- Watchers: 9
- Forks: 27
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Service Workers on Rails
This sandbox demonstrates various use cases for "Service Workers on Rails". Integration of Service Workers with the Rails asset pipeline is provided by the [serviceworker-rails](https://github.com/rossta/serviceworker-rails) gem.
## Background
The [Service Worker API](https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API) is coming. Service Workers are scripts that act as a proxy between the browser and the server. Among other things, Service Workers can be used to:
- enable the creation of effective offline experiences
- increase perceived performance while online
- access push notifications and background sync APIs.Service Workers are scripts that live outside the context of a rendered page.
This means that there are some considerations for hosting Service Workers:- service workers must be served over HTTPS
- service workers must be served within the "scope" of the page(s) they control ([pending override capability](https://slightlyoff.github.io/ServiceWorker/spec/service_worker/#service-worker-allowed))
- service workers should not be cached: browsers install service workers in the background so requesting and evaluating
these scripts will not tie up page rendering### Rails integration
So you want to use Service Workers in your Rails app? Consider that the Rails asset pipeline bundles JavaScript assets so that they're typically finger-printed, heavily cached, and served out of the `/assets` directory. While we'd like to take advantage of the asset pipeline for transpiling our Service Worker scripts just like any other JavaScript assets, we need flexibility for how these assets are served to the client.
This is where the [serviceworker-rails](https://github.com/rossta/serviceworker-rails) gem comes in. Using `serviceworker-rails` in your Rails app allows you to map Service Worker endpoints to bundled Rails assets and adds the appropriate (configurable) response headers. You can still take advantage of Rails pipeline with Service Workers in development and production!
The sandbox serviceworker initializer in [`config/initializers/serviceworker.rb`](https://github.com/rossta/serviceworker-rails-sandbox/blob/master/config/initializers/serviceworker.rb) provides several examples for customizing how service worker endpoints should map to assets in the Rails asset pipeline. Corresponding serviceworker implementations for the examples can be found in [`app/assets/javascripts`](https://github.com/rossta/serviceworker-rails-sandbox/tree/master/app/assets/javascripts).
## Resources
Examples in this sandbox are inspired by a variety of resources:
* [Mozilla's Service Worker Cookbook](https://github.com/mozilla/serviceworker-cookbook/)
* [Jake Archibald's Offline Cookbook](https://jakearchibald.com/2014/offline-cookbook/)
* [Pony Foo Service Worker Articles](https://ponyfoo.com/articles/tagged/serviceworker)## Development
Check out the project with git, run `bundle install` and copy the
`database.yml.example` to `database.yml` and edit to fit your needs.You could also try running with Docker. The `docker-compose.yml` assumes the
existence of an `.env.docker` file. You may want copy the `.env.docker.example`
file and set up your own environment variables. Assuming you have Docker
installed and running, you could simply try running `docker-compose up`. YMMV.If desired, for certain features you'll need Twitter app credentials. Example keys can be found in
`.env.docker.example`.Good luck!
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/rossta/serviceworker-rails-sandbox. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
## License
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).