dragonfly_server alternatives and similar packages
Based on the "Applications" category.
Alternatively, view dragonfly_server alternatives based on common mentions on social networks and blogs.
-
Logflare
Never get surprised by a logging bill again. Centralized structured logging for Cloudflare, Vercel, Elixir and Javascript. -
CaptainFact
🔎 CaptainFact - API. The one that serves and process all the data for https://captainfact.io -
Startup Job
An app to search startup jobs scraped from websites written in Elixir, Phoenix, React and styled-components. -
Exon
Exon is a “mess manager” developed in Elixir and provides a simple API to manage & document your stuff. -
medex
Medical Examination - application for register health check callbacks and represent their state via HTTP. -
chat
💬 CHAT: Instant Messenger. ISO/IEC: 20922; ITU/IETF: 3394, 3565, 5280, 5480, 5652, 5755 8551, X.509, CMS, PKCS-10, PCKS-7, OCSP, LDAP, DNS; ANSI: X9-42, X9-62, X25519, X488; NIST: SECP384r1. -
majremind
A self-maintained database of your updated server which tells you which one needs to be updated.
InfluxDB - Purpose built for real-time analytics at any scale.
Do you think we are missing an alternative of dragonfly_server or a related project?
README
Dragonfly server
This application can be used to serve Dragonfly urls.
Limitations
- Doesn't support the full Dragonfly feature set (for now).
- Limited to Imagemagick.
Setup
Dependencies
Erlang
IMPORTANT: Due to a known bug in Erlang 17.3, fetching urls with an https
scheme are not processed correctly and throw an exception.
Please use Erlang >= 17.4, available at https://www.erlang-solutions.com/downloads/download-erlang-otp.
Elixir
To install elixir on a Mac, brew install elixir
(you may need to brew update
first).
Alternatively, you can follow these instructions.
Imagemagick
To install Imagemagick with png support, run brew install jpeg libpng imagemagick
.
Goon
Communication with Imagemagick is managed by Goon, a middleman needed to polyfill the incomplete Port implementation provided by Erlang (see here for more information).
Download the binary and add it to a directory available in your $PATH
.
App setup
$ mix deps.get
This will install all needed packages.
Then, copy the example environment file and make the necessary adjustments.
$ cp .env.example .env
Run the app in development
$ iex -S mix
Starts the app and opens a console.
Run tests
$ mix test
General api
Images are served at the entry point defined in config.exs
, set as default at /media/:payload/:filename
.
Note that both params in the url scheme are needed by the application.
Admin api
The app exposes an admin api that can be used to programmatically expire an image and all its associated resources. Endpoints are:
- GET image (shows steps necessary to generate image)
- DELETE image (expires all caches involved in the generation of the image)
Given an image url in the form of:
http://example.com/media/12345/untitled.jpg
It can be deleted by sending a DELETE
request to the following endpoint:
http://example.com/admin/media/12345/untitled.jpg
From the command line:
$ curl -XDELETE http://example.com/admin/media/12345/untitled.jpg
The expected response is a 202
, which indicates that the cache expiry has been scheduled and will be performed asyncronously.
The steps necessary to generate the image can also be examined at:
http://example.com/admin/media/12345/untitled.jpg
From the command line:
$ curl http://example.com/admin/media/12345
Deploy on Heroku
The app runs only on Cedar-14 and requires the multi-buildpack as it uses a custom Elixir buildback (it includes Goon).
Buildpacks are defined in .buildpacks
.
Please follow instructions at https://github.com/ddollar/heroku-buildpack-multi.