| At line 1 added 3 lines | 
| __IMPORTANT:__ | 
| Since August 2023 we've found ImageMagick to be unstable or completely incompatible with javaexec. We strongly recommand to use __[GraphicsMagick|http://www.graphicsmagick.org/]__ instead. It's a compatible, well maintained forked version of ImageMagick, their dev team boasts 0 bugs per 1000 lines of code.\\ | 
| ---- | 
| At line 2 changed 2 lines | 
| first (usually title) page is rendered, for videos, 10 slides evenly sampled along the duration time.\\ | 
| [{Image src='preview_main.jpg' width='1440' height='..' align='left' style='..' class='..' }] | 
| first (usually title) page is rendered. For videos, 10 slides evenly sampled along the duration time, moving the mouse cursor horizontally over the thumbnail will play the slides.\\ | 
| [{Image src='preview_main.png' width='1440' height='..' align='left' style='..' class='..' }] | 
| At line 5 changed 7 lines | 
| !!Prerequisits: | 
| \\ | 
| Thumbnails generation relies on widely used free 3rd party conversion utilities, either part of the host operating system ( qlmanage in case of Mac OS ), can be downloaded from either the OS apps repository ( Linux yum and apt), or as a standalone package from the maintainer's site ( Windows, all OS).\\ | 
| The Preview settings page has a dropdown selector list displayed dynamically based on the host OS platform, we'll display the available presets for image and video preview. In case of Windows, | 
| Linux the conversion utilities need to be deployed manually.\\ | 
| !Image and document files: | 
| On Windows and Linux platforms need to deploy __GraphicsMagick__ for image formats and also __Ghostscript__ for documents. On Debian based platforms the packages are readily available from the apt repository | 
| !!!Prerequisits:\\ | 
| Thumbnails generation relies on widely used free 3rd party conversion utilities. CrushFTP renders the thumbnail list, but it doesn't include no native media conversion code to generate these, except the conversion scheduler. This latter we call the __Preview Scanner__ component. The required external media conversion utilities are either part of the host operating system (in case of Mac OS), can be downloaded from the OS apps repository ( Linux yum and apt), or as a standalone package from the maintainer's site (Windows, all OS). In case of Windows and Linux the conversion utilities need to be deployed manually.\\ | 
| Support for GraphicsMagic only exists from CrushFTP __v10.5.0 Build: 5__ and upwards, previous versions need to be updated.\\ | 
| !!Image and document files:\\ | 
| On __Linux__ platforms need to deploy __GraphicsMagick__ for image formats and also __Ghostscript__ for documents. On Debian based platforms the packages are readily available from the apt repository | 
| At line 14 removed one line | 
| apt-get update | 
| At line 16 added 29 lines | 
| }}} | 
| /% | 
| On Red Hat/CentOS and usually other RPM based distros, can be installed from the EPEL repository. Download the latest epel-release rpm from | 
| %%prettify | 
| {{{ | 
| http://dl.fedoraproject.org/pub/epel/[your redhat version here]/x86_64/ | 
| }}} | 
| /% | 
| Install epel-release rpm: | 
| %%prettify | 
| {{{ | 
| rpm -Uvh epel-release*rpm | 
| }}} | 
| /% | 
| Install GraphicsMagick the package: | 
| %%prettify | 
| {{{ | 
| yum install graphicsmagick | 
| }}} | 
| /% | 
| Alternatively, can try to use __ImageMagick__ still, the __v6.x__ version line if available, is stable. The __v7.x__ version line however may not be. | 
| %%prettify | 
| {{{ | 
| apt-get install imagemagick | 
| }}} | 
| /% | 
| Ghostscript has been on all major Linux app repositories for long, can simply install it like | 
| %%prettify | 
| {{{ | 
| At line 19 changed 3 lines | 
|  | 
| \\ | 
| [{Image src='preview_config1.jpg' width='1440' height='..' align='left' style='..' class='..' }] | 
| On __Windows__ platforms will need to use GraphicsMagick mandatorily, for the recent versions of ImageMagick will not work with Java no more. There are options, either use the binary installer, or use the portable __.zip__ package and deploy it somewhere.\\ | 
| External links to maintainer's download page\\ | 
| At line 23 changed 2 lines | 
| !Heading 2 title | 
| Holding down the Alt key while click the Add Folder button allows adding remote items (FTP://, SMB3://, etc.) | 
| GraphicsMagick: [http://www.graphicsmagick.org/download.html|http://www.graphicsmagick.org/download.html]\\ | 
| Ghostscript:    [https://ghostscript.com/releases/gsdnld.html|https://ghostscript.com/releases/gsdnld.html]\\ | 
| \\ | 
| On __Mac OS__ platforms, you need to select the __qlmanage__ preset.\\ | 
| Change the Working Directory to be ./OSX_scripts/ \\ | 
| On some OSX versions, you might need to make the CrushFTP11/OSX_scipts items executable with:\\ | 
| chmod +x qImanage_wrapper.sh | 
| \\ | 
| !!Video files:\\ | 
| On __Linux__, need to install __ffmpeg__ from the official app repository, depending on the distro, with apt, yum or dnf, like | 
| %%prettify | 
| {{{ | 
| apt-get install ffmpeg | 
| }}} | 
| /% | 
| \\ | 
| On __Windows__ need to download from the maintainer either the binary installer and run it, or the portable __.zip__ package then unzip it somewhere on the host. | 
| External link to maintainer's download page: | 
| \\ | 
| \\ | 
| FFmpeg: [https://ffmpeg.org/download.html|https://ffmpeg.org/download.html]\\ | 
| \\ | 
| On __Mac OS__ platforms, you need to select the __pcastaction__ preset.\\ | 
| Change the Working Directory to be ./OSX_scripts/ \\ | 
| On some OSX versions, you might need to make the CrushFTP11/OSX_scipts items executable with:\\ | 
| chmod +x pcastaction_wrapper.sh | 
| \\ | 
| \\ | 
| !EXIF data (optional):\\ | 
| We can display additional information under the thumbnails, and potentially all image metadata in the [Quickview|quick Preview] perspective, if __exiftool__ is deployed. It's not a mandatory component, Preview works fine without.\\ | 
| On Linux can install it from the official apt, yum, dnf, etc.  repository. | 
| On newer versions of Windows, the original Phil Harvey build may not work, in that case need to use the alternate build\\ | 
| \\ | 
| Original:                         [https://exiftool.org/|https://exiftool.org/]\\ | 
| Alternate(includes Perl runtime): [https://oliverbetz.de/pages/Artikel/ExifTool-for-Windows|https://oliverbetz.de/pages/Artikel/ExifTool-for-Windows]\\ | 
| \\ | 
| Deploy the installer version, or download the portable zip, unpack and drop it into the GraphicsMagick binary's parent folder.\\ | 
| On Mac OS, need to download and install from the __dmg__ package.\\ | 
| \\ | 
| To actually display the EXIF data, need to configure in [User Manager|User Manager]->Available Customizations section the __Display EXIF info keys in quick view__ option.\\ | 
| To edit the EXIF data, need to enable the __Editable EXIF info keys__ option.\\ | 
| \\ | 
| [{Image src='usermanager_config1.jpg' width='1440' height='..' align='left' style='..' class='..' }] | 
| At line 26 changed 10 lines | 
| So the top half of the window in general you don't touch or change anything.  Just use the preset menu.  The bottom half of the window, you specify directories that CrushFTP should monitor for new files.  When it sees a new file, it generates a thumbnail for that file. | 
|  | 
| You can also have thumbnails generated for movie files.  OS X has a built in method for doing this, other OS's can use other utilities such as FFmpeg.  Still frames will be grabbed out of movies and made available as the mouse hovers over the icon. | 
|  | 
| [attachments|preview2.png] | 
|  | 
| The WebInterface with previews being generated may look something like this. | 
|  | 
| [attachments|webinterface_folders.png] | 
|  | 
| \\ | 
| \\ | 
| !!!Setting it up: \\ | 
| Once the prerequisites are fulfilled, choose the appropriate preset from the __Conversion utility presets__ dropdown list. | 
| \\ | 
| \\ | 
| [{Image src='preview_config2.jpg' width='1440' height='..' align='left' style='..' class='..' }]\\ | 
| \\ | 
| In some cases the automatic __Working directory__ path may be inaccurate, in that case, use the right side __Browse__ button to locate the installation directory of the media conversion utility. | 
| \\ | 
| \\ | 
| [{Image src='preview_config1.jpg' width='1440' height='..' align='left' style='..' class='..' }]\\ | 
| \\ | 
| Then in the __lower half__ of the Preview config page, use the __Add folder__ button to browse for the user data directory to be processed by the Preview Scanner. This usually is the top level directory of all user VFS data directories.\\ | 
| \\ | 
| Holding down the Alt key or Shift key while click the Add Folder button allows adding remote items (FTP://, SMB3://, etc.)\\ | 
| \\ | 
| So the top half of the window in general you don't touch or change anything.  Just use the preset menu.  The bottom half of the window, you specify directories that CrushFTP should monitor for new files.  When it sees a new file, it generates a thumbnail for that file.\\ | 
| \\ | 
| To enable __both images/documents and videos preview__, need to add one instance of the Preview config for each with the appropriate preset, using the top right corner __Add Config__ button.\\ | 
| \\ | 
| !Config parameters explained:\\ | 
| __Caution : Changing these fields needs extreme caution as invalid arguments could result in data loss ! __\\ | 
| \\ | 
| ;Conversion utility presets:as mentioned above, to choose a conversion preset for images, videos based on the available utility and OS platform | 
| ;Supported file extensions:the file extensions we'll generate thumbnails for. For those unsupported or not listed, we'll render the default icons | 
| ;Command Line:the commands the Preview Scanner issues to call the conversion utility. | 
| ;Working Directory:the parent directory path of the conversion utility package's main binary | 
| ;Environment Variables:some of the conversion tools may read additional parameters from the shell environment these run within, such can be forced here | 
| ;Frames:only for video preview, this sets the number of slides we generate | 
| ;Info command line:only for video preview, this sets the command to query the video length. the returned value is divided internally by the Frames value to generate the position of the slide | 
| ;Get image EXIF info:only used with exiftool, the command to query image files' metadata | 
| ;Set image EXIF info:only used with exiftool, the command to update image files' metadata | 
| ;Scan subdirectories of directories in below list:toggles recursive scan of the data directories | 
| ;Delete thumbnails for files that no longer exist:toggles automatic cleanup of the Previews thumbnail database. May need to turn off in case the VFS backend is unstable. | 
| ;Scan interval in minutes:the frequency of the Preview Scanner's scheduler. The more aggressive, the quicker new files are detected at the cost of higher the CPU load | 
| ;Threads:multithreaded scanner, needs to be set 2x the number of CPU cores | 
| ;Timeout:timeout of a scanner thread, if reached, the failing file will also be blacklisted | 
| ;Previews Path:the location of the Preview thumbnails database, by default the CrushFTP10 installation directory. Need to relocate to a separate drive if the users' VFS directory structure is large | 
| \\ | 
| !Troubleshooting:\\ | 
| Issues with Preview can be traced in the main server log, the __Log__ tab reveals a filtered stream on Preview specific activity.\\ | 
| \\ | 
| [{Image src='preview_log.jpg' width='1440' height='..' align='left' style='..' class='..' }] |