Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/overnested/nestjs-octokit
Octokit module for NestJS
https://github.com/overnested/nestjs-octokit
github nest nest-js nestjs octokit octokit-js
Last synced: 3 months ago
JSON representation
Octokit module for NestJS
- Host: GitHub
- URL: https://github.com/overnested/nestjs-octokit
- Owner: overnested
- License: mit
- Created: 2022-01-14T09:46:54.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-12-15T17:34:46.000Z (about 1 year ago)
- Last Synced: 2024-09-29T01:42:02.592Z (4 months ago)
- Topics: github, nest, nest-js, nestjs, octokit, octokit-js
- Language: TypeScript
- Homepage:
- Size: 296 KB
- Stars: 12
- Watchers: 1
- Forks: 4
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NestJS Octokit Module
This module facilitates the usage of [Octokit](https://github.com/octokit/octokit.js) in [NestJS](https://github.com/nestjs/nest).
## Introduction
Octokit is "The all-batteries-included GitHub SDK for Browsers, Node.js, and Deno".
Using `nestjs-octokit` you can register the Octokit module and configure it the way NestJS suggests, then inject it as a standard NestJS injectable.## Installation
On Yarn:
```shell
yarn add nestjs-octokit octokit
```On NPM:
```shell
npm install nestjs-octokit octokit
```## Usage
First register the module:
```ts
import { OctokitModule } from 'nestjs-octokit';@Module({
imports: [
OctokitModule.forRoot({
isGlobal: true,
octokitOptions: {
auth: 'my-github-token',
},
}),
// ...
],
})
export class AppModule {}
```Or if want to inject any dependency:
```ts
import { OctokitModule } from 'nestjs-octokit';@Module({
imports: [
OctokitModule.forRootAsync({
isGlobal: true,
imports: [ConfigModule],
inject: [ConfigService],
useFactory: async (configService: ConfigService) => ({
octokitOptions: {
auth: configService.get('GITHUB_AUTH_TOKEN'),
},
}),
}),
// ...
],
})
export class AppModule {}
```Then you can inject the service:
```ts
import { OctokitService } from 'nestjs-octokit';@Controller()
export class SomeController {
constructor(private readonly octokitService: OctokitService) {}@Get('/')
someEndpoint() {
const response = await this.octokitService.rest.search.repos({
q: 'nest-js',
});return response.data.items;
}
}
```### Short-lived access tokens
If your access tokens are short-lived, you can configure a [request
scoped](https://docs.nestjs.com/fundamentals/injection-scopes#provider-scope)
Octokit provider with an `auth` callback, to renew the Octokits
and auth tokens:```ts
import { OctokitModule } from 'nestjs-octokit';
import { Scope } from '@nestjs/common';@Module({
imports: [
OctokitModule.forRootAsync({
isGlobal: true,
// Set request scope
octokitScope: Scope.REQUEST,
imports: [TokenModule],
inject: [TokenService],
useFactory: async (tokenService: TokenService) => ({
octokitOptions: {
// `auth` is a callback now. Return short-lived tokens
auth: () => tokenService.produceToken(),
},
}),
}),
// ...
],
})
export class AppModule {}
```## Plugins
To use plugins:
```ts
import { OctokitModule } from 'nestjs-octokit';
import { throttling } from '@octokit/plugin-throttling';@Module({
imports: [
OctokitModule.forRoot({
isGlobal: true,
plugins: [throttling], // Pass them here
octokitOptions: {
// Plugin options:
throttle: {
onRateLimit: (retryAfter, options, octokit) => {
octokit.log.warn(
`Request quota exhausted for request ${options.method} ${options.url}`
);
},
onAbuseLimit: (retryAfter, options, octokit) => {
octokit.log.warn(
`Abuse detected for request ${options.method} ${options.url}`
);
},
},
},
}),
],
})
export class AppModule {}
```