001/* 002 * nimbus-jose-jwt 003 * 004 * Copyright 2012-2016, Connect2id Ltd and contributors. 005 * 006 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use 007 * this file except in compliance with the License. You may obtain a copy of the 008 * License at 009 * 010 * http://www.apache.org/licenses/LICENSE-2.0 011 * 012 * Unless required by applicable law or agreed to in writing, software distributed 013 * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR 014 * CONDITIONS OF ANY KIND, either express or implied. See the License for the 015 * specific language governing permissions and limitations under the License. 016 */ 017 018package com.nimbusds.jose.proc; 019 020 021import java.util.List; 022 023import com.nimbusds.jose.jwk.JWK; 024 025/** 026 * A security context that contains JSON Web Keys (JWK). Typically, this would 027 * be used when the keys are evaluated outside of token validation. 028 * 029 * @author Rob Winch 030 * @author Josh Cummings 031 * @version 2019-01-10 032 */ 033public class JWKSecurityContext implements SecurityContext { 034 035 private final List<JWK> keys; 036 037 /** 038 * Constructs a {@code JWKSecurityContext} with the provided 039 * parameters. 040 * 041 * @param keys The list of keys. 042 */ 043 public JWKSecurityContext(final List<JWK> keys) { 044 this.keys = keys; 045 046 if (keys == null) { 047 throw new IllegalArgumentException("The list of keys must not be null"); 048 } 049 } 050 051 /** 052 * Gets the list of {@link JWK}s. 053 * 054 * @return The {@code JWK} list. 055 */ 056 public List<JWK> getKeys() { 057 return keys; 058 } 059}