All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openrewrite.java.security.secrets.FindJwtSecrets Maven / Gradle / Ivy

/*
 * Copyright 2022 the original author or authors.
 * 

* Licensed 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 *

* https://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.openrewrite.java.security.secrets; import com.nimbusds.jwt.JWTParser; import org.openrewrite.ExecutionContext; import org.openrewrite.Recipe; import org.openrewrite.TreeVisitor; import org.openrewrite.internal.lang.Nullable; import java.text.ParseException; import java.util.regex.Pattern; public class FindJwtSecrets extends Recipe { @Override public String getDisplayName() { return "Find JWT secrets"; } @Override public String getDescription() { return "Locates JWTs stored in plain text in code."; } @Override public TreeVisitor getVisitor() { return new FindSecretsVisitor("JWT") { private final Pattern valuePattern = Pattern.compile("eyJ[A-Za-z0-9-_=]+\\.[A-Za-z0-9-_=]+\\.?[A-Za-z0-9-_.+/=]*?"); @Override protected boolean isSecret(@Nullable String key, @Nullable String value, ExecutionContext ctx) { if (value != null && valuePattern.matcher(value).find()) { try { JWTParser.parse(value); } catch (ParseException e) { return false; } return true; } return false; } }; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy