| Age | Commit message (Collapse) | Author | 
|---|
|  |  | 
|  | clearing the clipboard isn't needed when in autotype only mode | 
|  | support for config file, changes in the options to `-d` instead of `-b`
is mentioned as well | 
|  | in addition, if a user selects gopass as the pass backend, use the
`get_gopass_files` function | 
|  | BREAKING CHANGE: the `-b` option has been changed to `-d` to make more
sense. i know changes like these may annoy users but i didn't want to
use a generic term like `--backend` for configuring dmenu programs.
`--backend` is also confusing because tessen supports two kinds of
backends now - pass backend and dmenu backend
the `tmp_opts` variable was declare before in the parse_config option as
a way to resolve a conflict when a user provides config files for rofi
and wofi and ends up choosing rofi or wofi explicitly from the
arguments. in that case, validate_backend would reset the list of
dmenu_backend_opts variable to its defaults without the config file
locations which are mentioned in the parse_config function
since we've parsed the `-c` option before in parse_config, the `-c`
option must be ignored in the main() function. we can't omit `-c`
because then a user would get incorrect arg specified error. | 
|  | the config file also supports pointing rofi and wofi to their config
files which allows for context dependent usage which wasn't possible
earlier (without siginficant annoyance and having to accept arbitrary
input) when environment variables were supported | 
|  | with this change, an action can't be selected if it's not possible and
the best available choice should be selected automatically in case no
action is provided. | 
|  | when using pass, use the clipboard timeout value specified by
PASSWORD_STORE_CLIP_TIME and if this isn't specified, fallback to 15
seconds.
when using gopass, use the clipboard timeout value as specified in the
`cliptimeout` key in gopass config | 
|  |  | 
|  | the config file supports setting a web browser of your choice and if it
is provided, it will used irrespective of what the default web browser
is according to XDG. if a user wants to use xdg-open, leave the
web_browser config flag commented in the config file. | 
|  | key_action is taking care of this | 
|  | refactor: offload the autotype and copy operation to key_action | 
|  | if the user selects a url, respond appropriately and change the third
menu if the action is default. if it's autotype, open the url. if it's
copy, copy the url. if the action is both, open the url and copy it. | 
|  | this changes the default behavior of the 2nd menu. if copy mode is
selected, it doesn't make sense to show the user the option to autotype
the username and the password. the option for autotyping has been
removed if copy mode is selected.
the autotype, both, and the default action mode have the same contents
in the 2nd menu. however, the default mode has a third menu which asks
for a user action.
the chosen_key variable was made a global variable rather than a
dynamically scoped variable to avoid confusion. i must admit,
dynamically scoped variables sounds kinda insane when you realize that
scripting languages like Lua support lexical scoping. | 
|  | in addition to adding support for parsing data from gopass, this commit
changes the default behavior of tessen to consider the first non-unique
key that it finds and ignore the rest. this is different from the
earlier behavior of going through each and every potentially identical
keys and considering the value of the last key, which is more expensive
and makes lesser sense.
the keys for url and autotype now support regex as well. this idea was
inspired by the following PR
https://github.com/ayushnix/tessen/pull/11 | 
|  | this feels like a hack as mentioned in the comments but if gopass
authors keep their output format stable, this should work
adding support for gopass mounts was somewhat tricky but worked out in
the end | 
|  |  | 
|  | I've dropped support for environment variables in favor of a config
file. This was motivated by
https://github.com/Cloudef/bemenu/issues/15
From what I think of environment variables, they're meant to be used
when they won't change often, especially not during a live session while
you're working. I don't think that performing a relogin to change colors
in a dmenu program is a sensible thing. Sure, you can create wrapper
scripts and place them in your `$PATH` but that feels like an inferior
solution compared to config file kept in `$XDG_CONFIG_HOME`. | 
|  | I'm gradually moving away from my .in email address. | 
|  | It seems there are some distros like NixOS which do not have `/bin/bash`
in an effort to be stateless, as mentioned in this PR
https://github.com/ayushnix/tessen/pull/15
I'm aware that BSDs probably don't have bash at that location either.
I'll go ahead and change the default shebang to use `env` to find bash
but I also intend to provide an optional patch to revert the shebang
back to `#!/bin/bash` and hardcode the `$PATH` to root owned directories
in `/usr`. | 
|  | also removed trailing whitespace | 
|  | This blog post is one of the reasons why I personally don't use a
browser extension to expose my passwords to the browser. | 
|  |  | 
|  | * userkey search uses regex to find field
* Changed userkey default value to "user"
* First matched entry will be set as tsn_username
* Update to man page
* Fixed setting userkey
* Fixed typo | 
|  |  | 
|  |  | 
|  | There's no point replicating the information inside the man page on the
README. | 
|  | tessen will now prefer finding fuzzel over rofi and wofi | 
|  | Besides some cosmetic changes, the man page now highlights that any
dmenu backend can be used. It also mentions the change in order how
tessen tries to find a backend. In addition, a missing sentence for the
default value of PASSWORD_STORE_CLIP_TIME is mentioned. | 
|  |  | 
|  | Instead of using multiple printf commands, we can just use one. No, I
don't like using heredocs for some reason. | 
|  | Recently, I realized that bash local variables aren't actually local and
use dynamic scoping. Renaming `backend` to `dmbd` is just a precaution. | 
|  | A few extraneous `{}` were removed from variable names, `=` was replaced
with `==` because we're using bash and the former is more confusing, and
other cosmetic changes. | 
|  | Instead of creating multiple functions for passing one line outputs, it
seems better to just use a case statment. Support for fuzzel has also
been added. | 
|  | In the absence of a colon, the default value (which is empty) will be
used only if TESSEN_BACKEND is unset. Adding a colon ensures that the
default value is also used if TESSEN_BACKEND is empty. Since the default
value is empty, the colon is redundant. | 
|  | This commit makes `tessen` agnostic to the dmenu backend used and closes issue #4. Thank you @t0fik for this PR. | 
|  |  | 
|  |  | 
|  |  | 
|  | It's unnecessary to check for the presence of oathtool considering it's
listed as a dependency of pass-otp. The explicit check was also causing
problems for people on NixOS as mentioned in #6. | 
|  |  | 
|  |  | 
|  |  | 
|  | BREAKING CHANGE: The location of the bash completion script has been
changed from the legacy folder '/etc/bash_completion.d/' to
'/usr/share/bash-completion/completions/'. Exisiting users will need to
delete the bash completion script for tessen from the legacy folder. | 
|  | I've used scdoc for now because of lower threshold of using it but I
really want to switch to mdoc and mandoc. | 
|  |  | 
|  | The auto type operation has been split into two functions - one of them
deals with the default auto type operation involving username and
password and the other deals with custom autotype operation specified by
the user.
The copy menu now checks for the presence of notify-send rather than
just using it. | 
|  | continue to implement features explained in 9511148 | 
|  | The validation functions have been changed to be more modular and more
resistant to invalid input. Instead of using printf to redirect error
messages to stderr and using `exit 1`, use the function `_die` which has
been changed as well. A function called `is_installed` was added as well
to check if the needed binaries are present on the system. | 
|  | The `key_menu()` function will now handle different types of keys using
case and specific functions instead of complex if-else monstrosity.
feat: continue to implement features explained in 9511148 |