summaryrefslogtreecommitdiffstats
path: root/lib/public/iavatar.php
blob: 1e80682c4f749fb0ddc159bf3eea21e36abfd276 (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
<?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);

	/**
	 * sets the users avatar
	 * @param Image $data mixed 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 \OCP\NotSquareException if the image is not square
	 * @return void
	 */
	function set($data);

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