A Clojure library to use the Blink Camera REST API.
The library interacts with the REST API of the cloud service. Those servers do the actual talking with your Blink devices. That is, you need an internet connection.
The protocol is not officially disclosed but has been reverse engineered by Matt Weinecke. See https://github.com/MattTW/BlinkMonitorProtocol
Require the library in your source code
(require '[fourteatoo.clj-blink.api :as blink])
The first time you use the library you need to register your client
and obtain a unique id (returned in the resulting BlinkClient
object).
(def client (blink/register-client "your@mail.address" "yourpassword"))
This will trigger whatever you have configured for 2FA. A PIN will be sent by Blink to your designated authentication means: an email, an SMS, whatever. Type it in.
register-client returns a BlinkClient object like the following:
{:user "your@email.address",
 :password "yourpassword",
 :auth-tokens #<Atom@73fdfb7f: "....">,
 :tier "yourregion,
 :account-id 42,
 :tulsa-id 1337}
Any subsequent authentications (next time your app restarts) should instead do:
(def client (blink/authenticate-client "your@mail.address" "yourpassword" "refresh-token"))
The username and password are the same as those used for the
register-client.  The refresh-token is within the client
object returned by register-client (see above).
(blink/refresh-token client)
The authentication expires after a while but it is automatically renewed by this libary.
You can use your client parameters like this:
(blink/get-networks client)
which will return something like:
{:summary {12345 {:name "Home", :onboarded true}},
 :networks
 [{:description "",
   :updated-at "2025-06-02T15:47:52+00:00",
   :autoarm-geo-enable false,
   :video-count 0,
   :dst true,
   :storage-total 0,
   :locale "",
   :lfr-channel 0,
   :name "Home",
   :video-history-count 4000,
   :arm-string nil,
   :ping-interval 60,
   :armed false,
   :busy nil,
   :account-id 42,
   :sync-module-error nil,
   :id 12345,
   :storage-used 0,
   :camera-error nil,
   :location-id nil,
   :lv-mode "relay",
   :feature-plan-id nil,
   :video-destination "server",
   :encryption-key nil,
   :autoarm-time-enable false,
   :network-origin "normal",
   :created-at "2015-12-13T21:13:19+00:00",
   :sm-backup-enabled false,
   :time-zone "Europe/Berlin",
   :network-key "abase64string"}]}
then you can, for instance, arm all your systems (assuming you have more than one):
(->> (blink/get-networks client)
     :networks
     (run! #(blink/system-arm client (:id %))))
or disarm them, substituting system-arm for system-disarm.
or you can create your own local documentation with:
$ lein codox
and then read it with your favorite browser
$ firefox target/doc/index.html
Copyright © 2025 Walter C. Pelissero
This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which is available at http://www.eclipse.org/legal/epl-2.0.
This Source Code may also be made available under the following Secondary Licenses when the conditions for such availability set forth in the Eclipse Public License, v. 2.0 are satisfied: GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version, with the GNU Classpath Exception which is available at https://www.gnu.org/software/classpath/license.html.
Can you improve this documentation?Edit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |