summaryrefslogtreecommitdiffstats
path: root/lib/public/iavatar.php
blob: 8f432c23fb8ecc04615109ca955adabf56a5c46d (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
<?php
/**
 * This file is licensed under the Affero General Public License version 3 or
 * later.
 * See the COPYING-README file.
 */

namespace OCP;

/**
 * This class provides avatar functionality
 */

interface IAvatar {

	/**
	 * get the users avatar
	 * @param int $size size in px of the avatar, avatars are square, defaults to 64
	 * @return boolean|\OC_Image containing the avatar or false if there's no image
	 */
	function get($size = 64);

	/**
	 * Check if an avatar exists for the user
	 *
	 * @return bool
	 */
	public function exists();

	/**
	 * sets the users avatar
	 * @param \OC_Image|resource|string $data OC_Image, imagedata or path to set a new avatar
	 * @throws \Exception if the provided file is not a jpg or png image
	 * @throws \Exception if the provided image is not valid
	 * @throws \OC\NotSquareException if the image is not square
	 * @return void
	 */
	function set($data);

	/**
	 * remove the users avatar
	 * @return void
	 */
	function remove();
}