Index: chromeos_login_helpers.cc |
diff --git a/chromeos_login_helpers.cc b/chromeos_login_helpers.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..035464d822280fb1ce4b87532652ca3e304780c6 |
--- /dev/null |
+++ b/chromeos_login_helpers.cc |
@@ -0,0 +1,228 @@ |
+// Copyright (c) 2010 The Chromium OS 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 "chromeos_login_helpers.h" // NOLINT |
+ |
+#include <base/basictypes.h> |
+#include <base/logging.h> |
+#include <base/string_util.h> |
+#include <dbus/dbus-glib-lowlevel.h> |
+#include <chromeos/dbus/dbus.h> |
+#include <chromeos/dbus/service_constants.h> |
+#include <chromeos/glib/object.h> |
+#include <chromeos/string.h> |
+#include <vector> |
+ |
+#include "marshal.glibmarshal.h" // NOLINT |
+#include "chromeos_login.h" // NOLINT |
+ |
+namespace chromeos { // NOLINT |
+ |
+#define SCOPED_SAFE_MESSAGE(e) (e->message ? e->message : "unknown error") |
+ |
+ChromeOSLoginHelpers::ChromeOSLoginHelpers() {} |
+ |
+ChromeOSLoginHelpers::~ChromeOSLoginHelpers() {} |
+ |
+// static |
+dbus::Proxy ChromeOSLoginHelpers::CreateProxy() { |
+ dbus::BusConnection bus = dbus::GetSystemBusConnection(); |
+ return dbus::Proxy(bus, |
+ login_manager::kSessionManagerServiceName, |
+ login_manager::kSessionManagerServicePath, |
+ login_manager::kSessionManagerInterface); |
+} |
+ |
+// Memory allocated by this method should be freed with delete, not delete []. |
+// static |
+uint8* ChromeOSLoginHelpers::NewBufferCopy(const uint8* x, int len) { |
+ uint8* result = static_cast<uint8*>(::operator new(len)); |
zel
2010/10/28 20:02:46
what's that magic cast here for? what's wrong with
Chris Masone
2010/10/28 20:09:08
To stay in line with what's done in NewStringCopy
|
+ std::memcpy(result, x, len); |
+ return result; |
+} |
+ |
+// static |
+GArray* ChromeOSLoginHelpers::CreateGArrayFromBytes(const uint8* in, |
+ const int in_len) { |
+ GArray* ary = g_array_sized_new(FALSE, FALSE, 1, in_len); |
+ g_array_append_vals(ary, in, in_len); |
+ return ary; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::CheckWhitelistHelper(const char* email, |
+ GArray** sig) { |
+ dbus::Proxy proxy = CreateProxy(); |
+ glib::ScopedError error; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ login_manager::kSessionManagerCheckWhitelist, |
+ &Resetter(&error).lvalue(), |
+ G_TYPE_STRING, email, |
+ G_TYPE_INVALID, |
+ DBUS_TYPE_G_UCHAR_ARRAY, sig, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << login_manager::kSessionManagerCheckWhitelist << " failed: " |
+ << SCOPED_SAFE_MESSAGE(error); |
+ return false; |
+ } |
+ return true; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::EnumerateWhitelistedHelper(gchar*** whitelisted) { |
+ dbus::Proxy proxy = ChromeOSLoginHelpers::CreateProxy(); |
+ glib::ScopedError error; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ login_manager::kSessionManagerEnumerateWhitelisted, |
+ &Resetter(&error).lvalue(), |
+ G_TYPE_INVALID, |
+ G_TYPE_STRV, whitelisted, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << login_manager::kSessionManagerEnumerateWhitelisted |
+ << " failed: " << SCOPED_SAFE_MESSAGE(error); |
+ return false; |
+ } |
+ return true; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::RetrievePropertyHelper(const char* name, |
+ gchar** value, |
+ GArray** sig) { |
+ dbus::Proxy proxy = ChromeOSLoginHelpers::CreateProxy(); |
+ glib::ScopedError error; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ login_manager::kSessionManagerRetrieveProperty, |
+ &Resetter(&error).lvalue(), |
+ G_TYPE_STRING, name, |
+ G_TYPE_INVALID, |
+ G_TYPE_STRING, value, |
+ DBUS_TYPE_G_UCHAR_ARRAY, sig, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << login_manager::kSessionManagerRetrieveProperty |
+ << " failed: " << SCOPED_SAFE_MESSAGE(error); |
+ return false; |
+ } |
+ return true; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::SetOwnerKeyHelper(GArray* key_der) { |
+ dbus::Proxy proxy = ChromeOSLoginHelpers::CreateProxy(); |
+ glib::ScopedError error; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ login_manager::kSessionManagerSetOwnerKey, |
+ &Resetter(&error).lvalue(), |
+ DBUS_TYPE_G_UCHAR_ARRAY, key_der, |
+ G_TYPE_INVALID, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << login_manager::kSessionManagerSetOwnerKey << " failed: " |
+ << SCOPED_SAFE_MESSAGE(error); |
+ return false; |
+ } |
+ return true; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::StorePropertyHelper(const char* name, |
+ const char* value, |
+ GArray* sig) { |
+ dbus::Proxy proxy = ChromeOSLoginHelpers::CreateProxy(); |
+ glib::ScopedError error; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ login_manager::kSessionManagerStoreProperty, |
+ &Resetter(&error).lvalue(), |
+ G_TYPE_STRING, name, |
+ G_TYPE_STRING, value, |
+ DBUS_TYPE_G_UCHAR_ARRAY, sig, |
+ G_TYPE_INVALID, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << login_manager::kSessionManagerStoreProperty << " failed: " |
+ << SCOPED_SAFE_MESSAGE(error); |
+ return false; |
+ } |
+ return true; |
+} |
+ |
+// static |
+bool ChromeOSLoginHelpers::WhitelistOpHelper( |
+ const char* op, |
+ const char* email, |
+ const std::vector<uint8>& signature) { |
+ dbus::Proxy proxy = ChromeOSLoginHelpers::CreateProxy(); |
+ glib::ScopedError error; |
+ GArray* sig = CreateGArrayFromBytes(&signature[0], signature.size()); |
+ |
+ bool rv = true; |
+ if (!::dbus_g_proxy_call(proxy.gproxy(), |
+ op, |
+ &Resetter(&error).lvalue(), |
+ G_TYPE_STRING, email, |
+ DBUS_TYPE_G_UCHAR_ARRAY, sig, |
+ G_TYPE_INVALID, |
+ G_TYPE_INVALID)) { |
+ LOG(WARNING) << op << " failed: " << SCOPED_SAFE_MESSAGE(error); |
+ rv = false; |
+ } |
+ g_array_free(sig, TRUE); |
+ return rv; |
+} |
+ |
+// static |
+CryptoBlob* ChromeOSLoginHelpers::CreateCryptoBlob(GArray* in) { |
+ CryptoBlob* blob = new CryptoBlob; |
+ blob->length = in->len; |
+ blob->data = ChromeOSLoginHelpers::NewBufferCopy( |
+ reinterpret_cast<const uint8*>(in->data), in->len); |
+ return blob; |
+} |
+ |
+// static |
+Property* ChromeOSLoginHelpers::CreateProperty(const char* name, |
+ const gchar* value, |
+ GArray* sig) { |
+ Property* prop = new Property; |
+ prop->signature = CreateCryptoBlob(sig); |
+ prop->name = NewStringCopy(name); |
+ prop->value = NewStringCopy(value); |
+ return prop; |
+} |
+ |
+// static |
+UserList* ChromeOSLoginHelpers::CreateUserList(const char* const* users) { |
+ UserList* list = new UserList; |
+ list->users = NULL; |
+ for (list->num_users = 0; users[list->num_users] != NULL; list->num_users++) |
+ ; |
+ list->users = static_cast<const char**>( |
+ ::operator new(sizeof(char*) * (list->num_users + 1))); |
+ list->users[list->num_users] = NULL; |
+ for (int i = 0; users[i] != NULL; ++i) |
+ list->users[i] = NewStringCopy(users[i]); |
+ return list; |
+} |
+ |
+// These Free* methods all use delete (as opposed to delete []) on purpose, |
+// following the pattern established by code that uses NewStringCopy. |
+// static |
+void ChromeOSLoginHelpers::FreeCryptoBlob(CryptoBlob* blob) { |
+ delete blob->data; |
+ delete blob; |
+} |
+ |
+// static |
+void ChromeOSLoginHelpers::FreeProperty(Property* property) { |
+ FreeCryptoBlob(property->signature); |
+ delete property->name; |
+ delete property->value; |
+} |
+ |
+// static |
+void ChromeOSLoginHelpers::FreeUserList(UserList* userlist) { |
+ for (int i = 0; i < userlist->num_users; ++i) |
+ delete userlist->users[i]; |
+ delete userlist->users; |
+ delete userlist; |
+} |
+} // namespace chromeos |