
com.reprezen.kaizen.oasparser.val3.SecurityRequirementValidator Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2017 ModelSolv, Inc. and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* ModelSolv, Inc. - initial API and implementation and/or initial documentation
*******************************************************************************/
package com.reprezen.kaizen.oasparser.val3;
import static com.reprezen.kaizen.oasparser.val.Messages.m;
import java.util.Map.Entry;
import java.util.Set;
import com.reprezen.jsonoverlay.Overlay;
import com.reprezen.kaizen.oasparser.model3.OpenApi3;
import com.reprezen.kaizen.oasparser.model3.SecurityParameter;
import com.reprezen.kaizen.oasparser.model3.SecurityRequirement;
import com.reprezen.kaizen.oasparser.val.Messages;
import com.reprezen.kaizen.oasparser.val.ObjectValidatorBase;
import com.reprezen.kaizen.oasparser.val.ValidationResults;
public class SecurityRequirementValidator extends ObjectValidatorBase {
@Override
public void validateObject(SecurityRequirement securityRequirement, ValidationResults results) {
OpenApi3 model = Overlay.of(securityRequirement).getModel();
Set definedSchemes = model.getSecuritySchemes().keySet();
for (Entry entry : securityRequirement.getRequirements().entrySet()) {
if (!definedSchemes.contains(entry.getKey())) {
results.addError(
m.msg("UnkSecScheme|Security scheme not defined in components object", entry.getKey()));
} else {
String type = model.getSecurityScheme(entry.getKey()).getType();
switch (type) {
case "oauth2":
case "openIdConnect":
// TODO Q: anything to test here? do we know what the allowed scope names are?
break;
default:
if (!entry.getValue().getParameters().isEmpty()) {
results.addError(Messages.m.msg(
"NonEmptySecReqParms|Security requirement parameters must be empty unless scheme type is oauth2 or openIdConnect",
entry.getKey(), type));
}
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy