blob: c932f038fd78ca3e9188d6658e28f48f84b7aa95 [file] [log] [blame]
// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_PROFILES_REPORTING_UTIL_H_
#define CHROME_BROWSER_PROFILES_REPORTING_UTIL_H_
#include "base/values.h"
#include "build/chromeos_buildflags.h"
#include "components/enterprise/common/proto/connectors.pb.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
class Profile;
namespace reporting {
// Fetches additional information that is common to every event. Fetches and
// returns corresponding info to a Device, Browser and Profile protos defined in
// google3/google/internal/chrome/reporting/v1/chromereporting.proto.
base::Value::Dict GetContext(Profile* profile);
// Fetches the same information as GetContext, but in a protobuf instead of a
// Value.
enterprise_connectors::ClientMetadata GetContextAsClientMetadata(
Profile* profile);
// Returns User DMToken or client id for a given `profile` if:
// * `profile` is NOT incognito profile.
// * `profile` is NOT sign-in screen profile
// * user corresponding to a `profile` is managed.
// Otherwise returns empty optional. More about DMToken:
// go/dmserver-domain-model#dmtoken.
absl::optional<std::string> GetUserDmToken(Profile* profile);
absl::optional<std::string> GetUserClientId(Profile* profile);
// TODO(crbug.com/1358833): Enable on Lacros.
#if BUILDFLAG(IS_CHROMEOS_ASH)
// Returns the client id if the current session is a managed guest session. Must
// not be called from other sessions.
// Returns an empty optional if the device is managed by Active Directory or if
// policies could not be retrieved from the policy store.
absl::optional<std::string> GetMGSUserClientId();
#endif
} // namespace reporting
#endif // CHROME_BROWSER_PROFILES_REPORTING_UTIL_H_