blob: 96f97b626dc1656884e974f956ffec004dc255c0 [file] [log] [blame]
/*
* 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 org.apache.cassandra.cql3;
import org.junit.BeforeClass;
import org.junit.Test;
import org.apache.cassandra.auth.RoleOptions;
import static org.apache.cassandra.cql3.PasswordObfuscator.*;
import static java.lang.String.format;
import static org.junit.Assert.assertEquals;
public class PasswordObfuscatorTest
{
private static final RoleOptions plainPwdOpts = new RoleOptions();
private static final RoleOptions hashedPwdOpts = new RoleOptions();
private static final String plainPwd = "testpassword";
private static final String hashedPwd = "$2a$10$1fI9MDCe13ZmEYW4XXZibuASNKyqOY828ELGUtml/t.0Mk/6Kqnsq";
@BeforeClass
public static void startup()
{
plainPwdOpts.setOption(org.apache.cassandra.auth.IRoleManager.Option.PASSWORD, plainPwd);
hashedPwdOpts.setOption(org.apache.cassandra.auth.IRoleManager.Option.HASHED_PASSWORD, hashedPwd);
}
@Test
public void testSpecialCharsObfuscation()
{
assertEquals("ALTER ROLE testrole WITH HASHED PASSWORD = '" + OBFUSCATION_TOKEN + "'",
obfuscate(format("ALTER ROLE testrole WITH HASHED PASSWORD = '%s'",hashedPwd), hashedPwdOpts));
}
@Test
public void testCreatRoleWithLoginPriorToPassword()
{
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '123'"));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '%s'", plainPwd), plainPwdOpts));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '" + hashedPwd + "'"));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testCreatRoleWithLoginAfterPassword()
{
assertEquals(format("CREATE ROLE role1 WITH password %s", OBFUSCATION_TOKEN),
obfuscate("CREATE ROLE role1 WITH password = '123' AND LOGIN = true"));
assertEquals(format("CREATE ROLE role1 WITH password = '%s' AND LOGIN = true", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH password = '%s' AND LOGIN = true", plainPwd), plainPwdOpts));
assertEquals(format("CREATE ROLE role1 WITH HASHED password %s", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH HASHED password = '%s' AND LOGIN = true", hashedPwd)));
assertEquals(format("CREATE ROLE role1 WITH HASHED password = '%s' AND LOGIN = true", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH HASHED password = '%s' AND LOGIN = true", hashedPwd), hashedPwdOpts));
}
@Test
public void testCreateRoleWithoutPassword()
{
assertEquals("CREATE ROLE role1", obfuscate("CREATE ROLE role1"));
assertEquals("CREATE ROLE role1", obfuscate("CREATE ROLE role1", plainPwdOpts));
}
@Test
public void testCreateMultipleRoles()
{
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '123';" +
"CREATE ROLE role2 WITH LOGIN = true AND PASSWORD = '123'"));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '%s';" +
"CREATE ROLE role2 WITH LOGIN = true AND PASSWORD = '%s'", OBFUSCATION_TOKEN, OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH LOGIN = true AND PASSWORD = '%s';" +
"CREATE ROLE role2 WITH LOGIN = true AND PASSWORD = '%s'", plainPwd, plainPwd), plainPwdOpts));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '%s';" +
"CREATE ROLE role2 WITH LOGIN = true AND HASHED PASSWORD = '%s'", hashedPwd, hashedPwd)));
assertEquals(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '%s';" +
"CREATE ROLE role2 WITH LOGIN = true AND HASHED PASSWORD = '%s'", OBFUSCATION_TOKEN, OBFUSCATION_TOKEN),
obfuscate(format("CREATE ROLE role1 WITH LOGIN = true AND HASHED PASSWORD = '%s';" +
"CREATE ROLE role2 WITH LOGIN = true AND HASHED PASSWORD = '%s'", hashedPwd, hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterRoleWithPassword()
{
assertEquals(format("ALTER ROLE role1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("ALTER ROLE role1 with PASSWORD = '123'"));
assertEquals(format("ALTER ROLE role1 with PASSWORD = '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with PASSWORD = '%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD = '%s'", hashedPwd)));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD = '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD = '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterRoleWithPasswordNoSpace()
{
assertEquals(format("ALTER ROLE role1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("ALTER ROLE role1 with PASSWORD='123'"));
assertEquals(format("ALTER ROLE role1 with PASSWORD='%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with PASSWORD='%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD='%s'", hashedPwd)));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD='%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD='%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterRoleWithPasswordNoImmediateSpace()
{
assertEquals(format("ALTER ROLE role1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("ALTER ROLE role1 with PASSWORD= '123'"));
assertEquals(format("ALTER ROLE role1 with PASSWORD= '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with PASSWORD= '%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD= '%s'", hashedPwd)));
assertEquals(format("ALTER ROLE role1 with HASHED PASSWORD= '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER ROLE role1 with HASHED PASSWORD= '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterRoleWithoutPassword()
{
assertEquals("ALTER ROLE role1", obfuscate("ALTER ROLE role1"));
assertEquals("ALTER ROLE role1", obfuscate("ALTER ROLE role1", plainPwdOpts));
assertEquals("ALTER ROLE role1", obfuscate("ALTER ROLE role1", hashedPwdOpts));
}
@Test
public void testCreateUserWithPassword()
{
assertEquals(format("CREATE USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with PASSWORD '123'"));
assertEquals(format("CREATE USER user1 with PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE USER user1 with PASSWORD '%s'", plainPwd), plainPwdOpts));
assertEquals(format("CREATE USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("CREATE USER user1 with HASHED PASSWORD '%s'", hashedPwd)));
assertEquals(format("CREATE USER user1 with HASHED PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE USER user1 with HASHED PASSWORD '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testCreateUserWithoutPassword()
{
assertEquals("CREATE USER user1", obfuscate("CREATE USER user1"));
assertEquals("CREATE USER user1", obfuscate("CREATE USER user1", plainPwdOpts));
assertEquals("CREATE USER user1", obfuscate("CREATE USER user1", hashedPwdOpts));
}
@Test
public void testAlterUserWithPassword()
{
assertEquals(format("ALTER USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("ALTER USER user1 with PASSWORD '123'"));
assertEquals(format("ALTER USER user1 with PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with PASSWORD '%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED PASSWORD '%s'", hashedPwd)));
assertEquals(format("ALTER USER user1 with HASHED PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED PASSWORD '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterUserWithPasswordMixedCase()
{
assertEquals(format("ALTER USER user1 with paSSwoRd %s", OBFUSCATION_TOKEN),
obfuscate("ALTER USER user1 with paSSwoRd '123'"));
assertEquals(format("ALTER USER user1 with paSSwoRd '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with paSSwoRd '%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER USER user1 with HASHED paSSwoRd %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED paSSwoRd '%s'", hashedPwd)));
assertEquals(format("ALTER USER user1 with HASHED paSSwoRd '%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED paSSwoRd '%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testAlterUserWithPasswordWithNewLine()
{
assertEquals(format("ALTER USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("ALTER USER user1 with PASSWORD\n'123'"));
assertEquals(format("ALTER USER user1 with PASSWORD\n'%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with PASSWORD\n'%s'", plainPwd), plainPwdOpts));
assertEquals(format("ALTER USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED PASSWORD\n'%s'", hashedPwd)));
assertEquals(format("ALTER USER user1 with HASHED PASSWORD\n'%s'", OBFUSCATION_TOKEN),
obfuscate(format("ALTER USER user1 with HASHED PASSWORD\n'%s'", hashedPwd), hashedPwdOpts));
}
@Test
public void testPasswordWithNewLinesObfuscation()
{
assertEquals(String.format("CREATE USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with PASSWORD 'a\nb'"));
RoleOptions newLinePassOpts = new RoleOptions();
newLinePassOpts.setOption(org.apache.cassandra.auth.IRoleManager.Option.PASSWORD, "test\npassword");
assertEquals(String.format("CREATE USER user1 with PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE USER user1 with PASSWORD '%s'", "test\npassword"), newLinePassOpts));
assertEquals(String.format("CREATE USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with HASHED PASSWORD 'a\nb'"));
assertEquals(String.format("CREATE USER user1 with HASHED PASSWORD '%s'", OBFUSCATION_TOKEN),
obfuscate(format("CREATE USER user1 with HASHED PASSWORD '%s'", "test\npassword"), newLinePassOpts));
}
@Test
public void testEmptyPasswordObfuscation()
{
assertEquals(String.format("CREATE USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with PASSWORD ''"));
RoleOptions emptyPassOpts = new RoleOptions();
emptyPassOpts.setOption(org.apache.cassandra.auth.IRoleManager.Option.PASSWORD, "");
assertEquals("CREATE USER user1 with PASSWORD ''",
obfuscate("CREATE USER user1 with PASSWORD ''", emptyPassOpts));
assertEquals(String.format("CREATE USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with HASHED PASSWORD ''"));
assertEquals("CREATE USER user1 with HASHED PASSWORD ''",
obfuscate("CREATE USER user1 with HASHED PASSWORD ''", emptyPassOpts));
}
@Test
public void testPasswordWithSpaces()
{
assertEquals(String.format("CREATE USER user1 with PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with PASSWORD 'p a ss wor d'"));
assertEquals(String.format("CREATE USER user1 with HASHED PASSWORD %s", OBFUSCATION_TOKEN),
obfuscate("CREATE USER user1 with HASHED PASSWORD 'p a ss wor d'"));
}
@Test
public void testSimpleBatch()
{
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD %s",
OBFUSCATION_TOKEN),
obfuscate("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = 'alice123' and LOGIN = true; \n" +
"APPLY BATCH;"));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", OBFUSCATION_TOKEN),
obfuscate(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", plainPwd),
plainPwdOpts));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD %s",
OBFUSCATION_TOKEN),
obfuscate("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '" + hashedPwd + "' and LOGIN = true; \n" +
"APPLY BATCH;"));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", OBFUSCATION_TOKEN),
obfuscate(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", hashedPwd),
hashedPwdOpts));
}
@Test
public void testComplexBatch()
{
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD %s",
OBFUSCATION_TOKEN),
obfuscate("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = 'alice123' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH PASSWORD = 'alice123' and LOGIN = true; \n" +
"APPLY BATCH;"));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = '%s' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;"
, OBFUSCATION_TOKEN, OBFUSCATION_TOKEN),
obfuscate(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH PASSWORD = '%s' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", plainPwd, plainPwd),
plainPwdOpts));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD %s",
OBFUSCATION_TOKEN),
obfuscate("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '" + hashedPwd + "' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH HASHED PASSWORD = '" + hashedPwd + "' and LOGIN = true; \n" +
"APPLY BATCH;"));
assertEquals(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;"
, OBFUSCATION_TOKEN, OBFUSCATION_TOKEN),
obfuscate(format("BEGIN BATCH \n" +
" CREATE ROLE alice1 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
" CREATE ROLE alice2 WITH HASHED PASSWORD = '%s' and LOGIN = true; \n" +
"APPLY BATCH;", hashedPwd, hashedPwd),
hashedPwdOpts));
}
}