Skip to content

Instantly share code, notes, and snippets.

@renekreijveld
Last active March 11, 2021 07:03
Show Gist options
  • Star 12 You must be signed in to star a gist
  • Fork 4 You must be signed in to fork a gist
  • Save renekreijveld/27d9062b941a2d0c80f3 to your computer and use it in GitHub Desktop.
Save renekreijveld/27d9062b941a2d0c80f3 to your computer and use it in GitHub Desktop.
Find unused and used content files in your Joomla website
#!/bin/sh
# jfindfiles -- Find used and unused content files in your Joomla website
#
# This scripts supports Joomla versions 2.5 - 3.x
#
# Copyright 2014 Rene Kreijveld - email@renekreijveld.nl
#
# This program is free software; you may redistribute it and/or modify it.
#
# Warning! This script needs the file jfunctions. This has to be installed in the same directory as this script.
#
# general variables
mypath=$(cd $(dirname ${0}); pwd -P)
myname=$(basename ${0})
# include general functions
. ${mypath}/jfunctions
# version
version=2.2
# Setup Vvariables
start=./images
curdir=`pwd`
echo "Creating database dump..."
# Dump the database to a .sql file
if mysqldump --skip-opt --add-drop-table --add-locks --create-options --disable-keys --lock-tables --quick --set-charset --host=${host} --user=${dbuser} --password=${password} ${database} > ${database}.sql
then
echo "Database dump ${database}.sql created."
else
echo "Error creating database dump."
exit 1
fi
dbdump=${curdir}/${database}.sql
usedfile=${curdir}/${sitename}-used.txt
notusedfile=${curdir}/${sitename}-notused.txt
echo "The following files were mentioned in your Joomla database:" > ${usedfile}
echo "The following files were NOT mentioned in your Joomla database:" > ${notusedfile}
echo "Checking for used and unused files..."
# Move into the images/stories directory
cd ${start}
# Find all files and check if they are mentioned in the database dump
for file in `find . -type f -print | cut -c 3- | sed 's/ /#}/g'`
do
file2=`echo $file | sed 's/#}/ /g'`
file3=`echo $file | sed 's/#}/%20/g'`
result1=`grep -c "$file2" ${dbdump}`
result2=`grep -c "$file3" ${dbdump}`
if [[ $result1 = 0 ]]; then
if [[ $result2 = 0 ]]; then
echo $file2 >> ${notusedfile}
else
echo $file2 >> ${usedfile}
fi
else
echo $file2 >> ${usedfile}
fi
done
# Move back to the root of the website
cd ${curdir}
# Cleanup database dump
rm ${dbdump}
# Report findings
echo "Files checking done."
echo "Check the following text-files for results:"
echo "${usedfile}"
echo "${notusedfile}"
@byman64
Copy link

byman64 commented Feb 1, 2021

First of All let me say T H A N K S ! to Author Rene for sharing this fantastic "time saving" script.

It works fine on my joomla 3.x

Some notes

MANDATORY
2 files:

STEPS

  • Download and upload jfindfiles and jfunctions on your joomla root, in my case in keep joomla on site folder
  • chmod +x jfindfiles (I also done for jfunction but I think it's not necessary)
  • ./findfiles

OUTPUT
findfiles created 2 files : mysitename-notused.txt and mysitename--used.thx

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment