summaryrefslogtreecommitdiffstats
path: root/chromium/chrome/common/extensions/api/users_private.idl
blob: 6e79d41adcfd07a123796ce933f96b95152510ec (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
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Use the <code>chrome.usersPrivate</code> API to manage users.
[platforms=("chromeos"),
 implemented_in="chrome/browser/chromeos/extensions/users_private/users_private_api.h"]
namespace usersPrivate {

  dictionary User {
    // Email for the user.
    DOMString email;

    // Display email for the user.
    DOMString displayEmail;

    // Display name for the user.
    DOMString name;

    // Whether this user is the device owner.
    boolean isOwner;

    // Whether this user is supervised.
    boolean isSupervised;

    // Whether this user is Child.
    boolean isChild;
  };

  dictionary LoginStatusDict {
    // True if a user is logged in (including guest, public session, etc).
    boolean isLoggedIn;

    // True if the screen is locked.
    boolean isScreenLocked;
  };

  callback UsersCallback = void (User[] users);
  callback UserAddedCallback = void (boolean success);
  callback UserRemovedCallback = void (boolean success);
  callback ManagedCallback = void (boolean managed);
  callback UserCallback = void (User user);
  callback LoginStatusCallback = void (LoginStatusDict status);
  callback IsWhiteListedUserCallback = void (boolean found);

  interface Functions {
    // Gets a list of the currently whitelisted users.
    static void getWhitelistedUsers(UsersCallback callback);

    // Checks to see if the user is already present as a whitelisted user.
    static void isWhitelistedUser(DOMString email,
                                  IsWhiteListedUserCallback callback);

    // Adds a new user with the given email to the whitelist.
    // The callback is called with true if the user was added succesfully, or
    // with false if not (e.g. because the user was already present, or the
    // current user isn't the owner).
    static void addWhitelistedUser(DOMString email, UserAddedCallback callback);

    // Removes the user with the given email from the whitelist.
    // The callback is called with true if the user was removed succesfully, or
    // with false if not (e.g. because the user was not already present, or
    // the current user isn't the owner).
    static void removeWhitelistedUser(DOMString email, UserRemovedCallback callback);

    // Whether the whitelist is managed by enterprise.
    static void isWhitelistManaged(ManagedCallback callback);

    // Returns the current user.
    static void getCurrentUser(UserCallback callback);

    // Get login status.
    static void getLoginStatus(LoginStatusCallback callback);
  };
};