From: Max Nikulin <manikulin@gmail.com>
To: emacs-orgmode@gnu.org
Subject: Re: [PATCH] New remote resource download policy
Date: Sat, 25 Jun 2022 14:50:43 +0700 [thread overview]
Message-ID: <t96eok$air$1@ciao.gmane.io> (raw)
In-Reply-To: <87pmj1nh7v.fsf@gmail.com>
On 22/06/2022 17:01, Timothy wrote:
>
>>> — a/lisp/org-attach.el
>>> +++ b/lisp/org-attach.el
>>> @@ -525,7 +525,11 @@ (defun org-attach-attach (file &optional visit-dir method)
>>> [snip]
>>> + (if (or (not noninteractive) (org–should-fetch-remote-resource-p file))
>>
>> I am confused by (not noninteractive). Does it mean that interactive call is
>> enough to bypass protection? It may have sense it at this step there is no
>> ambiguity what resources is fetched. On the other hand I am unsure concerning a
>> case when `org-attach-attach’ is a part of a larger command.
>
> The idea here is that when this is done interactively the user will be aware of
> the URL this is being applied to, and so it isn’t a risk. Let me know if this
> assumption doesn’t hold.
I am not sure what is the best option here. Despite `org-attach-attach'
is an interactive command, URL code path most likely will be followed
when this function is called from another one. *Currently* my opinion is
that it is caller who is responsible for the decision whether the user
explicitly asked for a particular resource so it may be considered safe.
For example for `org-attach-url' probability that it is called by user
directly is higher than it happens from another function.
So I am considering such variant: no heuristics is added to
`org-attach-attach', but `org-attach-url' temporary adjusts the list of
safe locations to bypass user prompt. Notice that I am not an active
user of `org-attach'.
>>> +(defcustom org-download-remote-resources ’prompt
>>
>> The name sounds like some function.
>
> Mmm. I could add `-policy' to that variable name perhaps.
It will be too long. Maybe org-remote-resources-policy, but I am leaving
the decision up to you.
>>> +(defun org–confirm-resource-safe (uri)
>>> + “Ask the user if URI should be considered safe, returning non-nil if so.”
>>> + (unless noninteractive
>>> + (let ((buf (get-buffer-create “*Org Remote Resource*”)))
>>
>> I see your intention to add something fancy to the dialog. May `org-mks’ be
>> reused instead to avoid proliferation variants of rather similar UI code?
>
> Well, the thing here is that I’m explicitly trying to mimic the
> file-local-variable dialog, and since a general form isn’t exposed by Emacs, a
> little bit of proliferation seems like the best option to me.
I do not have strong opinion, I provided an example of `org-mks' reusing
in another message.
>>> + (propertize “n” ’face ’error)
>>> + “ to skip this resource.”)
>>
>> From “skip” I do not expect aborting of export.
>
> Hmm, the “skip” action isn’t determined by the “is it safe” functions, but some
> wording that doesn’t sound completely safe at least would be good.
At least for export it works more like "Abort".
I have realized that e.g. 7zip, asking if it should overwrite an
existing file, offers "Always" variant. Almost certainly I saw similar
buttons in other dialogs on Windows as well. Unsure it it may be easily
implemented, but the case "Allow all remote URLs for the current file"
sounds like a valid option during export.
prev parent reply other threads:[~2022-06-25 7:51 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-12 14:43 [PATCH] New remote resource download policy Timothy
2022-06-12 16:18 ` Daniel Fleischer
2022-06-14 9:40 ` Robert Pluim
2022-06-22 9:58 ` Timothy
2022-06-15 12:35 ` Max Nikulin
2022-06-22 10:01 ` Timothy
2022-06-22 16:55 ` Max Nikulin
2022-06-29 15:27 ` Timothy
2022-06-30 16:57 ` Max Nikulin
2022-07-16 9:47 ` Timothy
2022-06-25 7:50 ` Max Nikulin [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='t96eok$air$1@ciao.gmane.io' \
--to=manikulin@gmail.com \
--cc=emacs-orgmode@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).