This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-05-11
Channels
- # aleph (3)
- # announcements (3)
- # aws (7)
- # babashka (121)
- # beginners (82)
- # calva (40)
- # chlorine-clover (37)
- # clj-kondo (68)
- # cljsrn (4)
- # clojure (43)
- # clojure-australia (1)
- # clojure-dev (6)
- # clojure-europe (15)
- # clojure-italy (2)
- # clojure-nl (1)
- # clojure-provo (3)
- # clojure-spec (23)
- # clojure-taiwan (1)
- # clojure-uk (21)
- # clojurescript (214)
- # code-reviews (1)
- # conjure (4)
- # core-async (10)
- # cursive (52)
- # datahike (5)
- # datascript (5)
- # datomic (62)
- # duct (1)
- # emacs (4)
- # fulcro (8)
- # graalvm (1)
- # helix (1)
- # honeysql (5)
- # integrant (1)
- # jackdaw (32)
- # jobs (3)
- # jobs-discuss (16)
- # juxt (1)
- # kaocha (3)
- # lsp (6)
- # malli (2)
- # meander (6)
- # nrepl (1)
- # off-topic (46)
- # other-languages (4)
- # pathom (7)
- # polylith (13)
- # re-frame (3)
- # releases (2)
- # shadow-cljs (56)
- # spacemacs (15)
- # tools-deps (3)
- # unrepl (1)
- # utah-clojurians (1)
Is there a good Clojure library for image manipulation? I have a bunch of .png and .jpg files that I need to resize
if no one has good library recs, image magick on the command line is sick
yeah image magick is really good (and you can shell out to it with whatever scripting solution you like :))
I've also used https://github.com/mikera/imagez a few times, don't remember much of it though
Yeah I’d love an alternative to Image Magick mostly just because I want to practice Clojure more (I’m a beginner and wanting early projects)
@rob370 You could practice Clojure using babashka and then shell out to image magick, if this is just for scripting and not a long running JVM production app or something
image magick is a disaster as soon as you actually care about not blowing things up
I’m curious if you could elaborate on this, as I’m actively considering shelling out to graphicsmagick or imagemagick for something I’m working on 🙂
it's a vulnerability, you need to learn to write its policy file so you don't accidentally your server to some attacker
it will keep throwing errors at you in the most arcane and mysterious ways (depending on how you call it) so good luck figuring out what actually is wrong when it fails
Good points. And thanks for sharing that twelve monkeys library, I hadn’t come across it yet.
i'm actually in the middle of rewriting our image processing from ruby-calling-imagemagick in clojure/java imageio because the former combination is just slow and vulnerable and complicated and fragile
if you do try imageio/twelve monkeys then feel free to throw questions at me if you get stuck haha (though i'm not doing complicated graphics editing, just simple compositing/resizing/cropping)
can you say more about how it's a security disaster? when would it be exposed to users?
This is sort of how the original PSP was hacked: https://en.wikibooks.org/wiki/PSP/Homebrew_History#The_TIFF_Exploit By exploiting a buffer overrun bug in libtiff
the hackers were able to run unsigned code, essentially by loading an image from a memory card
i've used the twelve monkeys library for doing imageio (compositing, resizing, thumbnails) https://github.com/haraldk/TwelveMonkeys
At work we use both the mikera/imagez library and the TwelveMonkeys libraries. We do a lot of resizing, rotation, and cropping.
On java 11, we're getting the following warning on startup:
> WARNING: sun.reflect.Reflection.getCallerClass is not supported. This will impact performance.
We currently think that this is caused by the use of log4j which is a multi-release jar, including specific code for different jvm versions. It seems that depending on a multi-release jar makes the jar you create a multi-release, but it seems you need to set it yourself. We are still creating an uberjar with lein at the moment. Does anyone know if there's a way for lein to add this configuration? It seems I can manually do it myself with jar umf manifest-update target/uberjar.jar
where manifest-update is a file with Multi-Release: true\n
.
oh thank you. i was looking for something specific to multi-release and didn't think to look for arbitrary manifest entry
i'm still a bit surprised that multi-release is transitive like this. depending on a jar with this requires your own jar to set this
Alternatively you could view it as a bug in lein
where uberjars are losing critical information
The process is basically take the jars and unzip into the same place and then rezip, to merge the contents
Which is of course problematic when you have conflicts, and thjar manifest is something that will always conflict
pretty sure @seancorfield did the correct thing
another thing lein
does with uberjars is propagate the module-info.class from modularized jars
depstar
also handles the log4j2 plugin cache correctly which you need if you build an uberjar with multiple dependencies that each include some log4j2 plugins (there is a Leiningen plugin that will “fix” lein uberjar
’s behavior).