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

com.onixbyte.simplejwt.annotations.ExcludeFromPayload Maven / Gradle / Ivy

/*
 * Copyright (C) 2024-2024 OnixByte.
 *
 * 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
 *
 *     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 com.onixbyte.simplejwt.annotations;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Annotation {@code ExcludeFromPayload} is used to mark a property of a data
 * class that should be excluded from being automatically injected into the
 * JSON Web Token (JWT) payload during token generation. When a property is
 * annotated by this annotation, it will not be included in the JWT payloads.
 * 

* Usage: * To exclude a property from the JWT payload, annotate the property with * {@code @ExcludeFromPayload}: * *

{@code
 * public class UserData implements TokenPayload {
 *     private String username;
 *
 *     // This property will not be included in the JWT payload
 *     @ExcludeFromPayload
 *     private String sensitiveData;
 *
 *     // Getters and setters...
 * }
 * }
*

* Note: * This annotation should be used on properties that are not intended to * be included in the JWT payload due to their sensitive nature or for other * reasons only. It is important to carefully choose which properties are * excluded from the payload to ensure the JWT remains secure and efficient. * * @author Zihlu Wang * @version 1.1.0 * @since 1.0.0 */ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD}) public @interface ExcludeFromPayload { }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy