Install and upgrade
On this page:
Requirements
All you need is a Linux server with these tools installed:
- docker
- docker-compose
- curl
Docker version 19.03.8, build afacb8b7f0
~/$ docker-compose -v
docker-compose version 1.24.0, build 0aa59064
~/$ curl --version
curl 7.70.0 (x86_64-pc-linux-gnu) ...
Release-Date: 2020-04-29
Protocols: ...
Features: ...
Hardware requirement is minimal: 128MB of RAM and 1 core will suffice, provided you’re not doing intensive video transcoding and/or serving thousands of users simultaneously.
Installation
The official Docker image is available on Docker Hub
~/filestash$ curl -O https://downloads.filestash.app/latest/docker-compose.yml
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 322 100 322 0 0 98 0 0:00:03 0:00:03 --:--:-- 98
~/filestash$ docker-compose up -d
Creating filestash_app ...
Creating filestash_app ... done
After installation, navigate to http://your_domain:8334
to configure your admin password:
Setup
You can pick and choose which storages you want your users to access:
Every single option available from the “Storage Backend” section is built as a “plugin”. Once you pick a storage, you get a web client that is functionally similar to the like of Filezilla, Cloudberry, WinSCP, and Cyberduck but you can get a lot further when you start thinking of your implementation as 3 separate components:
-
Storage component: that’s what we have already configured, it can be anything like FTP, SFTP, S3, SMB, NFS, GIT, etc…
-
Authentication component: it defines how users are expected to login. There are many valid strategies, from deferring the authentication to your storage (using the passthrough plugin) to defining your own users in Filestash itself (using the htpasswd plugin), AD, SAML, OIDC, proxy based authentication, and virtually any possible mechanism that could be used to authenticate a user. For example we’ve developed an authentication plugin for the MIT that authenticate their users through LDAP followed by an MFA step that is based of their existing mfa solution provider: duo, connecting all of this with their SMB based storage in a seamless fashion.
-
Authorisation component: once someone have logged in, what are they allowed to do? You might want to restrict everyone to be readonly or setup rules for the marketing department to have read/write access on their assets while sales can only read that folder, etc…
Let’s start with the “Authentication component” which is configured in the “authentication middleware” section:
By enabling an “Authentication middleware” plugin like the passthrough option shown above, you spare users from knowing and entering the technical details of your storage like hostname, port, access_keys, … etc… These parameters will then be used to create the connection details needed to connect to your storage.
In the exact setup shown above, end users will see:
Another very common pattern is to use a plugin like the htpasswd
to create a facade for your storage:
This setup grants “rick” complete access to all S3 buckets, whereas “jerry” is restricted to the “earth” bucket only. These mappings can be done using the Go templating language with a couple additional features to enable actions based on your environment variables and enabling role based access. A common exampe of this would be to have an admin group in your IDP which can see the whole filesystem but restrict non admin users to their respective folders like this: “//home//”
Plugins
So far, we’ve only touched on storage plugins and authentication middleware, which are 2 of the 3 pillars of a solid bespoke solution:
Yet, we’re just beginning to tap into the potential of plugins. As we see it, Filestash is a framework for developing file management applications. Once you open up the cover, you will find a core engine wrapped with plugins that define almost every facet of the file manager.
For example, with plugins, you can layer an authorisation framework like what’s enabled in the enterprise offering to restrict the possible set of action someone could do on your storage, change the default file viewer or build completly new ones from the ground up as we did with our OnlyOffice integration to support office documents. You can also alter where Filestash’s configuration is pulled from and saved. While the filesystem is the default method, there are existing plugins for S3 or using an environment variables. Searching capabilities go beyond the default recursive search plugin; they can be enhanced with more sophisticated FTS engines, like our SQLite implementation, integrate with your existing Elasticsearch or Solr cluster or be disabled altogether. Additionally, if the thought of a buffer overflow makes you sweat, you can switch the default thumbnail generators written in C for another implementation made entirely in Go.
You can see all the plugins installed in your build on the /about
page of your Filestash instance:
To truly grasp the breadth of options available through plugins, delving into the source code is the way to go. A good starting point for this exploration is this and this.
Advanced Setup
Filestash is deployed in many sensitive environments with very stringent needs. If this sounds like what you are doing, you might want to read:
-
our hardening guide
-
some examples of architecture diagram that was made for a deployment in large pharma with requirements for high availability and scalability. You can read about that in this post from the AWS Blog:
Upgrade
To update Filestash:
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 322 100 322 0 0 98 0 0:00:03 0:00:03 --:--:-- 98
~/filestash$ docker-compose pull
Pulling app (machines/filestash:latest)...
latest: Pulling from machines/filestash
Digest: sha256:4da068a5868d736f6382618e6f8baa6cf44c1cf0f94a3ded05aa25b00a41f425
Status: Image is up to date for machines/filestash:latest
~/filestash$ docker-compose up -d
Recreating filestash_app ...
Recreating filestash_app ... done