File: supervised_user_shared_settings_update.cc

package info (click to toggle)
chromium-browser 37.0.2062.120-1~deb7u1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 1,707,260 kB
  • sloc: cpp: 8,976,677; ansic: 3,473,199; python: 586,578; asm: 449,013; xml: 184,195; java: 142,924; sh: 118,496; perl: 81,467; makefile: 27,557; yacc: 10,506; objc: 8,886; tcl: 3,186; cs: 2,252; lex: 2,213; sql: 1,198; pascal: 1,170; lisp: 790; awk: 407; ruby: 155; php: 83; sed: 52; exp: 11
file content (40 lines) | stat: -rw-r--r-- 1,364 bytes parent folder | download
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
// Copyright 2014 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.

#include "chrome/browser/supervised_user/supervised_user_shared_settings_update.h"

#include "base/bind.h"
#include "base/values.h"
#include "chrome/browser/supervised_user/supervised_user_shared_settings_service.h"

SupervisedUserSharedSettingsUpdate::SupervisedUserSharedSettingsUpdate(
    SupervisedUserSharedSettingsService* service,
    const std::string& su_id,
    const std::string& key,
    scoped_ptr<base::Value> value,
    const base::Callback<void(bool)>& success_callback)
    : service_(service),
      su_id_(su_id),
      key_(key),
      value_(value.Pass()),
      callback_(success_callback) {
  service->SetValueInternal(su_id, key, *value_, false);
  subscription_ = service->Subscribe(
      base::Bind(&SupervisedUserSharedSettingsUpdate::OnSettingChanged,
                 base::Unretained(this)));
}

SupervisedUserSharedSettingsUpdate::~SupervisedUserSharedSettingsUpdate() {}

void SupervisedUserSharedSettingsUpdate::OnSettingChanged(
    const std::string& su_id, const std::string& key) {
  if (su_id != su_id_)
    return;

  if (key != key_)
    return;

  const base::Value* value = service_->GetValue(su_id, key);
  callback_.Run(value->Equals(value_.get()));
}