summaryrefslogtreecommitdiffstats
path: root/lib/public/FullTextSearch/Model/IRunner.php
blob: 0dff82bd5a0329ac0b1769d3cf08855752efb6ae (plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
<?php
declare(strict_types=1);


/**
 * FullTextSearch - Full text search framework for Nextcloud
 *
 * This file is licensed under the Affero General Public License version 3 or
 * later. See the COPYING file.
 *
 * @author Maxence Lange <maxence@artificial-owl.com>
 * @copyright 2018
 * @license GNU AGPL version 3 or any later version
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *
 */


namespace OCP\FullTextSearch\Model;


/**
 * Interface IRunner
 *
 * The indexing process can be long and heavy, and because errors can
 * be encountered the process is wrapped using this interface.
 * It allows the any extension of FullTextSearch to communicate with the process.
 *
 * The IRunner is coming with some methods so the Search Platform can
 * returns important information and errors to be displayed to the admin.
 *
 * @since 15.0.0
 *
 * @package OCP\FullTextSearch\Model
 */
interface IRunner {


	const RESULT_TYPE_SUCCESS = 1;
	const RESULT_TYPE_WARNING = 4;
	const RESULT_TYPE_FAIL = 9;


	/**
	 * Info are displayed in the user interface when an admin execute the
	 * ./occ fulltextsearch:index command.
	 *
	 * quick list of info that can be edited:
	 *   'documentId', 'info', 'title', 'resultIndex', 'resultStatus',
	 *   'content', 'documentCurrent', 'documentTotal', 'progressStatus',
	 *   'errorCurrent', 'errorException', 'errorIndex'.
	 *
	 * List of all editable info can be find in the Command\Index.php of the
	 * FullTextSearch app.
	 * (look for a comment 'full list of info that can be edited')
	 *
	 * @since 15.0.0
	 *
	 * @param string $info
	 * @param string $value
	 */
	public function setInfo(string $info, string $value);


	/**
	 * This method should be used when editing multiple info to avoid too many
	 * refresh of the interface.
	 *
	 * @since 15.0.0
	 *
	 * @param array $data
	 */
	public function setInfoArray(array $data);


	/**
	 * Method used to update the current Action when an index is running.
	 *
	 * This method should be used instead of manually update the 'action' using
	 * setInfo()/setInfoArray() as it is also used to keep the process alive,
	 * manage the input, and some statistics of the load of the process.
	 *
	 * $action is a string with no space
	 * $force should be set to true if the action is heavy while being executed
	 * multiple times
	 *
	 * @since 15.0.0
	 *
	 * @param string $action
	 * @param bool $force
	 *
	 * @return string
	 * @throws \Exception
	 */
	public function updateAction(string $action = '', bool $force = false): string;


	/**
	 * Call this method in a Search Platform or Content Provider if there is an
	 * issue while generating a document or while indexing the current document.
	 * This is used to store and display errors in the UI during an index to help
	 * admin to keep track of errors.
	 *
	 * @since 15.0.0
	 *
	 * @param IIndex $index
	 * @param string $message
	 * @param string $class
	 * @param int $sev
	 */
	public function newIndexError(IIndex $index, string $message, string $class = '', int $sev = 3);


	/**
	 * Call this method only in a Search Platform after an index of a document.
	 * This is used to store and display results (good or bad) in the UI during
	 * an index to help admin to keep track of fail and successful indexes.
	 *
	 * @since 15.0.0
	 *
	 * @param IIndex $index
	 * @param string $message
	 * @param string $status
	 * @param int $type
	 */
	public function newIndexResult(IIndex $index, string $message, string $status, int $type);


}