api & permission services and commandHandler
This commit is contained in:
parent
ca6dbafaf1
commit
3f0549bd44
6 changed files with 321 additions and 0 deletions
24
src/service/user/apiPermissionService.ts
Normal file
24
src/service/user/apiPermissionService.ts
Normal file
|
@ -0,0 +1,24 @@
|
|||
import { dataSource } from "../../data-source";
|
||||
import { apiPermission } from "../../entity/user/api_permission";
|
||||
import InternalException from "../../exceptions/internalException";
|
||||
|
||||
export default abstract class ApiPermissionService {
|
||||
/**
|
||||
* @description get permission by api
|
||||
* @param apiId number
|
||||
* @returns {Promise<Array<apiPermission>>}
|
||||
*/
|
||||
static async getByApi(apiId: number): Promise<Array<apiPermission>> {
|
||||
return await dataSource
|
||||
.getRepository(apiPermission)
|
||||
.createQueryBuilder("api_permission")
|
||||
.where("api_permission.apiId = :apiId", { apiId: apiId })
|
||||
.getMany()
|
||||
.then((res) => {
|
||||
return res;
|
||||
})
|
||||
.catch((err) => {
|
||||
throw new InternalException("api permissions not found by api", err);
|
||||
});
|
||||
}
|
||||
}
|
83
src/service/user/apiService.ts
Normal file
83
src/service/user/apiService.ts
Normal file
|
@ -0,0 +1,83 @@
|
|||
import { dataSource } from "../../data-source";
|
||||
import { api } from "../../entity/user/api";
|
||||
import InternalException from "../../exceptions/internalException";
|
||||
|
||||
export default abstract class ApiService {
|
||||
/**
|
||||
* @description get apis
|
||||
* @returns {Promise<Array<api>>}
|
||||
*/
|
||||
static async getAll(): Promise<Array<api>> {
|
||||
return await dataSource
|
||||
.getRepository(api)
|
||||
.createQueryBuilder("api")
|
||||
.leftJoinAndSelect("api.permissions", "permissions")
|
||||
.getMany()
|
||||
.then((res) => {
|
||||
return res;
|
||||
})
|
||||
.catch((err) => {
|
||||
throw new InternalException("apis not found", err);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @description get api by id
|
||||
* @param id number
|
||||
* @returns {Promise<api>}
|
||||
*/
|
||||
static async getById(id: number): Promise<api> {
|
||||
return await dataSource
|
||||
.getRepository(api)
|
||||
.createQueryBuilder("api")
|
||||
.leftJoinAndSelect("api.permissions", "permissions")
|
||||
.where("api.id = :id", { id: id })
|
||||
.getOneOrFail()
|
||||
.then((res) => {
|
||||
return res;
|
||||
})
|
||||
.catch((err) => {
|
||||
throw new InternalException("api not found by id", err);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @description get api by token
|
||||
* @param token string
|
||||
* @returns {Promise<api>}
|
||||
*/
|
||||
static async getByToken(token: string): Promise<api> {
|
||||
return await dataSource
|
||||
.getRepository(api)
|
||||
.createQueryBuilder("api")
|
||||
.leftJoinAndSelect("api.permissions", "permissions")
|
||||
.where("api.token = :token", { token: token })
|
||||
.getOneOrFail()
|
||||
.then((res) => {
|
||||
return res;
|
||||
})
|
||||
.catch((err) => {
|
||||
throw new InternalException("api not found by token", err);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @description get api by id
|
||||
* @param id number
|
||||
* @returns {Promise<api>}
|
||||
*/
|
||||
static async getTokenById(id: number): Promise<api> {
|
||||
return await dataSource
|
||||
.getRepository(api)
|
||||
.createQueryBuilder("api")
|
||||
.select("token")
|
||||
.where("api.id = :id", { id: id })
|
||||
.getOneOrFail()
|
||||
.then((res) => {
|
||||
return res;
|
||||
})
|
||||
.catch((err) => {
|
||||
throw new InternalException("api token not found by id", err);
|
||||
});
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue