You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cloudstack.apache.org by bh...@apache.org on 2015/01/14 15:50:23 UTC
[1/3] git commit: updated refs/heads/master to 78c3ef0
Repository: cloudstack
Updated Branches:
refs/heads/master 4eafdccc3 -> 78c3ef0e1
Use constant-time comparison functions when checking signatures
This limits the likeliness of timing attacks against the API.
See http://codahale.com/a-lesson-in-timing-attacks/ for the
full rationale.
Conflicts:
server/src/com/cloud/api/ApiServer.java
server/src/com/cloud/user/AccountManagerImpl.java
Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/9b4e39e8
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/9b4e39e8
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/9b4e39e8
Branch: refs/heads/master
Commit: 9b4e39e837af498599859c4a6687eb8bf9f8ad89
Parents: 185f7e0
Author: Pierre-Yves Ritschard <py...@spootnik.org>
Authored: Wed Jan 14 11:27:35 2015 +0100
Committer: Pierre-Yves Ritschard <py...@spootnik.org>
Committed: Wed Jan 14 11:32:29 2015 +0100
----------------------------------------------------------------------
server/src/com/cloud/api/ApiServer.java | 4 ++-
.../com/cloud/api/ConstantTimeComparator.java | 36 ++++++++++++++++++++
.../com/cloud/servlet/ConsoleProxyServlet.java | 3 +-
.../src/com/cloud/user/AccountManagerImpl.java | 4 ++-
4 files changed, 44 insertions(+), 3 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/9b4e39e8/server/src/com/cloud/api/ApiServer.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/api/ApiServer.java b/server/src/com/cloud/api/ApiServer.java
index e60af3b..357504f 100644
--- a/server/src/com/cloud/api/ApiServer.java
+++ b/server/src/com/cloud/api/ApiServer.java
@@ -910,9 +910,11 @@ public class ApiServer extends ManagerBase implements HttpRequestHandler, ApiSer
final SecretKeySpec keySpec = new SecretKeySpec(secretKey.getBytes(), "HmacSHA1");
mac.init(keySpec);
mac.update(unsignedRequest.getBytes());
+
final byte[] encryptedBytes = mac.doFinal();
final String computedSignature = Base64.encodeBase64String(encryptedBytes);
- final boolean equalSig = signature.equals(computedSignature);
+ final boolean equalSig = ConstantTimeComparator.compareStrings(signature, computedSignature);
+
if (!equalSig) {
s_logger.info("User signature: " + signature + " is not equaled to computed signature: " + computedSignature);
} else {
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/9b4e39e8/server/src/com/cloud/api/ConstantTimeComparator.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/api/ConstantTimeComparator.java b/server/src/com/cloud/api/ConstantTimeComparator.java
new file mode 100644
index 0000000..4612eee
--- /dev/null
+++ b/server/src/com/cloud/api/ConstantTimeComparator.java
@@ -0,0 +1,36 @@
+// Licensed to the Apache Software Foundation (ASF) under one
+// or more contributor license agreements. See the NOTICE file
+// distributed with this work for additional information
+// regarding copyright ownership. The ASF licenses this file
+// to you under the Apache License, Version 2.0 (the
+// "License"); you may not use this file except in compliance
+// with the License. You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing,
+// software distributed under the License is distributed on an
+// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+// KIND, either express or implied. See the License for the
+// specific language governing permissions and limitations
+// under the License.
+package com.cloud.api;
+
+public class ConstantTimeComparator {
+
+ public static boolean compareBytes(byte[] b1, byte[] b2) {
+ if (b1.length != b2.length) {
+ return false;
+ }
+
+ int result = 0;
+ for (int i = 0; i < b1.length; i++) {
+ result |= b1[i] ^ b2[i];
+ }
+ return result == 0;
+ }
+
+ public static boolean compareStrings(String s1, String s2) {
+ return compareBytes(s1.getBytes(), s2.getBytes());
+ }
+}
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/9b4e39e8/server/src/com/cloud/servlet/ConsoleProxyServlet.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/servlet/ConsoleProxyServlet.java b/server/src/com/cloud/servlet/ConsoleProxyServlet.java
index 8cbe82b..2e79792 100644
--- a/server/src/com/cloud/servlet/ConsoleProxyServlet.java
+++ b/server/src/com/cloud/servlet/ConsoleProxyServlet.java
@@ -45,6 +45,7 @@ import com.google.gson.GsonBuilder;
import org.apache.cloudstack.framework.security.keys.KeysManager;
+import com.cloud.api.ConstantTimeComparator;
import com.cloud.exception.PermissionDeniedException;
import com.cloud.host.HostVO;
import com.cloud.hypervisor.Hypervisor;
@@ -659,7 +660,7 @@ public class ConsoleProxyServlet extends HttpServlet {
mac.update(unsignedRequest.getBytes());
byte[] encryptedBytes = mac.doFinal();
String computedSignature = Base64.encodeBase64String(encryptedBytes);
- boolean equalSig = signature.equals(computedSignature);
+ boolean equalSig = ConstantTimeComparator.compareStrings(signature, computedSignature);
if (!equalSig) {
s_logger.debug("User signature: " + signature + " is not equaled to computed signature: " + computedSignature);
}
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/9b4e39e8/server/src/com/cloud/user/AccountManagerImpl.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/user/AccountManagerImpl.java b/server/src/com/cloud/user/AccountManagerImpl.java
index 983a58a..36983cc 100644
--- a/server/src/com/cloud/user/AccountManagerImpl.java
+++ b/server/src/com/cloud/user/AccountManagerImpl.java
@@ -63,6 +63,7 @@ import org.apache.cloudstack.managed.context.ManagedContextRunnable;
import org.apache.cloudstack.region.gslb.GlobalLoadBalancerRuleDao;
import com.cloud.api.ApiDBUtils;
+import com.cloud.api.ConstantTimeComparator;
import com.cloud.api.query.vo.ControlledViewEntity;
import com.cloud.configuration.Config;
import com.cloud.configuration.ConfigurationManager;
@@ -488,6 +489,7 @@ public class AccountManagerImpl extends ManagerBase implements AccountManager, M
@Override
public void checkAccess(Account caller, AccessType accessType, boolean sameOwner, String apiName, ControlledEntity... entities) {
+
//check for the same owner
Long ownerId = null;
ControlledEntity prevEntity = null;
@@ -2061,7 +2063,7 @@ public class AccountManagerImpl extends ManagerBase implements AccountManager, M
mac.update(unsignedRequest.getBytes());
byte[] encryptedBytes = mac.doFinal();
String computedSignature = new String(Base64.encodeBase64(encryptedBytes));
- boolean equalSig = signature.equals(computedSignature);
+ boolean equalSig = ConstantTimeComparator.compareStrings(signature, computedSignature);
if (!equalSig) {
s_logger.info("User signature: " + signature + " is not equaled to computed signature: " + computedSignature);
} else {
[3/3] git commit: updated refs/heads/master to 78c3ef0
Posted by bh...@apache.org.
Merge remote-tracking branch 'exoscale/feature/constant-time'
This closes #65
Signed-off-by: Rohit Yadav <ro...@shapeblue.com>
Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/78c3ef0e
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/78c3ef0e
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/78c3ef0e
Branch: refs/heads/master
Commit: 78c3ef0e1e65633d42606e85191888dca87709ee
Parents: 4eafdcc b2393c3
Author: Rohit Yadav <ro...@shapeblue.com>
Authored: Wed Jan 14 16:46:04 2015 +0530
Committer: Rohit Yadav <ro...@shapeblue.com>
Committed: Wed Jan 14 16:46:51 2015 +0530
----------------------------------------------------------------------
server/src/com/cloud/api/ApiServer.java | 5 ++-
.../com/cloud/servlet/ConsoleProxyServlet.java | 3 +-
.../src/com/cloud/user/AccountManagerImpl.java | 4 +-
.../com/cloud/utils/ConstantTimeComparator.java | 39 ++++++++++++++++++++
4 files changed, 48 insertions(+), 3 deletions(-)
----------------------------------------------------------------------
[2/3] git commit: updated refs/heads/master to 78c3ef0
Posted by bh...@apache.org.
move ConstantTimeComparator to utils
Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/b2393c31
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/b2393c31
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/b2393c31
Branch: refs/heads/master
Commit: b2393c31ed8f689e45227f12371fc042c9dbd0e4
Parents: 9b4e39e
Author: Pierre-Yves Ritschard <py...@spootnik.org>
Authored: Wed Jan 14 12:14:00 2015 +0100
Committer: Pierre-Yves Ritschard <py...@spootnik.org>
Committed: Wed Jan 14 12:14:00 2015 +0100
----------------------------------------------------------------------
server/src/com/cloud/api/ApiServer.java | 1 +
.../com/cloud/api/ConstantTimeComparator.java | 36 ------------------
.../com/cloud/servlet/ConsoleProxyServlet.java | 2 +-
.../src/com/cloud/user/AccountManagerImpl.java | 2 +-
.../com/cloud/utils/ConstantTimeComparator.java | 39 ++++++++++++++++++++
5 files changed, 42 insertions(+), 38 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/b2393c31/server/src/com/cloud/api/ApiServer.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/api/ApiServer.java b/server/src/com/cloud/api/ApiServer.java
index 357504f..daf24ef 100644
--- a/server/src/com/cloud/api/ApiServer.java
+++ b/server/src/com/cloud/api/ApiServer.java
@@ -40,6 +40,7 @@ import com.cloud.user.DomainManager;
import com.cloud.user.User;
import com.cloud.user.UserAccount;
import com.cloud.user.UserVO;
+import com.cloud.utils.ConstantTimeComparator;
import com.cloud.utils.HttpUtils;
import com.cloud.utils.NumbersUtil;
import com.cloud.utils.Pair;
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/b2393c31/server/src/com/cloud/api/ConstantTimeComparator.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/api/ConstantTimeComparator.java b/server/src/com/cloud/api/ConstantTimeComparator.java
deleted file mode 100644
index 4612eee..0000000
--- a/server/src/com/cloud/api/ConstantTimeComparator.java
+++ /dev/null
@@ -1,36 +0,0 @@
-// Licensed to the Apache Software Foundation (ASF) under one
-// or more contributor license agreements. See the NOTICE file
-// distributed with this work for additional information
-// regarding copyright ownership. The ASF licenses this file
-// to you under the Apache License, Version 2.0 (the
-// "License"); you may not use this file except in compliance
-// with the License. You may obtain a copy of the License at
-//
-// http://www.apache.org/licenses/LICENSE-2.0
-//
-// Unless required by applicable law or agreed to in writing,
-// software distributed under the License is distributed on an
-// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
-// KIND, either express or implied. See the License for the
-// specific language governing permissions and limitations
-// under the License.
-package com.cloud.api;
-
-public class ConstantTimeComparator {
-
- public static boolean compareBytes(byte[] b1, byte[] b2) {
- if (b1.length != b2.length) {
- return false;
- }
-
- int result = 0;
- for (int i = 0; i < b1.length; i++) {
- result |= b1[i] ^ b2[i];
- }
- return result == 0;
- }
-
- public static boolean compareStrings(String s1, String s2) {
- return compareBytes(s1.getBytes(), s2.getBytes());
- }
-}
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/b2393c31/server/src/com/cloud/servlet/ConsoleProxyServlet.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/servlet/ConsoleProxyServlet.java b/server/src/com/cloud/servlet/ConsoleProxyServlet.java
index 2e79792..d08bcdb 100644
--- a/server/src/com/cloud/servlet/ConsoleProxyServlet.java
+++ b/server/src/com/cloud/servlet/ConsoleProxyServlet.java
@@ -45,7 +45,6 @@ import com.google.gson.GsonBuilder;
import org.apache.cloudstack.framework.security.keys.KeysManager;
-import com.cloud.api.ConstantTimeComparator;
import com.cloud.exception.PermissionDeniedException;
import com.cloud.host.HostVO;
import com.cloud.hypervisor.Hypervisor;
@@ -55,6 +54,7 @@ import com.cloud.user.Account;
import com.cloud.user.AccountManager;
import com.cloud.user.User;
import com.cloud.uservm.UserVm;
+import com.cloud.utils.ConstantTimeComparator;
import com.cloud.utils.Pair;
import com.cloud.utils.Ternary;
import com.cloud.utils.db.EntityManager;
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/b2393c31/server/src/com/cloud/user/AccountManagerImpl.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/user/AccountManagerImpl.java b/server/src/com/cloud/user/AccountManagerImpl.java
index 36983cc..a681c90 100644
--- a/server/src/com/cloud/user/AccountManagerImpl.java
+++ b/server/src/com/cloud/user/AccountManagerImpl.java
@@ -63,7 +63,6 @@ import org.apache.cloudstack.managed.context.ManagedContextRunnable;
import org.apache.cloudstack.region.gslb.GlobalLoadBalancerRuleDao;
import com.cloud.api.ApiDBUtils;
-import com.cloud.api.ConstantTimeComparator;
import com.cloud.api.query.vo.ControlledViewEntity;
import com.cloud.configuration.Config;
import com.cloud.configuration.ConfigurationManager;
@@ -136,6 +135,7 @@ import com.cloud.user.Account.State;
import com.cloud.user.dao.AccountDao;
import com.cloud.user.dao.UserAccountDao;
import com.cloud.user.dao.UserDao;
+import com.cloud.utils.ConstantTimeComparator;
import com.cloud.utils.NumbersUtil;
import com.cloud.utils.Pair;
import com.cloud.utils.Ternary;
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/b2393c31/utils/src/com/cloud/utils/ConstantTimeComparator.java
----------------------------------------------------------------------
diff --git a/utils/src/com/cloud/utils/ConstantTimeComparator.java b/utils/src/com/cloud/utils/ConstantTimeComparator.java
new file mode 100644
index 0000000..4d4a595
--- /dev/null
+++ b/utils/src/com/cloud/utils/ConstantTimeComparator.java
@@ -0,0 +1,39 @@
+//
+// Licensed to the Apache Software Foundation (ASF) under one
+// or more contributor license agreements. See the NOTICE file
+// distributed with this work for additional information
+// regarding copyright ownership. The ASF licenses this file
+// to you under the Apache License, Version 2.0 (the
+// "License"); you may not use this file except in compliance
+// with the License. You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing,
+// software distributed under the License is distributed on an
+// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+// KIND, either express or implied. See the License for the
+// specific language governing permissions and limitations
+// under the License.
+//
+
+package com.cloud.utils;
+
+public class ConstantTimeComparator {
+
+ public static boolean compareBytes(byte[] b1, byte[] b2) {
+ if (b1.length != b2.length) {
+ return false;
+ }
+
+ int result = 0;
+ for (int i = 0; i < b1.length; i++) {
+ result |= b1[i] ^ b2[i];
+ }
+ return result == 0;
+ }
+
+ public static boolean compareStrings(String s1, String s2) {
+ return compareBytes(s1.getBytes(), s2.getBytes());
+ }
+}