IMPORTANT: This is a breaking update for Mac users, as your shell environment will no longer be inherited correctly (with the removal of exec-path-from-shell). The quick fix is: 'bin/doom env refresh'. Also, the set-env! autodef now does nothing (and is deprecated), be sure to remove calls to it in your config. Smaller changes: + This update also adds --no-* switches to doom quickstart + Includes general improvements to the documentation of several bin/doom commands. + Moves doom/reload* commands to core/autoload/config.el + doom/reload-project has been removed (it didn't actually do anything) The breaking change: This update adds an "envvar file" to Doom Emacs. This file is generated by `doom env refresh`, populated with variables scraped from your shell environment (from both non-interactive and interactive sessions). This file is then (inexpensively) loaded at startup, if it exists. + The file is manually generated with `doom env refresh`. + It can be regenerated automatically whenever `doom refresh` is run by running `doom env enable` (`doom env clear` will reverse this and delete the env file). + `doom quickstart` will ask if you want to auto-generate this envvar file. You won't need it if you're confident Emacs will always be started from the correct environment, however. + Your env file can be reloaded from a running Emacs session with `M-x doom/reload-env`. Note: this won't work if the Emacs session you're running it in doesn't have a correct SHELL set. i.e. don't use this to create your first env file! The idea isn't mine -- it's borrowed from Spacemacs -- and was introduced to me in #1053 by @yurimx. I was impressed with it. Prior to this, I was unhappy with exec-path-from-shell (no hate to the dev, I understand its necessity), and 'doom patch-macos' wasn't ideal for mac users (needed to be reapplied every time you update Emacs). What's more, many users (even Linux users) had to install exec-path-from-shell anyway. This solution suffers from none of their shortcomings. More reliable than patch-macos, more performant and complete than exec-path-from-shell, and easily handled by bin/doom.
40 lines
1.2 KiB
EmacsLisp
40 lines
1.2 KiB
EmacsLisp
;;; tools/password-store/config.el -*- lexical-binding: t; -*-
|
|
|
|
(defvar +pass-user-fields '("login" "user" "username" "email")
|
|
"A list of fields for `+pass/ivy' to search for the username.")
|
|
|
|
(defvar +pass-url-fields '("url" "site" "location")
|
|
"A list of fields for `+pass/ivy' to search for the username.")
|
|
|
|
|
|
;;
|
|
;; Packages
|
|
|
|
;; `password-store'
|
|
(setq password-store-password-length 12)
|
|
|
|
;; Fix hard-coded password-store location; respect PASSWORD_STORE_DIR envvar
|
|
(defun +password-store*read-entry (entry)
|
|
"Return a string with the file content of ENTRY."
|
|
(with-temp-buffer
|
|
(insert-file-contents
|
|
(expand-file-name (format "%s.gpg" entry) (password-store-dir)))
|
|
(buffer-substring-no-properties (point-min) (point-max))))
|
|
(advice-add #'auth-source-pass--read-entry :override #'+password-store*read-entry)
|
|
|
|
|
|
;; `pass'
|
|
(after! pass
|
|
(set-evil-initial-state! 'pass-mode 'emacs)
|
|
(set-popup-rule! "^\\*Password-Store" :side 'left :size 0.25 :quit nil)
|
|
(define-key! pass-mode-map
|
|
"j" #'pass-next-entry
|
|
"k" #'pass-prev-entry
|
|
"d" #'pass-kill
|
|
"\C-j" #'pass-next-directory
|
|
"\C-k" #'pass-prev-directory))
|
|
|
|
|
|
;; Is built into Emacs 26+
|
|
(when (and EMACS26+ (featurep! +auth))
|
|
(auth-source-pass-enable))
|