lyx_mirror/src/graphics/PreviewImage.h
Tommaso Cucinotta 244de5d2c1 Add 'needauth' option to converters that need explicit user authorization.
Addressing #10481.

This patch adds the new 'needauth' option for converters launching
external programs that are capable of running arbitrary code on behalf
of the user. These converters won't be run unless the user gives explicit
authorization, which is asked on-demand when the converter is about to
be run (question is not asked if the file is cached and calling the
converter is not needed).

The user prompt has a 3rd button so that he/she's not prompted again
for (any converter over) the same document (identified through
buffer->absFileName()).

Two preference options are added:

lyxrc.use_converter_needauth_forbidden disables any converter with
the 'needauth' option, which is meant to force user to an explicit
action via the preferences pane, before being able to use advanced
converters that can potentially bring security threats;

lyxrc.use_converter_needauth enables prompting the user for 'needauth'
converters, or bypasses the check if not enabled, falling back to the
previous behavior.

So, the first option is for maximum security, the second is for
maximum usability.
2016-11-22 23:54:58 +01:00

66 lines
1.2 KiB
C++

// -*- C++ -*-
/**
* \file PreviewImage.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#ifndef PREVIEWIMAGE_H
#define PREVIEWIMAGE_H
#include "support/strfwd.h"
namespace lyx {
namespace support { class FileName; }
class Dimension;
namespace graphics {
class Cache;
class PreviewLoader;
class Image;
class PreviewImage {
public:
/** ascent = height * ascent_frac
* descent = height * (1 - ascent_frac)
*/
PreviewImage(PreviewLoader & parent,
std::string const & latex_snippet,
support::FileName const & bitmap_file,
double ascent_frac);
///
~PreviewImage();
///
std::string const & snippet() const;
///
Dimension dim() const;
/** If the image is not yet loaded (WaitingToLoad), then this method
* triggers that.
*/
Image const * image() const;
///
support::FileName const & filename() const;
PreviewLoader & previewLoader() const;
private:
/// Use the Pimpl idiom to hide the internals.
class Impl;
/// The pointer never changes although *pimpl_'s contents may.
Impl * const pimpl_;
};
} // namespace graphics
} // namespace lyx
#endif // PREVIEWIMAGE_H