Giter VIP home page Giter VIP logo

grumpy's Introduction

Minimalistic blog engine

Grumpy.website

Runtime dependencies

  • JDK 14
  • imagemagick
  • mailutils
  • ffmpeg

Development

mkdir grumpy_data
./script/bootstrap.sh
./script/repl.sh
open http://localhost:8080

grumpy's People

Contributors

agudulin avatar d1skort avatar igrishaev avatar kharin avatar neronmoon avatar tonsky avatar zelark avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

grumpy's Issues

Feedly does not play Atom video

Us:

<content type="text/html">&lt;p&gt;&lt;video autoplay=&quot;autoplay&quot; loop=&quot;loop&quot; style=&quot;max-width:550px;height:auto;max-height:500px&quot;&gt;&lt;source type=&quot;video/mp4&quot; src=&quot;https://grumpy.website/post/0TVUDglhS/M3fbtVu.orig.mp4&quot;/&gt;&lt;/video&gt;&lt;/p&gt;&lt;p&gt;&lt;strong&gt;nikitonsky: &lt;/strong&gt;very helpful icons, thank you&lt;/p&gt;</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>

Get rid of “broken pipe” exception in Pedestal

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

Fix upside-down mode

  • the orientation should persist through page reloading (cookies?)
  • on-the-fly content uploading should consider the orientation

Add enclosure links with images

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 кун-фу

NullPointerException: instant

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

Catch nil dimention/OOMs

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=
screen shot 2018-03-27 at 12 02 43

Картинка не сохраняется при редактировании

Если зайти в редактирование поста и поменять только текст, при сохранении уже существующая картинка удалится. Надо так:

  • При редактировании, если файл не указан, то оставить старый
  • При редактировании, если файл указан, удалить старый, загрузить/прописать новый
  • Отдельный баг: при создании заметки, если файл не указан, сохранить пост без картинки (сейчас там он создает пустой файл в этом случае)

Не заполняется автор поста

Каким-то образом вот этот пост https://grumpy.website/post/0PISqXJzk опубликовался под анонимом. Внутри edn-файла не было ключа :author.

Возможно, это связано с черновиками: сначала я создал этот пост: https://grumpy.website/post/0PISe1tMj Затем открыл форму создания нового, но смутился тем, что в форме уже был контент предыдущего поста. Как я понимаю, туда подставился черновик. Я подумал, что по ошибке правлю старый пост, нажал "назад", потом опять плюсик. Удалил контент из формы, нажал сабмит -- пост создался под анонимом.

Полагаю, нужно как-то следить, что если пост успешно ушел на сервер, то черновик удалять. На сервере всегда проверять, что автор заполнен, потому что аноним не может создать пост сам.

В идеале можно было бы добавить в форму поле "автор" для гостевого или анонимного поста. По умолчанию в нем ник текущего пользователя. Можно вписать иное для гостевого поста. Если пусто, то анонимный.

Do not log java.io.IOException: Connection reset by peer

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

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.