Simple IO library to enable rapid development on at least files, http/https, s3 with optional caching.
The philosophy is to split the difference between do-as-I-want programming which is what I do at the repl and do-as-I-say programming which matches system programming much closer. "tech.io" is DWIW, but it is built on an set of protocols to enable very precise DWIS programming where surprises are minimal.
(io/get-nippy "s3://blah/blah.nippy")
(io/copy "s3://blah/blah.nippy" "file://blah.nippy")
(io/put-image! "s3://blah/blah.jpg" buffered-image)
This layer has a global variable you can use to override the way the system maps from url->io-provider. Using this variable you can setup global caching so that anything downloaded or read will get cached, regardless of where it came from (http, https, file, s3). You can also setup redirection where a directory looks like s3 for unit tests that read/write to s3 urls.
The intention is to provide a simple and minimal base io abstraction and then add capabilities via chaining and layering abstractions.
The base abstraction is the IOProvider. There are basic implementations of this abstraction in base.clj
Given this abstraction we can implement a caching layer which will cache anything to a defined point in the filesystem. We can also implement a redirection layer which will redirect requests to a defined point on the filesystem.
Please see the tests.
Copyright © 2018 TechAscent, LLC
Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close