Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/scordio/spring-batch-notion
Spring Batch extension for Notion
https://github.com/scordio/spring-batch-notion
batch hacktoberfest java notion spring
Last synced: 3 months ago
JSON representation
Spring Batch extension for Notion
- Host: GitHub
- URL: https://github.com/scordio/spring-batch-notion
- Owner: scordio
- License: apache-2.0
- Created: 2022-12-26T13:38:01.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-26T21:30:46.000Z (4 months ago)
- Last Synced: 2024-10-14T20:29:48.865Z (3 months ago)
- Topics: batch, hacktoberfest, java, notion, spring
- Language: Java
- Homepage:
- Size: 217 KB
- Stars: 9
- Watchers: 1
- Forks: 0
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# Spring Batch Notion [![Maven Central](https://img.shields.io/maven-central/v/io.github.scordio/spring-batch-notion?label=Maven%20Central)](https://mvnrepository.com/artifact/io.github.scordio/spring-batch-notion) [![javadoc](https://javadoc.io/badge2/io.github.scordio/spring-batch-notion/javadoc.svg)](https://javadoc.io/doc/io.github.scordio/spring-batch-notion)
[![CI](https://github.com/scordio/spring-batch-notion/actions/workflows/main.yml/badge.svg?branch=main)](https://github.com/scordio/spring-batch-notion/actions/workflows/main.yml?query=branch%3Amain)
[![Cross-Version](https://github.com/scordio/spring-batch-notion/actions/workflows/cross-version.yml/badge.svg?branch=main)](https://github.com/scordio/spring-batch-notion/actions/workflows/cross-version.yml?query=branch%3Amain)This project provides a [Spring Batch][] extension module that adds support for [Notion][].
## Compatibility
Spring Batch Notion is based on Spring Batch 5 and tested on Spring Boot 3, thus requiring at least Java 17.
Compatibility is guaranteed only with the Spring Boot versions under [OSS support](https://spring.io/projects/spring-boot/#support).
## Getting Started
### Maven
```xml
io.github.scordio
spring-batch-notion
${spring-batch-notion.version}```
### Gradle
```kotlin
implementation("io.github.scordio:spring-batch-notion:${springBatchNotionVersion}")
```## NotionDatabaseItemReader
The `NotionDatabaseItemReader` is a restartable `ItemReader` that reads entries from a [Notion Database] via a paging technique.
A minimal configuration of the item reader is as follows:
```java
NotionDatabaseItemReader itemReader() {
NotionDatabaseItemReader reader = new NotionDatabaseItemReader<>();
reader.setToken(System.getenv("NOTION_TOKEN"));
reader.setDatabaseId("XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX"); // UUID
reader.setPropertiesMapper(new CustomPropertyMapper());
return reader;
}
```The following configuration options are available:
| Property | Required | Default | Description |
|------------------|----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------|
| `baseUrl` | no | `https://api.notion.com/v1` | Base URL of the Notion API. A custom value can be provided for testing purposes (e.g., the URL of a [WireMock][] server). |
| `databaseId` | yes | - | UUID of the database to read from. |
| `filter` | no | `null` | `Filter` condition to limit the returned items. |
| `pageSize` | no | `100` | Number of items to be read with each page. Must be greater than zero and less than or equal to 100. |
| `propertyMapper` | yes | - | The `PropertyMapper` responsible for mapping properties of a Notion item into a Java object. |
| `sorts` | no | `null` | `Sort` conditions to order the returned items. Each condition is applied following the declaration order. |
| `token` | yes | - | The Notion integration token. |In addition to the Notion-specific configuration, all the configuration options of the Spring Batch
[`AbstractPaginatedDataItemReader`](https://docs.spring.io/spring-batch/docs/current/api/org/springframework/batch/item/data/AbstractPaginatedDataItemReader.html)
are supported.### PropertyMapper
The `NotionDatabaseItemReader` requires a `PropertyMapper` to map the properties of a Notion item into an object.
Currently, only properties of type [Title](https://developers.notion.com/reference/property-object#title)
and [Rich Text](https://developers.notion.com/reference/property-object#rich-text) are supported,
and both are converted to strings.The following `PropertyMapper` implementations are provided out of the box.
| Name | Description |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| `BeanWrapperPropertyMapper` | Supports JavaBeans. Requires a default constructor and expects the setter names to match the Notion item property names (case-insensitive). |
| `ConstructorPropertyMapper` | Supports types with a constructor with arguments. Requires the constructor to be unique and its argument names to match the Notion item property names (case-insensitive). |
| `RecordPropertyMapper` | Supports Java records. It uses the record canonical constructor and requires the record component names to match the Notion item property names (case-insensitive). |All implementations above offer two constructors:
* One accepting the `Class` instance of the type to be mapped
* One without parameters, for cases where the type to be mapped can be inferred by the generic type of the variable or method enclosing the constructor declarationIn case none of the provided implementations is suitable, a custom one can be provided.
## NotionDatabaseItemWriter
Currently not provided but will be added in the future.
## License
The Spring Batch Notion is released under version 2.0 of the [Apache License][].
[Apache License]: https://www.apache.org/licenses/LICENSE-2.0
[Notion]: https://notion.so/
[Notion Database]: https://www.notion.so/help/category/databases
[Spring Batch]: https://github.com/spring-projects/spring-batch
[WireMock]: https://wiremock.org/