Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@wrtn/decorators
Advanced tools
@wrtn/decorators
스튜디오 프로젝트를 위한 NestJS 디코레이터 모음.
npm i @wrtn/decorators
Placeholder<string>
import { Placeholder } from "@wrtn/decorators";
import { tags } from "typia";
export interface Something {
/**
* 고객의 이름.
*
* @title 이름
*/
name: string & Placeholder<"이름을 입력해주세요.">;
/**
* 고객의 생년월일.
*
* @title 생년월일
*/
birthdate: string &
tags.Format<"date"> &
Placeholder<"생년월일을 입력해주세요. 형식은 YYYY-MM-DD 입니다.">;
flag: number & Placeholder<"Something">;
}
boolean
이나 number
및 string
타입을 부여할 때, 위와 같이 Placeholder<string>
타입을 intersection (&)
으로 결합해주면, JSON Schema 에 x-wrtn-placeholder
속성이 추가된다.
만일 위와 같은 JSON Schema customizer 가 필요하다면, 아래 문서를 보고 참고하여, 새로운 JSON Schema customizer 타입을 만들어주도록 하자. 그리고 새로이 추가한 커스텀 속성에 대하여, inspector 개발자들에게 전파하도록 한다.
Prerequisite<Props>
& @Prerequisite()
특정 값을 구성하기 위하여, 반드시 사전에 실행해야하는 API 에 대한 스펙, 그리고 해당 prerequisite API 를 실행한 후, 대상 값을 어떻게 변환해와야하는지 (transform) 에 대한 메타데이터를 정의한 타입과 디코레이터 함수.
자세한 내용은 Prerequisite
타입 및 디코레이터 함수에 적힌 주석을 읽어볼 것.
SecretKey<string, string[]?>
export interface IGoogleDriveFileUploader {
token: string & SecretKey<"google-auth-key">;
location: string;
file: File;
}
SecretKey<string, string[]?>
타입은 스튜디오의 워크플로우 프로그램에서 특정 커넥터 함수를 실행함에 있어, 어떠한 속성 내지 파라미터가 외부 서비스의 secret key 를 필요로 할 때 사용하는 타입이다. 만일 해당 서비스가 OAuth 의 scopes
에 대한 제약 또한 가해진 경우, 두 번째 template argument string[]
타입을 설정해주면 된다.
위 예제 코드 IGoogleDriveFileUploader
와 같이 구글 드라이브에 파일을 업로드하는 경우, DTO 수준에서 구글 사용자 인증 토큰이 필요하기 마련이다. 그리고 구글처럼 각각이 발생되는 사용자 인증 토큰에 OAuth 의 scopes
라는 제약을 두어 그 권한을 깐깐하게 관리하는 경우, 두 번째 파라미터 string[]
또한 그에 맞추어 설정해줘야 한다.
@RouteIcon()
export function RouteIcon(uri: string): MethodDecorator;
Controller 메서드에 @RouteIcon()
을 적용하면, 아이콘을 적용할 수 있다.
@RouteIcon(url: string)
에 입력한 URL 주소는 스웨거 문서의 해당 endpoint 부에, ISwaggerRoute["x-wrtn-icon"]
속성으로 기입된다.
단, 본 디코레이터는 파라미터로 입력한 URL 값의 실존 여부를 검증하지 않으니, 이 점 주의하기 바란다.
@SelectorParam()
export function SelectorParam<T extends SelectorParam.IElement<any>>(
neighbor: () => (...args: any[]) => Promise<T[]>,
): ParameterDecorator;
export namespace SelectorParam {
export interface IElement<T> {
title: string;
data: T;
}
}
Path parameter 에 @SelectorParam()
를 적용하면 된다.
단 @SelectorParam()
에 적용하는 대상 메서드는, 반드시 title
과 data
필드가 정의된 객체의 배열 타입을 리턴해야 한다.
이후 npx nestia swagger
명령어를 통하여 스웨거 문서를 생성하는 경우, 아래와 같이 swagger.json
파일의 해당 endpoint 객체에 "x-wrtn-selector"
라는 필드가 추가된다.
@Controller("connector/google-calendar")
import core from "@nestia/core";
import { Controller } from "@nestjs/common";
import { RouteIcon, SelectorParam } from "@wrtn/decorators";
import { IGoogleCalendar } from "@wrtn/connector-api/lib/structures/connector/google_calendar/IGoogleCalendar";
import { GoogleCalendarProvider } from "../../../providers/connector/google_calendar/GoogleCalendarProvider";
@Controller("connector/google-calendar")
export class GoogleCalendarController {
@RouteIcon("https://typia.io/favicon/android-chrome-192x192.png")
@core.TypedRoute.Post("/:calendarId/get-events")
public async readEvents(
// 대상 메서드의 리턴 타입은 반드시,
// title 및 data 등의 속성을 담은 오브젝트의 배열이어야 함.
@SelectorParam(() => GoogleCalendarController.prototype.readCalenders)
@core.TypedParam("calendarId") calendarId: string,
@core.TypedBody() input: IGoogleCalendar.IReadGoogleCalendarEventInput,
): Promise<IGoogleCalendar.IReadGoogleCalendarEventOutput>;
// Selector 대상 메서드는 최소 아래 리턴값을 지켜야 함.
@core.TypedRoute.Get()
public async readCalenders(): Promise<Array<{
title: string;
data: string;
}>>;
}
{
"openapi": "3.0.1",
"servers": [
{
"url": "https://github.com/samchon/nestia",
"description": "insert your server url"
}
],
"info": {
"version": "0.2.0",
"title": "@wrtn/decorators",
"description": "",
"license": {
"name": "COMMERCIAL"
}
},
"paths": {
"/connector/google-calendar/{calendarId}/get-events": {
"get": {
"tags": [],
"x-wrtn-icon": "https://typia.io/favicon/android-chrome-192x192.png",
"parameters": [
{
"name": "calendarId",
"in": "path",
"schema": {
"type": "string"
},
"description": "",
"required": true,
"x-wrtn-selector": {
"method": "get",
"path": "/connector/google-calendar"
}
}
],
"responses": {
"200": {
"description": "",
"content": {
"application/json": {
"schema": {
"type": "array",
"items": {
"type": "object",
"properties": {
"something": {
"type": "number"
},
"nothing": {
"type": "boolean"
},
"anything": {
"type": "string"
}
},
"nullable": false,
"required": ["something", "nothing", "anything"]
}
}
}
}
}
}
}
},
"/connector/google-calendar": {
"get": {
"tags": [],
"parameters": [],
"responses": {
"200": {
"description": "",
"content": {
"application/json": {
"schema": {
"type": "array",
"items": {
"type": "object",
"properties": {
"title": {
"type": "string"
},
"data": {
"type": "string"
}
},
"nullable": false,
"required": ["title", "data"]
}
}
}
}
}
}
}
}
},
"components": {
"schemas": {}
}
}
@Standalone()
export function Standalone(): MethodDecorator;
Controller 메서드에 @Standalone()
을 적용하면, 해당 API 함수는 단독으로 실행 가능한 것임을 뜻한다. 그리고 이는 스웨거 문서의 해당 operation 부에, ISwaggerRoute["x-wrtn-standalone"]
속성으로써 기입된다.
FAQs
스튜디오 프로젝트를 위한 NestJS 디코레이터 모음.
We found that @wrtn/decorators demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 9 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.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.