
Product
Introducing Module Reachability: Focus on the Vulnerabilities That Matter
Module Reachability filters out unreachable CVEs so you can focus on vulnerabilities that actually matter to your application.
nestjs-http-promise
Advanced tools
promise implementation of nestjs http module with retries feature using axios-retry and axios
nestjs module that just doing little modification to the original and good nestjs http module.
.toPromise()
every http call.{ retries: NUMBER_OF_RETRIES }
in the config of the http module.
more details in the configuration sectionUsing npm:
$ npm install nestjs-http-promise
Using yarn:
$ yarn add nestjs-http-promise
import the module:
import { HttpModule } from 'nestjs-http-promise'
@Module({
imports: [HttpModule]
})
inject the service in the class:
import { HttpService } from 'nestjs-http-promise'
class Demo {
constructor(private readonly httpService: HttpService) {}
}
use the service:
public callSomeServer(): Promise<object> {
return this.httpService.get('http://fakeService')
}
the service uses axios and axios-retry, so you can pass any AxiosRequestConfig And/Or AxiosRetryConfig
just pass it in the .register()
method as you would do in the original nestjs httpModule
import { HttpModule } from 'nestjs-http-promise'
@Module({
imports: [HttpModule.register(
{
timeout: 1000,
retries: 5,
...
}
)]
})
When you need to pass module options asynchronously instead of statically, use the registerAsync()
method just like in nest httpModule.
you have a couple of techniques to do it:
HttpModule.registerAsync({
useFactory: () => ({
timeout: 1000,
retries: 5,
...
}),
});
HttpModule.registerAsync({
useClass: HttpConfigService,
});
Note that in this example, the HttpConfigService has to implement HttpModuleOptionsFactory interface as shown below.
@Injectable()
class HttpConfigService implements HttpModuleOptionsFactory {
async createHttpOptions(): Promise<HttpModuleOptions> {
const configurationData = await someAsyncMethod();
return {
timeout: configurationData.timeout,
retries: 5,
...
};
}
}
If you want to reuse an existing options provider instead of creating a copy inside the HttpModule, use the useExisting syntax.
HttpModule.registerAsync({
imports: [ConfigModule],
useExisting: ConfigService,
});
FAQs
promise implementation of nestjs http module with retries feature using axios-retry and axios
The npm package nestjs-http-promise receives a total of 23,218 weekly downloads. As such, nestjs-http-promise popularity was classified as popular.
We found that nestjs-http-promise demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Module Reachability filters out unreachable CVEs so you can focus on vulnerabilities that actually matter to your application.
Product
Socket is introducing a new way to organize repositories and apply repository-specific security policies.
Research
Security News
Socket researchers uncovered malicious npm and PyPI packages that steal crypto wallet credentials using Google Analytics and Telegram for exfiltration.