我正在将现有的Express应用程序转换为NestJS,目前我有一个配置文件,其中为每个微服务创建多个axios实例:
export const writeModelApi = axios.create({
baseURL: getWriteModelApiUrl(),
});
export const readModelApi = axios.create({
baseURL: getReadModelApiUrl(),
});
export const configApi = axios.create({
baseURL: getConfigApiUrl(),
});
function addCamelizeInterceptors(api: any) {
api.interceptors.request.use(
(config: AxiosRequestConfig): AxiosRequestConfig => {
config.data = decamelizeKeys(config.data);
return config;
},
(error: any) => {
return Promise.reject(error);
}
);
api.interceptors.response.use(
(response: AxiosResponse): AxiosResponse => {
response.data = camelizeKeys(response.data);
return response;
},
(error: any) => {
if (error.response != null) {
error.response.data = camelizeKeys(error.response.data);
}
return Promise.reject(error);
}
);
}
addCamelizeInterceptors(taskingApi);
addCamelizeInterceptors(readModelApi);
addCamelizeInterceptors(configApi);
我想到了使用nestjs中的共享模块来复制它的方法,目前我有:
@Module({
imports: [
HttpModule.register({
baseURL: getReadModelApiUrl(),
}),
],
providers: [ReadModelService],
exports: [ReadModelService],
})
export class ReadModelModule implements OnModuleInit {
constructor(@Inject() private httpService: ReadModelService) {}
public onModuleInit() {
addCamelizeInterceptors(this.httpService.axiosRef);
}
}
@Injectable()
export class ReadModelService extends HttpService {}
但是巢给我一个错误,说:
[ExceptionHandler] Nest can't resolve dependencies of the ReadModelModule (?). Please make sure that the argument dependency at index [0] is available in the ReadModelModule context.
Potential solutions:
- If dependency is a provider, is it part of the current ReadModelModule?
- If dependency is exported from a separate @Module, is that module imported within ReadModelModule?
@Module({
imports: [ /* the Module containing dependency */ ]
})
我真的不确定该怎么做。有人可以帮忙吗?
答案 0 :(得分:0)
尝试将HttpService
添加到providers: []
的{{1}}数组中
答案 1 :(得分:0)
为了将来参考,我最后做了一些修改。我浏览了NestJs代码,发现当前没有扩展HttpService的方法,因为未公开其构造函数所需的提供程序常量(AXIOS_INSTANCE_TOKEN)。
所以我创建了自己的HttpModule版本,并提供了所需的常量,以便我的服务可以扩展HttpService。
这是我的代码:
MyHttpModule:
export const AXIOS_INSTANCE_TOKEN = "AXIOS_INSTANCE_TOKEN";
@Module({
providers: [
ReadModelService,
{
provide: AXIOS_INSTANCE_TOKEN,
useValue: Axios,
},
],
exports: [ReadModelService],
})
export class MyHttpModule {}
ReadModelService:
@Injectable()
export class ReadModelService extends HttpService {
constructor() {
const instance = Axios.create({
baseURL: getReadModelApiUrl(),
});
addCamelizeInterceptors(instance);
super(instance);
}
}
这使我可以像使用HttpService一样使用ReadModelService,但是具有baseURL和axios拦截器。我还为WriteModelService和其他创建了类似的服务。我不确定这是否是最好的解决方案,但是它是否可以按预期工作并且不需要太多代码。