mirror of
https://github.com/status-im/status-react.git
synced 2025-01-11 03:26:31 +00:00
[fix] ipfs CID
Signed-off-by: Andrey Shovkoplyas <motor4ik@gmail.com>
This commit is contained in:
parent
1ff0a937ac
commit
b0449f3416
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
;; we currently use an ipfs gateway but this detail is not relevant
|
;; we currently use an ipfs gateway but this detail is not relevant
|
||||||
;; outside of this namespace
|
;; outside of this namespace
|
||||||
(def ^:const ipfs-add-url "https://ipfs.infura.io:5001/api/v0/add")
|
(def ^:const ipfs-add-url "https://ipfs.infura.io:5001/api/v0/add?cid-version=1")
|
||||||
(def ^:const ipfs-cat-url "https://ipfs.infura.io/ipfs/")
|
(def ^:const ipfs-cat-url "https://ipfs.infura.io/ipfs/")
|
||||||
|
|
||||||
(fx/defn cat
|
(fx/defn cat
|
||||||
@ -30,10 +30,11 @@
|
|||||||
:size Size})))
|
:size Size})))
|
||||||
|
|
||||||
(fx/defn add
|
(fx/defn add
|
||||||
|
"Add `value` on ipfs, and returns its b58 encoded CID"
|
||||||
[cofx {:keys [value on-success on-failure]}]
|
[cofx {:keys [value on-success on-failure]}]
|
||||||
(let [formdata (doto (js/FormData.)
|
(let [formdata (doto (js/FormData.)
|
||||||
;; the key is ignored so there is no need to provide one
|
;; the key is ignored so there is no need to provide one
|
||||||
(.append nil value))]
|
(.append "file" value))]
|
||||||
{:http-raw-post (cond-> {:url ipfs-add-url
|
{:http-raw-post (cond-> {:url ipfs-add-url
|
||||||
:body formdata
|
:body formdata
|
||||||
:timeout-ms 5000
|
:timeout-ms 5000
|
||||||
|
@ -11,13 +11,23 @@
|
|||||||
(defn encode [{:keys [hash namespace ipld]}]
|
(defn encode [{:keys [hash namespace ipld]}]
|
||||||
(when (and hash
|
(when (and hash
|
||||||
(= namespace :ipfs)
|
(= namespace :ipfs)
|
||||||
(= 46 (count hash))
|
|
||||||
(nil? ipld))
|
(nil? ipld))
|
||||||
(str "0xe301" (hex/encode (b58/decode hash)))))
|
(when-let [b58-hash (if (string/starts-with? hash "z")
|
||||||
|
(when (= (count hash) 49)
|
||||||
|
;; this is a CID multihash
|
||||||
|
;; the z is removed, it indicates that the
|
||||||
|
;; CID is b58 encoded
|
||||||
|
(subs hash 1))
|
||||||
|
(when (= (count hash) 46)
|
||||||
|
;; this is a deprecated simple ipfs hash
|
||||||
|
hash))]
|
||||||
|
(str "0xe301" (hex/encode (b58/decode b58-hash))))))
|
||||||
|
|
||||||
(defn decode [hex]
|
(defn decode [hex]
|
||||||
(when (and hex (not= hex "0x")
|
(when (and hex (not= hex "0x")
|
||||||
(string/starts-with? hex "0xe30101")
|
(string/starts-with? hex "0xe30101")
|
||||||
|
;; TODO properly decode the CID
|
||||||
|
;; extract the content-type using varint ns
|
||||||
(= 78 (count hex)))
|
(= 78 (count hex)))
|
||||||
{:namespace :ipfs
|
{:namespace :ipfs
|
||||||
:hash (-> hex
|
:hash (-> hex
|
||||||
|
@ -23,6 +23,11 @@
|
|||||||
{:namespace :ipfs
|
{:namespace :ipfs
|
||||||
:hash "QmRAQB6YaCyidP37UdDnjFY5vQuiBrcqdyoW1CuDgwxkD4"})
|
:hash "QmRAQB6YaCyidP37UdDnjFY5vQuiBrcqdyoW1CuDgwxkD4"})
|
||||||
"0xe301122029f2d17be6139079dc48696d1f582a8530eb9805b561eda517e22a892c7e3f1f")))
|
"0xe301122029f2d17be6139079dc48696d1f582a8530eb9805b561eda517e22a892c7e3f1f")))
|
||||||
|
(testing "encoding a valid ipfs cid"
|
||||||
|
(is (= (contenthash/encode
|
||||||
|
{:namespace :ipfs
|
||||||
|
:hash "zb2rhZfjRh2FHHB2RkHVEvL2vJnCTcu7kwRqgVsf9gpkLgteo"})
|
||||||
|
"0xe301015512202cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824")))
|
||||||
(testing "encoding an invalid ipfs hash"
|
(testing "encoding an invalid ipfs hash"
|
||||||
(is (nil? (contenthash/encode {:namespace :ipfs
|
(is (nil? (contenthash/encode {:namespace :ipfs
|
||||||
:hash "0xe301122029f2d17be6139079dc48696d1f582a8530eb9805b561eda517e2"}))))
|
:hash "0xe301122029f2d17be6139079dc48696d1f582a8530eb9805b561eda517e2"}))))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user