-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmatterless.el
73 lines (55 loc) · 2.23 KB
/
matterless.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
;;; matterless.el --- MatterMost client for Emacs -*- lexical-binding: t; -*-
;; Copyright (C) 2019-2020 Gaelan D'costa
;; Author: Gaelan D'costa <[email protected]>
;; Version: 0.0.1
;; Created: April 07, 2019
;; Keywords: chat, mattermost
;; Homepage: https://github.com/RobotDisco/matterless
;; This file is not part of GNU Emacs.
;; This program is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; I have no idea how Emacs Lisp programs are written, let's find out!
;; No doubt I will be shamelessly inspired by the amazing slack client written
;; by Yuya Minami over at https://github.com/yuya373/emacs-slack/
;;; Code:
(require 'json)
(require 'request)
(defgroup matterless nil
"Emacs Mattermost Client"
:prefix "matterless-"
:group 'tools)
(defcustom matterless-server-url nil
"URL of the mattermost server we will be talking to."
:type 'string
:group 'matterless)
(defun matterless-api-prefix ()
"Return the full url of the base Mattermost API path."
(concat matterless-server-url "/api/v4/"))
(defcustom matterless-username nil
"Username of our mattermost server."
:type 'string
:group 'matterless)
(defcustom matterless-password nil
"User password of our mattermost server."
:type 'string
:group 'matterless)
(defun matterless-request-login ()
"Login to mattermost."
(let ((req (request
(concat (matterless-api-prefix) "users/login")
:data (json-encode `(("login_id" . ,matterless-username)
("password" . ,matterless-password)))
:parser 'json-read
:sync t)))
(request-response-data req)))
(provide 'matterless)
;;; matterless.el ends here