Skip to content

lestrrat-go/sharaq

Repository files navigation

sharaq

sharaq is an image transforming web server, aimed to be run on a cloud service provider.

Given a URL to an image and a transformation specification, sharaq will serve a transformed version of said image.

Please note that sharaq does this transformation on demand, lazily. If the requested resource has already been transformed, the transformed version will have already been stored in the backend storage, and that content will be served. Otherwise if the transformation has not been performed yet, sharaq will first reply with the original unmodified image. Meanwhile there will be a thread that would be performing the transformation, so that when the next request comes, the transformed version is used.

DESCRIPTION

Suppose http://sharaq.example.com is the sharaq endpoint URL, and you want to transform http://images.example.com/foo/bar/baz.jpg to small preset (see below for what presets are).

You can do this by accessing the following URL

http://sharaq.example.com/?url=http://images.example.com/foo/bar/baz.jpg&preset=small

preset denotes the spec to which the image should be transformed to. This must be defined in the configuration before hand (there's no on-demand transformation).

In Real Life / Reverse Proxy

In real life, you probably don't want to expose sharaq directly to the internet. Using a reverse proxy minimizes the chances of a screw up, and also, you can make URLs look a bit nicer. For example, you could accept this in your reverse proxy:

http://sharaq.example.com/small/http://images.example.com/foo/bar/baz.jpg

and transform that to below when passing to the actual sharaq app

http://upstream/?url=http://images.example.com/foo/bar/baz.jpg&preset=small

CONFIGURATION

Listen Address

{
  "Listen": "0.0.0.0:8080"
}

Access Log

See also: https://github.com/lestrrat-go/apache-logformat

{
  "AccessLog": {
    "LogFile": "/path/to/logfile",
    "LinkName": "/path/to/linkname.%Y%m%d",
    "RotationTime": 86400,
    "MaxAge": 172800,
  }
}

AWS (S3) Backend

{
  "Backend": {
    "Type": "aws",
    "Amazon": {
      "AccessKey": "...",
      "SecretKey": "...",
      "BucketName": "..."
    }
  }
}

IAM Setup

The S3 backend stores all the images within the specified S3 bucket. You should setup a IAM role to be used by the sharaq instance so access to the S3 bucket is secured. To allow proper access your IAM policy should look something like this:

{
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "s3:ListBucket",
        "s3:GetBucketLocation",
        "s3:ListBucketMultipartUploads"
      ],
      "Resource": "arn:aws:s3:::BUCKET_NAME",
      "Condition": {}
    },
    {
      "Sid": "Stmt1420772143000",
      "Effect": "Allow",
      "Action": [
        "s3:*"
      ],
      "Resource": [
        "arn:aws:s3:::BUCKET_NAME/*"
      ]
    },
    {
      "Effect":"Allow",
      "Action": [ "s3:ListAllMyBuckets" ],
      "Resource": [ "arn:aws:s3:::*" ]
    }
  ]
}

GCP (Google Storage) Backend

For GCP (Google Storage), service keys are looked under several known locations.Look at "golang.org/x/oauth2/google".DefaultTokenSource for details.

{
  "Backend": {
    "Type": "gcp",
    "Google": {
      "BucketName": "..."
    }
  }
}

sharaq also supports running on Google AppEngine (standard environment). For this to work, you will have to change the setup a bit. You will not need a config.json file, but you will have to setup your environment in app.yaml

service: sharaq
version: 1
runtime: go
api_version: go1
handlers:
  - url: /
    script: _go_app
env_variables:
  SHARAQ_PRESETS: large=600x600,medium=400x400,small=200x200
  SHARAQ_BACKEND_TYPE: gcp
  SHARAQ_BACKEND_GCP_BUCKET_NAME: "bucket-name-of-your-choise"
  SHARAQ_BACKEND_GCP_PREFIX: "resize (this is optional)"
  SHARAQ_TOKENS: "foobarbaz (if you want to access the POST/DELETE endpoints via HTTP)"
  SHARAQ_URLCACHE_TYPE: Memcached
  SHARAQ_WHITELIST: "whitelisting your target is recommended"

For instructions on how to map sharaq configuration parameters to environment variables, please look at https://github.com/lestrrat-go/config/env

File System Backend

The FS backend stores all the images in a directory in the sharaq host. You probably don't want to use this except for testing and for debugging.

{
  "Backend": {
    "Type": "fs",
    "FileSystem": {
      "StorageRoot": "/path/to/storage-dir"
    }
  }
}

Presets

Presets define a mapping from a "name" to "a set of rules to transform the image". The rules are stolend directly from https://github.com/willnorris/imageproxy. It should be stored in the config file, which is passed to sharaq server:

{
  "Presets": {
    "square": "200x200",
    "small": "300x400",
    "big": "400x500"
  }
}

Whitelist

You probably don't want to transform any image URL that was passed. For this, you should specify the whitelist regular expression to filter what can be proxied.

To enable this, specify a list of URLs in the config file:

{
    "Whitelist": [
        "^http(s)?://myconmpany.com/"
    ]
}

URL Cache

sharaq stores URL of images known to have been transformed already in a cache so that it can save on a roundtrip back to the storage backend to check if it exists. Performance will degrade significantly if you don't use a cache, so enabling the cache is highly recommended.

Redis backend

In your configuration file, specify the following parameter to specify the servers to use

{
  "URLCache": {
    "Type": "Redis",
    "DefaultExpires": 60
  },
  "Redis": {
    "Addr": ["mycache:6397"]
  }
}

Memcache backend

In your configuration file, specify the following parameter to specify the servers to use

{
  "URLCache": {
    "Type": "Memcached",
    "DefaultExpires": 60,
    "Memcached": {
      "Addr": ["mycache:11211"]
    }
  }
}

Note that you if you are running under Google App Engine (GAE), you do not need to set anything other than the URLCache Type. GAE does not allow you to configure memcached servers.

ACKNOWLEDGEMENTS

This code was originally developed at Peatix Inc, and has since been transferred to Daisuke Maki (lestrrat)

Releases

No releases published

Packages

No packages published