Можно ли вводить кинжал в статическом методе?

У меня есть этот сетевой модуль. Я хочу добавить модуль сети в статический метод ErrorUtils.

@Module
public class NetworkModule {
    private final String END_POINT = "https://www.myurl.com/";

    @Provides
    @Singleton
    public OkHttpClient getOkHttpClient() {
            OkHttpClient okHttpClient = builder.build();
            return okHttpClient;
       }

    @Provides
    @Singleton
    public GsonConverterFactory getGsonConverterFactory() {
        return GsonConverterFactory.create();
    }

    @Provides
    @Singleton
    public Retrofit getRetrofit(OkHttpClient okHttpClient, GsonConverterFactory gsonConverterFactory) {
        return new Retrofit.Builder()
                .baseUrl(END_POINT)
                .client(okHttpClient)
                .addConverterFactory(gsonConverterFactory)
                .build();
    }

    @Provides
    @Singleton
    public RetrofitService getRetrofitService(Retrofit retrofit) {
        return retrofit.create(RetrofitService.class);
    }

И я хочу ввести этот модуль в статический метод как:

public class ErrorUtils {
    @Inject
    static Retrofit retrofit;

    public static RestError parseError(Response<?> response) {

        **//showing error while writing this line**

        MyApplication.getComponent().inject(ErrorUtils.class);
        Converter<ResponseBody, RestError> converter = retrofit.responseBodyConverter(RestError.class, new Annotation[0]);

        RestError error;

        try {
            error = converter.convert(response.errorBody());
        } catch (IOException e) {
            return new RestError();
        }

        return error;
    }
}

Как мы можем вводить модуль в статический метод, любое предложение?

Ответы

Ответ 1

Как видно из раздела "Миграция с кинжала 1"

Кинжал 2 не поддерживает статическую инъекцию.

Статические методы и переменные, как правило, представляют собой плохую идею. В вашем случае вы можете просто сделать свой ErrorUtils объектом, например, с областью @Singleton. Затем вы можете правильно ввести службу, а также правильно errorUtils свой errorUtils без использования статических вызовов.

Если это не вариант, вы можете просто предоставить получателю свой компонент

@Component interface MyComponent {
    Retrofit getRetrofit();
}

И затем используйте этот метод для установки вашей статической переменной.