Gatsby + Notion = ✨
Notion에 아카이빙한 문서들을 Gatsby 정적 블로그로 서비스하기 위해 개발된 플러그인입니다.
손쉽게 Gatsby에서 GraphQL로 Notion 데이터베이스를 조회할 수 있습니다.
Gatsby 정적 사이트의 CMS로 Notion을 생각하셨다면, 이 플러그인이 도움이 될 수 있을 것입니다.
1개의 Notion 계정만 연결이 가능하며, 해당 계정 내의 여러 데이터베이스와 연결할 수 있습니다.
orlowdev/gatsby-source-notion-api 플러그인을 fork하여 개발되었습니다.
이용 사례에 등록을 원하실 경우 Use Case Issue로 등록해주세요.
- Weezip 블로그 서비스에서 사용하고 있습니다.
Notion API를 사용하고 있으므로 아래 문서를 참고하시면 좋습니다.
- Notion 공식 API
2022-06-28
버전을 사용합니다. - Notion 데이터베이스 API의 페이지 필터 기능을 이용할 수 있습니다.
- Notion 자체적인 request-limits 제한 정책으로 인해, block 정보를 조회하는 과정에서 API 호출을 재시도할 수 있습니다.
- 모든 block 정보가 조회된 페이지는 캐싱하여 제공합니다.
조회 가능한 응답 및 자세한 block 구조는 Notion A block object에서 더 자세히 확인하실 수 있습니다.
- 마크다운 양식을 지원할 예정입니다.
yarn add gatsby-source-notion-feely
or
npm install --save gatsby-source-notion-feely
먼저 Notion API 호출을 위한 Key와 연결할 데이터베이스 ID가 필요합니다. 아래는 발급 단계에 대한 간단한 설명으로 Notion Build your first integration에서 더 자세히 확인하실 수 있습니다.
- Notion에 로그인 후 새 Integration을 생성합니다. -> 바로가기
- 이미 사용 중인 Key가 있다면, 이 단계는 생략될 수 있습니다.
- Notion Create your integration in Notion에서 더 자세히 확인하실 수 있습니다.
- Notion에서 연결할 데이터베이스를 생성합니다.
- 이미 생성한 데이터베이스가 있다면, 이 단계는 생략될 수 있습니다.
- 연결할 페이지에서 위에 생성한 Integration을 연결합니다.
- [Pick Page] - [...(More)] - [+ Add Connections] - Integration 선택
- 데이터베이스가 포함된 페이지에서 Integration을 연결할 경우, 하위 페이지들에도 자동으로 적용됩니다.
- Notion Give your integration page permissions에서 더 자세히 확인하실 수 있습니다.
- 데이터베이스 ID를 확인합니다.
- 반드시 데이터베이스가 포함된 페이지가 아닌, 데이터베이스 페이지에서 확인해야합니다.
- Notion Retrieve a database Guide에서 더 자세히 확인하실 수 있습니다.
To find a database ID, navigate to the database URL in your Notion workspace. The ID is the string of characters in the URL that is between the slash following the workspace name (if applicable) and the question mark. The ID is a 32 characters alphanumeric string.
여러 데이터베이스를 연결하는 경우에는 모든 데이터베이스에 대해 3번과 4번 작업을 진행해야합니다.
plugins: [
{
resolve: `gatsby-source-notion-feely`,
options: {
token: `{YOUR__INTEGRATION__KEY}`,
databases: [
{
id: `{YOUR__DATABASE__ID}`,
name: `{ANY__NAME__VALUE}`,
},
],
},
},
];
gatsby-config.js
에 설정을 추가합니다. 설정 관련 더 자세한 내용은 뒤의 4. 설정값 섹션을 확인해주세요.
plugins: [
{
resolve: `gatsby-source-notion-feely`,
options: {
token: `ItsMyIntegrationKey`,
databases: [
{
id: `ItsFirstDataBaseID`,
name: `blog`,
pageFilter: {
property: "is_published",
checkbox: {
equals: true,
},
},
},
{
id: `ItsSecondDataBaseID`,
name: `archive`,
option: {
isIncludeChildren: false
}
},
],
},
},
];
- 노션에서 발급받은 Integration Key인
ItsMyIntegrationKey
를token
으로 전달해 Notion 연결을 진행합니다. ItsFirstDatabaseID
데이터베이스를 조회합니다.- 이 데이터베이스의 이름은
blog
로 설정합니다. - Notion API 필터를 적용해
is_published
체크박스가 선택된 페이지만 조회합니다.
- 이 데이터베이스의 이름은
ItsSecondDataBaseID
데이터베이스를 조회합니다.- 이 데이터베이스의 이름은
archive
로 설정합니다. - 페이지 내 하위 블럭은 조회하지 않고, 페이지 정보만 조회합니다.
- 이 데이터베이스의 이름은
query {
allNotion {
edges {
node {
id
parent
children
internal
databaseName
title
json
createdAt
updatedAt
}
}
}
}
이제 Gatsby에서 GraphQL로 데이터를 조회할 수 있습니다.
JSON.parse(json)
을 통해 Notion 페이지 객체를 이용할 수 있습니다.
interface Options {
token: string;
databases: Array<{
id: string;
name: string;
pageFilter?: NotionFilterJSON;
option?: {
isIncludeChildren?: boolean
}
}>
}
Field | Type | Description | Default |
---|---|---|---|
token |
string | Notion에서 발급받은 토큰 키. | |
databases |
Array | 연결할 Notion 데이터베이스 정보 배열. | |
id |
string | databases 내부 객체의 하위 필드.Notion 데이터베이스 ID. |
|
name |
string | databases 내부 객체의 하위 필드.데이터베이스들의 명시적 구분을 위해 사용할 이름. |
|
pageFilter |
databases 내부 객체의 하위 필드.데이터베이스 필터 쿼리. Filter database entries 참조. |
undefined |
|
option |
databases 내부 객체의 하위 필드.추가 옵션 설정. |
||
isIncludeChildren |
boolean | option 객체의 하위 필드.true 일 경우, 데이터베이스 페이지 내 하위 블럭까지 조회. false 일 경우, 데이터베이스 페이지만 조회. |
true |
interface Response {
id: string;
parent: null;
children: [];
databaseName: string;
title: string;
json: string;
createdAt: string;
updateAt: string;
}
Field | Type | Description |
---|---|---|
id |
string | 페이지마다 생성된 Gatsby 노드 ID. Gatsby 공식 문서에서 더 자세히 확인하실 수 있습니다. |
parent |
null | 부모 노드 ID. 최상위 노드이기 때문에 null 로 지정됩니다. |
children |
[] | 자식 노드 ID의 배열. 자식 노드를 가지지 않기 때문에 [] 로 지정됩니다. |
databaseName |
string | 플러그인 연결 시 설정한 데이터베이스 이름. |
title |
string | 데이터베이스의 title 로 설정된 컬럼의 정보. |
json |
string | 페이지 정보를 JSON string으로 변환한 정보. Notion API 공식 문서에서 더 자세히 확인하실 수 있습니다. |
createdAt |
string | 데이터베이스가 생성된 ISO 8601 형식의 날짜 및 시간. |
updatedAt |
string | 데이터베이스가 마지막으로 변경된 ISO 8601 형식의 날짜 및 시간. |
v2.0.0에서 삭제되었습니다.
- Notion 데이터베이스 매개변수 중
isCheckPublish
값이 삭제되었습니다.- checkbox 타입의
is_published
값을 판단할 수 있게 해주는 이 값은pageFilter
로 대체되어 더 폭넓은 필터링을 지원할 수 있게 되었습니다.
- checkbox 타입의
Jest를 사용하고 있으며, /test/gatsby-node.test.js
파일이 실행됩니다.
.env.test
환경변수 파일을 추가합니다.NOTION_INTEGRATION_TOKEN
,NOTION_DB_ID
환경변수를 설정합니다.yarn test
를 실행합니다.
더 멋진 기능을 위한 이슈 생성과 PR을 기다리고 있습니다.
gatsby-source-notion-feely is 0BSD.