Security
Headlines
HeadlinesLatestCVEs

Headline

CVE-2022-39309: SCMMaterial changes #000 · gocd/gocd@691b479

GoCD is a continuous delivery server. GoCD helps you automate and streamline the build-test-release cycle for continuous delivery of your product. GoCD versions prior to 21.1.0 leak the symmetric key used to encrypt/decrypt any secure variables/secrets in GoCD configuration to authenticated agents. A malicious/compromised agent may then expose that key from memory, and potentially allow an attacker the ability to decrypt secrets intended for other agents/environments if they also are able to obtain access to encrypted configuration values from the GoCD server. This issue is fixed in GoCD version 21.1.0. There are currently no known workarounds.

CVE
#sql#auth

@@ -68,8 +68,8 @@ public class TfsMaterialTest { @BeforeEach void setUp() { GoCipher goCipher = mock(GoCipher.class); tfsMaterialFirstCollectionFirstProject = new TfsMaterial(goCipher, new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, DOMAIN, PASSWORD, TFS_FIRST_PROJECT); tfsMaterialFirstCollectionSecondProject = new TfsMaterial(goCipher, new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, DOMAIN, PASSWORD, TFS_SECOND_PROJECT); tfsMaterialFirstCollectionFirstProject = new TfsMaterial(new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, DOMAIN, PASSWORD, TFS_FIRST_PROJECT); tfsMaterialFirstCollectionSecondProject = new TfsMaterial(new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, DOMAIN, PASSWORD, TFS_SECOND_PROJECT); }
@Test @@ -104,7 +104,7 @@ void shouldLoadAllModificationsSinceAGivenRevision() throws IOException {
@Test void shouldInjectAllRelevantAttributesInSqlCriteriaMap() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“my-url”), "loser", DOMAIN, "foo_bar_baz", “/dev/null”); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“my-url”), "loser", DOMAIN, "foo_bar_baz", “/dev/null”); assertThat(tfsMaterial.getSqlCriteria()).isEqualTo(m( SQL_CRITERIA_TYPE, (Object) "TfsMaterial", "url", "my-url", @@ -114,7 +114,7 @@ void shouldInjectAllRelevantAttributesInSqlCriteriaMap() {
@Test void shouldInjectAllRelevantAttributesInAttributeMap() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“my-url”), "loser", DOMAIN, "foo_bar_baz", “/dev/null”); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“my-url”), "loser", DOMAIN, "foo_bar_baz", “/dev/null”); assertThat(tfsMaterial.getAttributesForXml()).isEqualTo(m( AbstractMaterial.SQL_CRITERIA_TYPE, (Object) "TfsMaterial", "url", "my-url", @@ -124,56 +124,31 @@ void shouldInjectAllRelevantAttributesInAttributeMap() {
@Test void shouldReturnUrlForCommandLine_asUrl_IfSet() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“http://foo:[email protected]”), "loser", DOMAIN, "foo_bar_baz", “/dev/null” TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“http://foo:[email protected]”), "loser", DOMAIN, "foo_bar_baz", “/dev/null” ); assertThat(tfsMaterial.getUrl()).isEqualTo(“http://foo:[email protected]”);
tfsMaterial = new TfsMaterial(new GoCipher(), null, "loser", DOMAIN, "foo_bar_baz", “/dev/null”); tfsMaterial = new TfsMaterial(null, "loser", DOMAIN, "foo_bar_baz", “/dev/null”); assertThat(tfsMaterial.getUrl()).isNull(); }
@Test void shouldReturnUrlForCommandLine_asLocation_IfSet() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“http://foo:[email protected]”), "loser", DOMAIN, "foo_bar_baz", “/dev/null” TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“http://foo:[email protected]”), "loser", DOMAIN, "foo_bar_baz", “/dev/null” ); assertThat(tfsMaterial.getLocation()).isEqualTo(“http://foo:******@my-url.com”);
tfsMaterial = new TfsMaterial(new GoCipher(), null, "loser", DOMAIN, "foo_bar_baz", “/dev/null”); tfsMaterial = new TfsMaterial(null, "loser", DOMAIN, "foo_bar_baz", “/dev/null”); assertThat(tfsMaterial.getLocation()).isNull(); }
@Test void shouldEncryptTfsPasswordAndMarkPasswordAsNull() throws Exception { GoCipher mockGoCipher = mock(GoCipher.class); when(mockGoCipher.encrypt(“password”)).thenReturn(“encrypted”);
TfsMaterial tfsMaterial = new TfsMaterial(mockGoCipher, new UrlArgument(“/foo”), "username", DOMAIN, "password", “”); tfsMaterial.ensureEncrypted();
assertThat(tfsMaterial.getPassword()).isNull(); assertThat(tfsMaterial.getEncryptedPassword()).isEqualTo(“encrypted”); }
@Test void shouldDecryptTfsPassword() throws Exception { GoCipher mockGoCipher = mock(GoCipher.class); when(mockGoCipher.decrypt(“encrypted”)).thenReturn(“password”);
TfsMaterial tfsMaterial = new TfsMaterial(mockGoCipher, new UrlArgument(“/foo”), "username", DOMAIN, null, “”);
ReflectionUtil.setField(tfsMaterial, "encryptedPassword", “encrypted”);
tfsMaterial.ensureEncrypted(); assertThat(tfsMaterial.getPassword()).isEqualTo(“password”); }
@Test void shouldNotDecryptPasswordIfPasswordIsNotNull() throws Exception { GoCipher mockGoCipher = mock(GoCipher.class); when(mockGoCipher.encrypt(“password”)).thenReturn(“encrypted”); when(mockGoCipher.decrypt(“encrypted”)).thenReturn(“password”);
TfsMaterial material = new TfsMaterial(mockGoCipher, new UrlArgument(“/foo”), "username", DOMAIN, "password", “”); TfsMaterial material = new TfsMaterial(new UrlArgument(“/foo”), "username", DOMAIN, "password", “”); material.ensureEncrypted(); when(mockGoCipher.encrypt(“new_password”)).thenReturn(“new_encrypted”); material.setPassword(“new_password”); @@ -182,33 +157,6 @@ void shouldNotDecryptPasswordIfPasswordIsNotNull() throws Exception { assertThat(material.getPassword()).isEqualTo(“new_password”); }
@Test void shouldErrorOutIfDecryptionFails() throws CryptoException { GoCipher mockGoCipher = mock(GoCipher.class); String fakeCipherText = "fake cipher text"; when(mockGoCipher.decrypt(fakeCipherText)).thenThrow(new CryptoException(“exception”)); TfsMaterial material = new TfsMaterial(mockGoCipher, new UrlArgument(“/foo”), "username", DOMAIN, "password", “”); ReflectionUtil.setField(material, "encryptedPassword", fakeCipherText); try { material.getPassword(); fail(“Should have thrown up”); } catch (Exception e) { assertThat(e.getMessage()).isEqualTo(“Could not decrypt the password to get the real password”); } }
@Test void shouldErrorOutIfEncryptionFails() throws Exception { GoCipher mockGoCipher = mock(GoCipher.class); when(mockGoCipher.encrypt(“password”)).thenThrow(new CryptoException(“exception”)); try { new TfsMaterial(mockGoCipher, new UrlArgument(“/foo”), "username", DOMAIN, "password", “”); fail(“Should have thrown up”); } catch (Exception e) { assertThat(e.getMessage()).isEqualTo(“Password encryption failed. Please verify your cipher key.”); } }
@Test void shouldBePasswordAware() { assertThat(PasswordAwareMaterial.class.isAssignableFrom(TfsMaterial.class)).isTrue(); @@ -237,13 +185,13 @@ void shouldCheckConnection() {
@Test void shouldGetLongDescriptionForMaterial() { TfsMaterial material = new TfsMaterial(new GoCipher(), new UrlArgument(“http://url/”), "user", "domain", "password", “$project/path/”); TfsMaterial material = new TfsMaterial(new UrlArgument(“http://url/”), "user", "domain", "password", “$project/path/”); assertThat(material.getLongDescription()).isEqualTo(“URL: http://url/, Username: user, Domain: domain, ProjectPath: $project/path/”); }
@Test void shouldCopyOverPasswordWhenConvertingToConfig() throws Exception { TfsMaterial material = new TfsMaterial(new GoCipher(), new UrlArgument(“http://url/”), "user", "domain", "password", “$project/path/”); TfsMaterial material = new TfsMaterial(new UrlArgument(“http://url/”), "user", "domain", "password", “$project/path/”);
TfsMaterialConfig config = (TfsMaterialConfig) material.config();
@@ -253,7 +201,7 @@ void shouldCopyOverPasswordWhenConvertingToConfig() throws Exception {
@Test void shouldGetAttributesWithSecureFields() { TfsMaterial material = new TfsMaterial(new GoCipher(), new UrlArgument(“http://username:[email protected]”), "username", "domain", "password", “$project/path/”); TfsMaterial material = new TfsMaterial(new UrlArgument(“http://username:[email protected]”), "username", "domain", "password", “$project/path/”); Map<String, Object> attributes = material.getAttributes(true);
assertThat(attributes.get(“type”)).isEqualTo(“tfs”); @@ -267,7 +215,7 @@ void shouldGetAttributesWithSecureFields() {
@Test void shouldGetAttributesWithoutSecureFields() { TfsMaterial material = new TfsMaterial(new GoCipher(), new UrlArgument(“http://username:[email protected]”), "username", "domain", "password", “$project/path/”); TfsMaterial material = new TfsMaterial(new UrlArgument(“http://username:[email protected]”), "username", "domain", "password", “$project/path/”); Map<String, Object> attributes = material.getAttributes(false);
assertThat(attributes.get(“type”)).isEqualTo(“tfs”); @@ -283,14 +231,14 @@ void shouldGetAttributesWithoutSecureFields() { class passwordForCommandLine { @Test void shouldReturnPasswordAsConfigured_IfNotDefinedAsSecretParam() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“some-url”), null, null, "badger", null); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“some-url”), null, null, "badger", null);
assertThat(tfsMaterial.passwordForCommandLine()).isEqualTo(“badger”); }
@Test void shouldReturnAResolvedPassword_IfPasswordDefinedAsSecretParam() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null);
tfsMaterial.getSecretParams().findFirst(“lookup_pass”).ifPresent(secretParam -> secretParam.setValue(“resolved_password”));
@@ -299,7 +247,7 @@ void shouldReturnAResolvedPassword_IfPasswordDefinedAsSecretParam() {
@Test void shouldErrorOutWhenCalledOnAUnResolvedSecretParam_IfPasswordDefinedAsSecretParam() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null);
assertThatCode(tfsMaterial::passwordForCommandLine) .isInstanceOf(UnresolvedSecretParamException.class) @@ -311,7 +259,7 @@ void shouldErrorOutWhenCalledOnAUnResolvedSecretParam_IfPasswordDefinedAsSecretP class setPassword { @Test void shouldParsePasswordString_IfDefinedAsSecretParam() { TfsMaterial tfsMaterial = new TfsMaterial(new GoCipher(), new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null); TfsMaterial tfsMaterial = new TfsMaterial(new UrlArgument(“some-url”), null, null, "{{SECRET:[secret_config_id][lookup_pass]}}", null);
assertThat(tfsMaterial.getSecretParams()) .hasSize(1) @@ -339,7 +287,7 @@ void populateEnvContextShouldSetMaterialEnvVars() {
@Test void shouldOnlyPopulateDomainEnvVarIfPresent() { TfsMaterial material = new TfsMaterial(mock(GoCipher.class), new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, "", PASSWORD, TFS_FIRST_PROJECT); TfsMaterial material = new TfsMaterial(new UrlArgument(TFS_FIRST_COLLECTION_URL), USERNAME, "", PASSWORD, TFS_FIRST_PROJECT); EnvironmentVariableContext ctx = new EnvironmentVariableContext(); final ArrayList<Modification> modifications = new ArrayList<>();

CVE: Latest News

CVE-2023-50976: Transactions API Authorization by oleiman · Pull Request #14969 · redpanda-data/redpanda