From 96f4b3627b3cbb38b28ba07206fb6196e71e212a Mon Sep 17 00:00:00 2001 From: Johnson Denen Date: Sat, 8 Apr 2017 07:23:07 -0400 Subject: Refactor authorization --- lisp/mastodon-toot.el | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 lisp/mastodon-toot.el (limited to 'lisp/mastodon-toot.el') diff --git a/lisp/mastodon-toot.el b/lisp/mastodon-toot.el new file mode 100644 index 0000000..82fac8c --- /dev/null +++ b/lisp/mastodon-toot.el @@ -0,0 +1,45 @@ +(require 'mastodon-auth) +(require 'mastodon-http) + +(defgroup mastodon-toot nil + "Capture Mastodon toots." + :group 'mastodon) + +(defun mastodon-new-toot () + (interactive) + (progn + (switch-to-buffer-other-window (get-buffer-create "*new toot*")) + (mastodon-toot-mode t))) + +(defun mastodon-toot--send () + (interactive) + (let ((toot (buffer-string)) + (endpoint (mastodon--api-for "statuses"))) + (progn + (kill-buffer-and-window) + (mastodon--http-post endpoint + (lambda (status) (switch-to-buffer (current-buffer))) ;; FIXME + `(("status" . ,toot) + ("visibility" . "public")) + `(("Authorization" . ,(concat + "Bearer " + (mastodon--access-token)))))))) + +(defun mastodon-toot--cancel () + (interactive) + (kill-buffer-and-window)) + +(defvar mastodon-toot-mode-map + (let ((map (make-sparse-keymap))) + (define-key map (kbd "C-c C-c") #'mastodon-toot--send) + (define-key map (kbd "C-c C-k") #'mastodon-toot--cancel) + map) + "Keymap for `mastodon-toot-mode'.") + +(define-minor-mode mastodon-toot-mode + "Minor mode to capture Mastodon toots." + :group 'mastodon-toot + :keymap mastodon-toot-mode-map + :global nil) + +(provide 'mastodon-toot) -- cgit v1.2.3