- JDK 14
- imagemagick
- mailutils
- ffmpeg
mkdir grumpy_data
./script/bootstrap.sh
./script/repl.sh
open http://localhost:8080
Minimalistic blog engine
Home Page: http://grumpy.website
mkdir grumpy_data
./script/bootstrap.sh
./script/repl.sh
open http://localhost:8080
Us:
<content type="text/html"><p><video autoplay="autoplay" loop="loop" style="max-width:550px;height:auto;max-height:500px"><source type="video/mp4" src="https://grumpy.website/post/0TVUDglhS/M3fbtVu.orig.mp4"/></video></p><p><strong>nikitonsky: </strong>very helpful icons, thank you</p></content>
This works (from https://www.underconsideration.com/brandnew/atom.xml):
<video autoplay loop muted playsinline controls controlsList="nodownload"><source src="https://www.underconsideration.com/brandnew/archives/cruise_car_car_origin.mp4" type="video/mp4">Your browser does not support the video tag.</video>
15:10:50.543 ERROR i.p.http.impl.servlet-interceptor: {:msg "error-stylobate triggered", :context {:response {:status 200, :headers {"X-Frame-Options" "DENY", "X-XSS-Protection" "1; mode=block", "Last-Modified" "Sun, 12 May 2019 21:
40:17 GMT", "X-Download-Options" "noopen", "Strict-Transport-Security" "max-age=31536000; includeSubdomains", "X-Permitted-Cross-Domain-Policies" "none", "Cache-Control" "max-age=315360000", "Content-Length" "9647", "X-Content-Type-
Options" "nosniff", "Content-Security-Policy" "object-src 'none'; script-src 'self' 'unsafe-inline' 'unsafe-eval'", "Content-Type" "image/jpeg"}, :body #object[sun.net.www.protocol.jar.JarURLConnection$JarURLInputStream 0x5dc965dc "
sun.net.www.protocol.jar.JarURLConnection$JarURLInputStream@5dc965dc"]}, :io.pedestal.interceptor.chain/stack (#Interceptor{:name :io.pedestal.http.impl.servlet-interceptor/terminator-injector}), :request {:protocol "HTTP/1.1", :asy
nc-supported? true, :remote-addr "127.0.0.1", :servlet-response #object[io.undertow.servlet.spec.HttpServletResponseImpl 0x397fb1c1 "io.undertow.servlet.spec.HttpServletResponseImpl@397fb1c1"], :servlet #object[io.pedestal.http.serv
let.FnServlet 0x49d267a "io.pedestal.http.servlet.FnServlet@49d267a"], :headers {"referer" "https://grumpy.website/", "accept-language" "en-GB,en;q=0.5", "connection" "close", "host" "127.0.0.1:7000", "dnt" "1", "accept-encoding" "g
zip, deflate, br", "accept" "image/webp,*/*", "user-agent" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:66.0) Gecko/20100101 Firefox/66.0"}, :server-port 7000, :servlet-request #object[io.undertow.servlet.spec.HttpServletRequestImp
l 0x3904eb6e "HttpServletRequestImpl [ GET /static/nikitonsky.jpg ]"], :path-info "/static/nikitonsky.jpg", :url-for #object[clojure.lang.Delay 0x6b40c391 {:status :pending, :val nil}], :uri "/static/nikitonsky.jpg", :server-name "1
27.0.0.1", :query-string nil, :path-params {:path "nikitonsky.jpg"}, :body #object[io.undertow.servlet.spec.ServletInputStreamImpl 0x1b447269 "io.undertow.servlet.spec.ServletInputStreamImpl@1b447269"], :scheme :http, :request-method :get, :context-path ""}, :bindings {#'io.pedestal.http.route/*url-for* #object[clojure.lang.Delay 0x6b40c391 {:status :pending, :val nil}]}, :enter-async [#object[io.pedestal.http.impl.servlet_interceptor$start_servlet_async 0x6cdfe65e "io.pedestal.http.impl.servlet_interceptor$start_servlet_async@6cdfe65e"]], :io.pedestal.interceptor.chain/terminators (#object[io.pedestal.http.impl.servlet_interceptor$terminator_inject$fn__17139 0x5eea08d4 "io.pedestal.http.impl.servlet_interceptor$terminator_inject$fn__17139@5eea08d4"]), :servlet-response #object[io.undertow.servlet.spec.HttpServletResponseImpl 0x397fb1c1 "io.undertow.servlet.spec.HttpServletResponseImpl@397fb1c1"], :route {:path "/static/*path", :method :get, :path-constraints {:path "(.*)"}, :path-re #"/\Qstatic\E/(.*)", :path-parts ["static" :path], :interceptors [#Interceptor{:name } #Interceptor{:name }], :route-name :get:/static/*path, :path-params {:path "nikitonsky.jpg"}, :matcher #object[io.pedestal.http.route.linear_search$matcher$fn__12878 0x100a854a "io.pedestal.http.route.linear_search$matcher$fn__12878@100a854a"]}, :servlet #object[io.pedestal.http.servlet.FnServlet 0x49d267a "io.pedestal.http.servlet.FnServlet@49d267a"], :servlet-request #object[io.undertow.servlet.spec.HttpServletRequestImpl 0x3904eb6e "HttpServletRequestImpl [ GET /static/nikitonsky.jpg ]"], :url-for #object[clojure.lang.Delay 0x6b40c391 {:status :pending, :val nil}], :io.pedestal.interceptor.chain/execution-id 146, :servlet-config #object[io.undertow.servlet.spec.ServletConfigImpl 0x57ae1680 "io.undertow.servlet.spec.ServletConfigImpl@57ae1680"], :async? #object[io.pedestal.http.impl.servlet_interceptor$servlet_async_QMARK_ 0x336d6e69 "io.pedestal.http.impl.servlet_interceptor$servlet_async_QMARK_@336d6e69"]}, :line 242}
clojure.lang.ExceptionInfo: java.io.IOException in Interceptor :io.pedestal.http.impl.servlet-interceptor/ring-response - Broken pipe
at io.pedestal.interceptor.chain$throwable__GT_ex_info.invokeStatic(chain.clj:35) ~[na:na]
at io.pedestal.interceptor.chain$throwable__GT_ex_info.invoke(chain.clj:32) ~[na:na]
at io.pedestal.interceptor.chain$try_f.invokeStatic(chain.clj:57) ~[na:na]
at io.pedestal.interceptor.chain$try_f.invoke(chain.clj:44) ~[na:na]
at io.pedestal.interceptor.chain$leave_all_with_binding.invokeStatic(chain.clj:254) [na:na]
at io.pedestal.interceptor.chain$leave_all_with_binding.invoke(chain.clj:237) [na:na]
at io.pedestal.interceptor.chain$leave_all$fn__12228.invoke(chain.clj:268) [na:na]
at clojure.lang.AFn.applyToHelper(AFn.java:152) [grumpy.jar:na]
at clojure.lang.AFn.applyTo(AFn.java:144) [grumpy.jar:na]
at clojure.core$apply.invokeStatic(core.clj:665) [grumpy.jar:na]
at clojure.core$with_bindings_STAR_.invokeStatic(core.clj:1973) [grumpy.jar:na]
at clojure.core$with_bindings_STAR_.doInvoke(core.clj:1973) [grumpy.jar:na]
at clojure.lang.RestFn.invoke(RestFn.java:425) [grumpy.jar:na]
at io.pedestal.interceptor.chain$leave_all.invokeStatic(chain.clj:266) [na:na]
at io.pedestal.interceptor.chain$leave_all.invoke(chain.clj:260) [na:na]
at io.pedestal.interceptor.chain$execute.invokeStatic(chain.clj:379) [na:na]
at io.pedestal.interceptor.chain$execute.invoke(chain.clj:352) [na:na]
at io.pedestal.interceptor.chain$execute.invokeStatic(chain.clj:389) [na:na]
at io.pedestal.interceptor.chain$execute.invoke(chain.clj:352) [na:na]
at io.pedestal.http.impl.servlet_interceptor$interceptor_service_fn$fn__17164.invoke(servlet_interceptor.clj:351) [na:na]
at io.pedestal.http.servlet.FnServlet.service(servlet.clj:28) [na:na]
at io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85) [grumpy.jar:na]
at io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:129) [grumpy.jar:na]
at org.projectodd.wunderboss.web.async.websocket.WebSocketHelpyHelpertonFilter.doFilter(WebSocketHelpyHelpertonFilter.java:80) [grumpy.jar:na]
at io.undertow.servlet.core.ManagedFilter.doFilter(ManagedFilter.java:61) [grumpy.jar:na]
at io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:131) [grumpy.jar:na]
at io.undertow.servlet.handlers.FilterHandler.handleRequest(FilterHandler.java:84) [grumpy.jar:na]
at io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:62) [grumpy.jar:na]
at io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36) [grumpy.jar:na]
at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131) [grumpy.jar:na]
at io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:57) [grumpy.jar:na]
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [grumpy.jar:na]
at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:46) [grumpy.jar:na]
at io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:64) [grumpy.jar:na]
at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:60) [grumpy.jar:na]
at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:77) [grumpy.jar:na]
Caused by: java.io.IOException: Broken pipe
at sun.nio.ch.FileDispatcherImpl.writev0(Native Method) ~[na:1.8.0_77]
at sun.nio.ch.SocketDispatcher.writev(SocketDispatcher.java:51) ~[na:1.8.0_77]
at sun.nio.ch.IOUtil.write(IOUtil.java:148) ~[na:1.8.0_77]
at sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:504) ~[na:1.8.0_77]
at org.xnio.nio.NioSocketConduit.write(NioSocketConduit.java:161) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.processStatefulWrite(HttpResponseConduit.java:472) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.processWrite(HttpResponseConduit.java:214) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.write(HttpResponseConduit.java:632) ~[grumpy.jar:na]
at io.undertow.conduits.AbstractFixedLengthStreamSinkConduit.write(AbstractFixedLengthStreamSinkConduit.java:148) ~[grumpy.jar:na]
at org.xnio.conduits.ConduitStreamSinkChannel.write(ConduitStreamSinkChannel.java:158) ~[grumpy.jar:na]
at io.undertow.channels.DetachableStreamSinkChannel.write(DetachableStreamSinkChannel.java:179) ~[grumpy.jar:na]
at io.undertow.server.HttpServerExchange$WriteDispatchChannel.write(HttpServerExchange.java:2014) ~[grumpy.jar:na]
at org.xnio.channels.Channels.writeBlocking(Channels.java:152) ~[grumpy.jar:na]
at io.undertow.servlet.spec.ServletOutputStreamImpl.writeTooLargeForBuffer(ServletOutputStreamImpl.java:193) ~[grumpy.jar:na]
at io.undertow.servlet.spec.ServletOutputStreamImpl.write(ServletOutputStreamImpl.java:141) ~[grumpy.jar:na]
at clojure.java.io$fn__11534.invokeStatic(io.clj:307) ~[grumpy.jar:na]
at clojure.java.io$fn__11534.invoke(io.clj:302) ~[grumpy.jar:na]
at clojure.lang.MultiFn.invoke(MultiFn.java:239) ~[grumpy.jar:na]
at clojure.java.io$copy.invokeStatic(io.clj:406) ~[grumpy.jar:na]
at clojure.java.io$copy.doInvoke(io.clj:391) ~[grumpy.jar:na]
at clojure.lang.RestFn.invoke(RestFn.java:425) [grumpy.jar:na]
at io.pedestal.http.impl.servlet_interceptor$eval16797$fn__16800.invoke(servlet_interceptor.clj:78) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$eval16761$fn__16762$G__16752__16769.invoke(servlet_interceptor.clj:38) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$write_body.invokeStatic(servlet_interceptor.clj:93) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$write_body.invoke(servlet_interceptor.clj:91) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$send_response.invokeStatic(servlet_interceptor.clj:170) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$send_response.invoke(servlet_interceptor.clj:162) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$leave_ring_response.invokeStatic(servlet_interceptor.clj:229) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$leave_ring_response.invoke(servlet_interceptor.clj:218) ~[na:na]
at io.pedestal.interceptor.chain$try_f.invokeStatic(chain.clj:54) ~[na:na]
... 51 common frames omitted
Videos with no audio are displayed as gif, inline, in small size with no controls.
Картинки должны стать ссылками, которые открывают сами себя (.jpg/.png) в новом окне
https://twitter.com/dtruebin/status/1255076432977506307
@dmitriid's video on https://grumpy.website/post/0Tdy2H0Td is painful to watch in that small size, and there is no way to open it in full screen.
Как одно из решение сделать чтобы автоподгрузка срабатывала только 2-3 раза, а потом показывать кнопку подгрузить еще
.
The feed is broken: https://grumpy.website/feed.xml
What the web site generates:
<feed xmlns:b="http://www.w3.org/2005/Atom" xml:lang="ru">
It really should be xmlns
instead of xmlns:b
. Not sure why this happens, the code seems correct, but this prevents my RSS client from rendering the feed
because some rss readers don't extract images from HTML body.
Example:
<entry>
...
<link rel="enclosure"
type="image/jpeg"
title="dunno" # skip
href="http://www.example.org/funny.jpg"
length="1234" /> # skip
либо удаление, либо замена, приводят к состоянию ошибки и потом только перезагрузка редактора
Должны всегда сжиматься пропорционально. Засада в том, что у некоторых из них размер известен (и подставляется), а у некоторых нет. В принципе, это может быть два разных решения на эти два случая. Надо CSS кун-фу
Могу сделать пулреквест. Что думаешь?
it blocks access to the video element making it impossible (okay, annoying as you have to inspect it, copy relative path and join it with base) to display it in full size for example
https://twitter.com/jaroslawjarosik/status/1165950021667307520
Caused by: java.lang.NullPointerException: instant
at java.base/java.util.Objects.requireNonNull(Objects.java:247) ~[na:na]
at java.base/java.time.LocalDate.ofInstant(LocalDate.java:319) ~[na:na]
at grumpy.time$format_date.invokeStatic(time.clj:15) ~[na:na]
at grumpy.time$format_date.invoke(time.clj:14) ~[na:na]
at grumpy.server$fn__19317.invokeStatic(server.clj:70) ~[na:na]
at grumpy.server$fn__19317.invoke(server.clj:28) ~[na:na]
at clojure.lang.AFn.applyToHelper(AFn.java:154) ~[grumpy.jar:na]
at clojure.lang.AFn.applyTo(AFn.java:144) ~[grumpy.jar:na]
at clojure.core$apply.invokeStatic(core.clj:665) ~[grumpy.jar:na]
at clojure.core$apply.invoke(core.clj:660) ~[grumpy.jar:na]
at rum.core$build_defc$fn__521.doInvoke(core.clj:137) ~[na:na]
at clojure.lang.RestFn.invoke(RestFn.java:408) ~[grumpy.jar:na]
at grumpy.server$fn__19361.invokeStatic(server.clj:88) ~[na:na]
at grumpy.server$fn__19361.invoke(server.clj:86) ~[na:na]
at clojure.lang.AFn.applyToHelper(AFn.java:154) ~[grumpy.jar:na]
at clojure.lang.AFn.applyTo(AFn.java:144) ~[grumpy.jar:na]
at clojure.core$apply.invokeStatic(core.clj:665) ~[grumpy.jar:na]
at clojure.core$apply.invoke(core.clj:660) ~[grumpy.jar:na]
at rum.core$build_defc$fn__521.doInvoke(core.clj:137) ~[na:na]
at clojure.lang.RestFn.invoke(RestFn.java:408) ~[grumpy.jar:na]
at grumpy.server$fn__19373.invokeStatic(server.clj:108) ~[na:na]
at grumpy.server$fn__19373.invoke(server.clj:107) ~[na:na]
at io.pedestal.interceptor$eval694$fn__695$fn__696.invoke(interceptor.clj:41) ~[na:na]
at io.pedestal.interceptor.chain$try_f.invokeStatic(chain.clj:54) ~[na:na]
... 53 common frames omitted
Calling convert (or any external process) could OOM
Nil dimensions could be written
Nil dimensions fail to render post
Mar 26 21:13:38 hosting postfix/pickup[8378]: 2B03AE20BC: uid=1004 from=<[email protected]>
Mar 26 21:13:38 hosting postfix/cleanup[8453]: 2B03AE20BC: message-id=<20180326181338.2B03AE20BC@hosting>
Mar 26 21:13:38 hosting postfix/qmgr[1075]: 2B03AE20BC: from=<[email protected]>, size=706, nrcpt=1 (queue active)
Mar 26 21:13:38 hosting postfix/smtp[8455]: 2B03AE20BC: to=<[email protected]>, relay=aspmx.l.google.com[2a00:1450:400c:c09::1a]:25, delay=0.41, delays=0.02/0.01/0.16/0.23, dsn=5.7.1, status=bounced (host aspmx.l.google.com[2a00:1450:400c:c09::1a] said: 550-5.7.1 This message does not have authentication information or fails to pass 550-5.7.1 authentication checks. To best protect our users from spam, the 550-5.7.1 message has been blocked. Please visit 550-5.7.1 https://support.google.com/mail/answer/81126#authentication for more 550 5.7.1 information. s3si80784wri.3 - gsmtp (in reply to end of DATA command))
Mar 26 21:13:38 hosting postfix/cleanup[8453]: 91C6FE20BD: message-id=<20180326181338.91C6FE20BD@hosting>
Mar 26 21:13:38 hosting postfix/qmgr[1075]: 91C6FE20BD: from=<>, size=3179, nrcpt=1 (queue active)
Mar 26 21:13:38 hosting postfix/bounce[8456]: 2B03AE20BC: sender non-delivery notification: 91C6FE20BD
Mar 26 21:13:38 hosting postfix/qmgr[1075]: 2B03AE20BC: removed
Mar 26 21:13:40 hosting postfix/smtp[8455]: 91C6FE20BD: to=<[email protected]>, relay=eforward2.registrar-servers.com[162.255.118.62]:25, delay=1.8, delays=0/0/1.1/0.65, dsn=5.0.0, status=bounced (host eforward2.registrar-servers.com[162.255.118.62] said: 550 Access denied - Invalid HELO name (See RFC5321 4.1.1.1) (in reply to RCPT TO command))
Mar 26 21:13:40 hosting postfix/qmgr[1075]: 91C6FE20BD: removed
550-5.7.1 This message does not have authentication information or fails to pass 550-5.7.1 authentication checks. To best protect our users from spam, the 550-5.7.1 message has been blocked. Please visit 550-5.7.1 https://support.google.com/mail/answer/81126#authentication for more 550 5.7.1 information.
https://support.google.com/mail/answer/81126#authentication
To ensure that Gmail can identify you:
Use a consistent IP address to send bulk mail.
Keep valid reverse DNS records for the IP address(es) from which you send mail, pointing to your domain.
Use the same address in the 'From:' header on every bulk mail you send.
We also recommend the following:
Sign messages with DKIM. We do not authenticate messages signed with keys using fewer than 1024 bits.
Publish an SPF record.
Publish a DMARC policy.
https://toolbox.googleapps.com/apps/checkmx/check?domain=grumpy.website&dkim_selector=
Если зайти в редактирование поста и поменять только текст, при сохранении уже существующая картинка удалится. Надо так:
http://lichess.org/
должно рендериться как lichess.org
, а не lichess.org/
https://core.telegram.org/bots/api#editmessagemedia
(post! "@grumpy_test" "/editMessageMedia"
{:chat_id "@grumpy_test"
:message_id 51
:media {:type "photo"
:media "https://grumpy.website/post/0ZnG78YKt/Nb02EKK.fit.jpeg"}})
Каким-то образом вот этот пост https://grumpy.website/post/0PISqXJzk опубликовался под анонимом. Внутри edn-файла не было ключа :author
.
Возможно, это связано с черновиками: сначала я создал этот пост: https://grumpy.website/post/0PISe1tMj Затем открыл форму создания нового, но смутился тем, что в форме уже был контент предыдущего поста. Как я понимаю, туда подставился черновик. Я подумал, что по ошибке правлю старый пост, нажал "назад", потом опять плюсик. Удалил контент из формы, нажал сабмит -- пост создался под анонимом.
Полагаю, нужно как-то следить, что если пост успешно ушел на сервер, то черновик удалять. На сервере всегда проверять, что автор заполнен, потому что аноним не может создать пост сам.
В идеале можно было бы добавить в форму поле "автор" для гостевого или анонимного поста. По умолчанию в нем ник текущего пользователя. Можно вписать иное для гостевого поста. Если пусто, то анонимный.
Caused by: java.io.IOException: Connection reset by peer
at java.base/sun.nio.ch.FileDispatcherImpl.writev0(Native Method) ~[na:na]
at java.base/sun.nio.ch.SocketDispatcher.writev(SocketDispatcher.java:51) ~[na:na]
at java.base/sun.nio.ch.IOUtil.write(IOUtil.java:182) ~[na:na]
at java.base/sun.nio.ch.IOUtil.write(IOUtil.java:130) ~[na:na]
at java.base/sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:496) ~[na:na]
at org.xnio.nio.NioSocketConduit.write(NioSocketConduit.java:161) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.processStatefulWrite(HttpResponseConduit.java:472) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.processWrite(HttpResponseConduit.java:214) ~[grumpy.jar:na]
at io.undertow.server.protocol.http.HttpResponseConduit.write(HttpResponseConduit.java:632) ~[grumpy.jar:na]
at io.undertow.conduits.AbstractFixedLengthStreamSinkConduit.write(AbstractFixedLengthStreamSinkConduit.java:148) ~[grumpy.jar:na]
at org.xnio.conduits.ConduitStreamSinkChannel.write(ConduitStreamSinkChannel.java:158) ~[grumpy.jar:na]
at io.undertow.channels.DetachableStreamSinkChannel.write(DetachableStreamSinkChannel.java:179) ~[grumpy.jar:na]
at io.undertow.server.HttpServerExchange$WriteDispatchChannel.write(HttpServerExchange.java:2014) ~[grumpy.jar:na]
at org.xnio.channels.Channels.writeBlocking(Channels.java:152) ~[grumpy.jar:na]
at io.undertow.servlet.spec.ServletOutputStreamImpl.writeTooLargeForBuffer(ServletOutputStreamImpl.java:193) ~[grumpy.jar:na]
at io.undertow.servlet.spec.ServletOutputStreamImpl.write(ServletOutputStreamImpl.java:141) ~[grumpy.jar:na]
at clojure.java.io$fn__11530.invokeStatic(io.clj:307) ~[grumpy.jar:na]
at clojure.java.io$fn__11530.invoke(io.clj:302) ~[grumpy.jar:na]
at clojure.lang.MultiFn.invoke(MultiFn.java:239) ~[grumpy.jar:na]
at clojure.java.io$copy.invokeStatic(io.clj:406) ~[grumpy.jar:na]
at clojure.java.io$copy.doInvoke(io.clj:391) ~[grumpy.jar:na]
at clojure.lang.RestFn.invoke(RestFn.java:425) ~[grumpy.jar:na]
at io.pedestal.http.impl.servlet_interceptor$eval16814$fn__16817.invoke(servlet_interceptor.clj:78) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$eval16778$fn__16779$G__16769__16786.invoke(servlet_interceptor.clj:38) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$write_body.invokeStatic(servlet_interceptor.clj:93) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$write_body.invoke(servlet_interceptor.clj:91) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$send_response.invokeStatic(servlet_interceptor.clj:170) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$send_response.invoke(servlet_interceptor.clj:162) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$leave_ring_response.invokeStatic(servlet_interceptor.clj:229) ~[na:na]
at io.pedestal.http.impl.servlet_interceptor$leave_ring_response.invoke(servlet_interceptor.clj:218) ~[na:na]
at io.pedestal.interceptor.chain$try_f.invokeStatic(chain.clj:54) ~[na:na]
... 51 common frames omitted
A declarative, efficient, and flexible JavaScript library for building user interfaces.
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google ❤️ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.