Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mpetuska/kon
Kotlin Object Notation - Lightweight DSL to build fluid JSON trees
https://github.com/mpetuska/kon
json kotlin multiplatform
Last synced: 6 days ago
JSON representation
Kotlin Object Notation - Lightweight DSL to build fluid JSON trees
- Host: GitHub
- URL: https://github.com/mpetuska/kon
- Owner: mpetuska
- License: apache-2.0
- Created: 2021-10-14T14:12:41.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-09-03T22:10:34.000Z (4 months ago)
- Last Synced: 2025-01-01T14:04:59.889Z (13 days ago)
- Topics: json, kotlin, multiplatform
- Language: Kotlin
- Homepage: https://mpetuska.github.io/kon
- Size: 482 KB
- Stars: 47
- Watchers: 2
- Forks: 1
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- kmp-awesome - Kotlin Object Notation - Lightweight DSL to build fluid JSON trees (Libraries / 🗃 Serializer)
README
[![Slack chat](https://img.shields.io/badge/kotlinlang-chat-green?logo=slack&style=flat-square)](https://kotlinlang.slack.com/team/UL1A5BA2X)
[![Dokka docs](https://img.shields.io/badge/docs-dokka-orange?style=flat-square&logo=kotlin)](http://mpetuska.github.io/kon)
[![Version maven-central](https://img.shields.io/maven-central/v/dev.petuska/kon?logo=apache-maven&style=flat-square)](https://mvnrepository.com/artifact/dev.petuska/kon/latest)# Kotlin Object Notation
Lightweight kotlin MPP DSL for building JSON trees
## Setup
Just drop the dependency in your `commonMain` sourceSet
```kotlin
kotlin {
sourceSets {
commonMain {
dependencies {
implementation("dev.petuska:kon:_")
}
}
}
}
```### Usage
Build the object map via `kobj` builder function. Built object overrides `Any::toString` function to return proper json
representation of the underlying structure. Currently, supported kotlin types for json output are the following:* Map
* Array
* Collection
* KObject
* KArray
* Number
* Unsigned Number
* String
* Boolean
* null
* Pair
* Triple```kotlin
val json: KON = kobj {
"str" to "string"
"number" to 420
"boolean" to true
"object" {
"str" to "string"
"number" to 1
"pair" to (1 to null)
"triple" to Triple(1, "2", 3)
"boolean" to true
"withArray" [1, "2"]
"nested" {
"stillGood" to true
"nullable" to null
}
}
"consistentObject" to {
"nice?" to 69
}
"array"[
1,
"2",
true,
karr[1, "2", false],
kobj {
"inner" to true
}
]
"singleIntArray".to[1]
"singleIntArray2" to karr[1]
}
json.toString() // Will return json string
json.toJS() // Only available on js target. Will return JS Json object
val jsonObject = json.toJsonObject() // Requires kon-serialization dependency. Will return kotlinx.serialization JsonObject.
jsonObject.toKObject() // Requires kon-serialization dependency. Will return KON KObject.
```### Modules
* [kon](./) - wrapper module bringing all the other modules as transitive dependencies
* [kon-core](./lib/kon-core) - core implementation module
* [kon-serialization](./lib/kon-serialization) - kotlinx-serialization interop module