funkygao/cp-ddd-framework

View on GitHub
dddplus-spec/src/main/java/io/github/dddplus/model/encapsulation/AllowedAccessors.java

Summary

Maintainability
A
0 mins
Test Coverage
/*
 * Copyright DDDplus Authors.
 *
 * Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
 */
package io.github.dddplus.model.encapsulation;

import io.github.dddplus.model.IRepository;

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

/**
 * 谁可以调用本方法.
 *
 * <p>面向定向类的可访问方法.</p>
 * <p>例如,一个{@code Entity}为了能让{@link IRepository}在构造时传入一些属性,就需要把本来无需{@code public}的方法公开.</p>
 * <p>这破坏了封装,并且可能引发{@code bad side effect}.</p>
 * <p>为了解决这个问题,我们引入{@link AllowedAccessors},并结合{@code AllowedAccessorsEnforcer}通过静态扫描保障.</p>
 */
@Target({ElementType.METHOD, ElementType.CONSTRUCTOR})
@Retention(RetentionPolicy.SOURCE)
public @interface AllowedAccessors {

    /**
     * 哪些类可以访问本方法.
     *
     * <p>如果类访问自己内部方法,无需声明.</p>
     * <p>Example:</p>
     * <pre>
     * {@code
     *
     * public class Task {
     *     ℗AllowedAccessors(ITaskRepository.class)
     *     public bar() {}
     *
     *     void foo() {
     *         // 自己访问自己定义的方法,在bar方法的Accessors里无需声明Task自己
     *         bar();
     *         // ...
     *     }
     * }
     * }
     * </pre>
     */
    Class[] value();
}