Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1441 ariadna 1
<?php
2
// This file is part of Moodle - http://moodle.org/
3
//
4
// Moodle is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8
//
9
// Moodle is distributed in the hope that it will be useful,
10
// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
// GNU General Public License for more details.
13
//
14
// You should have received a copy of the GNU General Public License
15
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
 
17
namespace core_cache;
18
 
19
/**
20
 * Cache lock interface.
21
 *
22
 * This interface needs to be inherited by all cache lock plugins.
23
 *
24
 * @package core_cache
25
 * @copyright Sam Hemelryk
26
 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
27
 */
28
interface cache_lock_interface {
29
    /**
30
     * Constructs an instance of the cache lock given its name and its configuration data
31
     *
32
     * @param string $name The unique name of the lock instance
33
     * @param array $configuration
34
     */
35
    public function __construct($name, array $configuration = []);
36
 
37
    /**
38
     * Acquires a lock on a given key.
39
     *
40
     * @param string $key The key to acquire a lock for.
41
     * @param string $ownerid An unique identifier for the owner of this lock. It is entirely optional for the cache lock plugin
42
     *      to use this. Each implementation can decide for themselves.
43
     * @param bool $block If set to true the application will wait until a lock can be acquired
44
     * @return bool True if the lock can be acquired false otherwise.
45
     */
46
    public function lock($key, $ownerid, $block = false);
47
 
48
    /**
49
     * Releases the lock held on a certain key.
50
     *
51
     * @param string $key The key to release the lock for.
52
     * @param string $ownerid An unique identifier for the owner of this lock. It is entirely optional for the cache lock plugin
53
     *      to use this. Each implementation can decide for themselves.
54
     * @param bool $forceunlock If set to true the lock will be removed if it exists regardless of whether or not we own it.
55
     */
56
    public function unlock($key, $ownerid, $forceunlock = false);
57
 
58
    /**
59
     * Checks the state of the given key.
60
     *
61
     * Returns true if the key is locked and belongs to the ownerid.
62
     * Returns false if the key is locked but does not belong to the ownerid.
63
     * Returns null if there is no lock
64
     *
65
     * @param string $key The key we are checking for.
66
     * @param string $ownerid The identifier so we can check if we have the lock or if it is someone else.
67
     * @return bool True if this code has the lock, false if there is a lock but this code doesn't have it, null if there
68
     *      is no lock.
69
     */
70
    public function check_state($key, $ownerid);
71
 
72
    /**
73
     * Cleans up any left over locks.
74
     *
75
     * This function MUST clean up any locks that have been acquired and not released during processing.
76
     * Although the situation of acquiring a lock and not releasing it should be insanely rare we need to deal with it.
77
     * Things such as unfortunate timeouts etc could cause this situation.
78
     */
79
    public function __destruct();
80
}
81
 
82
// Alias this class to the old name.
83
// This file will be autoloaded by the legacyclasses autoload system.
84
// In future all uses of this class will be corrected and the legacy references will be removed.
85
class_alias(cache_lock_interface::class, \cache_lock_interface::class);