diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/clojure/contrib/http/connection.clj | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/src/clojure/contrib/http/connection.clj b/src/clojure/contrib/http/connection.clj new file mode 100644 index 00000000..81d897c9 --- /dev/null +++ b/src/clojure/contrib/http/connection.clj @@ -0,0 +1,56 @@ +;;; http/connection.clj: low-level HTTP client API around HttpURLConnection + +;; by Stuart Sierra, http://stuartsierra.com/ +;; June 8, 2009 + +;; Copyright (c) Stuart Sierra, 2009. All rights reserved. The use +;; and distribution terms for this software are covered by the Eclipse +;; Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php) +;; which can be found in the file epl-v10.html at the root of this +;; distribution. By using this software in any fashion, you are +;; agreeing to be bound by the terms of this license. You must not +;; remove this notice, or any other, from this software. + +(ns #^{:doc "Low-level HTTP client API around HttpURLConnection"} + clojure.contrib.http.connection + (:require [clojure.contrib.duck-streams :as duck] + [clojure.contrib.java-utils :as j]) + (:import (java.net URI URL HttpURLConnection) + (java.io File InputStream Reader))) + +(defn http-connection + "Opens an HttpURLConnection at the URL, handled by as-url." + [url] + (.openConnection (j/as-url url))) + +(defmulti + #^{:doc "Transmits a request entity body."} + send-request-entity (fn [conn entity] (type entity))) + +(defmethod send-request-entity duck/*byte-array-type* [conn entity] + (.setFixedLenghtStreamingMode conn (count entity)) + (duck/copy entity (.getOutputStream conn))) + +(defmethod send-request-entity String [conn entity] + (send-request-entity conn (.getBytes entity duck/*default-encoding*))) + +(defmethod send-request-entity File [conn entity] + (.setFixedLengthStreamingMode conn (.length entity)) + (duck/copy entity (.getOutputStream conn))) + +(defmethod send-request-entity InputStream [conn entity] + (.setChunkedStreamingMode conn -1) + (duck/copy entity (.getOutputStream conn))) + +(defmethod send-request-entity Reader [conn entity] + (.setChunkedStreamingMode conn -1) + (duck/copy entity (.getOutputStream conn))) + +(defn start-http-connection + ([conn] (.connect conn)) + ([conn request-entity-body] + (if request-entity-body + (do (.setDoOutput conn true) + (.connect conn) + (send-request-entity conn request-entity-body)) + (.connect conn)))) |