forked from opencats/OpenCATS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrebuild_old_docs.php
66 lines (57 loc) · 2.26 KB
/
rebuild_old_docs.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?php
// This tool will reindex your *.odt, *.rtf and *.docx formats
// Feature to reindex those files has nbeen added by patch on 2011 July, 08
// by Inuits Company. Email: dennis.povshedny@gmail.com
//
// If you used version 0.9.2 or earlier for a while all your RTF, DOCX and ODT
// candidate attachments are not indexed. By running this script once you may
// index all such attachments.
//
// Please run this from CATS root directory.
//
require_once 'config.php';
function rebuild_old_docs() {
global $con;
$result = mysqli_query($con, 'SELECT * FROM `attachment` WHERE `text` IS NULL');
include_once(LEGACY_ROOT . '/lib/DocumentToText.php');
$countOK = 0;
$countError = 0;
while ($attachment = mysqli_fetch_object($result)) {
$doc2txt = new DocumentToText();
$doc2txt->convert('attachments/' . $attachment->directory_name . $attachment->stored_filename,
$doc2txt->getDocumentType('attachments/' . $attachment->directory_name . $attachment->stored_filename));
if ($doc2txt->isError())
{
$countError++;
print('Error while converting ' . $attachment->stored_filename . " file\n");
}
else
{
$extractedText = $doc2txt->getString();
print('File ' . $attachment->stored_filename." reindexed.\n");
$sql = 'UPDATE `attachment` SET `text` = \'' . addslashes($extractedText) . '\', `md5_sum_text` = \'' . md5($extractedText) . '\' WHERE `attachment_id` = ' . $attachment->attachment_id;
$upd = mysqli_query($con, $sql);
if (!$upd) {
$countError++;
$error = "errno: " . $upd->connect_errno . ", ";
$error .= "error: " . $upd->connect_error;
print('DB error: ' . $error);
} else {
$countOK++;
}
}
unset($doc2txt);
}
print('Success/Fail counters:' . $countOK . '/' . $countError);
}
//$con = mysql_connect("localhost","root","root");
$con = mysqli_connect(DATABASE_HOST, DATABASE_USER, DATABASE_PASS);
if (!$con)
{
$error = "errno: " . mysqli_connect_errno() . ", ";
$error .= "error: " . mysqli_connect_error();
die('Could not connect: ' . $error);
}
mysqli_select_db($con, DATABASE_NAME);
rebuild_old_docs();
?>