Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dscyrescotti/codablex

Make Swift's Codable easier using Property Wrappers.
https://github.com/dscyrescotti/codablex

codable json-parsing propertywrapper spm swift swift-codable swiftpackagemanager

Last synced: 3 months ago
JSON representation

Make Swift's Codable easier using Property Wrappers.

Awesome Lists containing this project

README

        





Platform Compatibility


Swift Compatibility


Action Status


MIT License

__CodableX__ provides the property wrappers that are pretty handy to decode and encode structs or classes as you desire without implementing your custom codable structs or classes from scratch.

## Installation

### Swift Package Manager
Add it as a dependency within your `Package.swift`,
```swift
dependencies: [
.package(url: "https://github.com/dscyrescotti/CodableX.git", from: "0.2.0")
]
```

### CocoaPods
Inside your Podfile,
```ruby
pod 'CodableX', :git => 'https://github.com/dscyrescotti/CodableX.git'
```

Currently, __CodableX__ can be installed via __Swift Package Manager__ and __CocoaPods__.

## @AnyValuable
`@AnyValuable` is pretty similar to the original `@Anyable` property wrapper. It wraps decoded value inside `AnyValue` which can hold the type that conforms to `AnyCodable` and also provide easier access to value than `Any`.

### Usage
Using the default options of __CodableX__.

```swift
struct AnyValuableExample: Codable {
@AnyValuable var value: AnyValue // Int, String, Bool or Double inside AnyValue
}

let data = #"{ "value": 1 }"#.data(using: .utf8)!

let decoded = try JSONDecoder().decode(AnyValuableExample.self, from: data)

print(decoded) // AnyValuableExample(value: AnyValue(value: 1))
```

___Note: `DefaultOptions` only supports for `Int`, `String`, `Bool` and `Double`.___

### Accessing the value inside `AnyValue`

```swift
// You can directly access data via value
print(decoded.value) // 1
```
Or
```swift
// You can access data via type casting. It's helpful for optional unwrapping and is also clear to read.
print(decoded.value.int) // Optional(1)
```

___Note: `AnyValue` already has type casting for Swift built-in types. For your custom types, you can extend `AnyValue` to declare them.___

Using the custom options.

```swift
struct Custom: AnyCodable {
let value: String
}

// For type casting
extension AnyValue {
var custom: Custom? {
value as? Custom
}
}

struct CustomOptions: OptionConfigurable {
static var options: [Option] = [
.init(Int.self),
.init(Custom.self),
// add more
]
}

struct AnyValuableExample: Codable {
@AnyValuable var value: AnyValue // Int, Custom or types you specify inside AnyValue
}
```

___Note: All the options of structs or classes must conform to `AnyCodable`.___

For the array of `AnyValuable` and the optional `AnyValuable`, you can use __`@ArrayAnyValuable`__ and __`@OptionalAnyValuable`__.

## @Anyable

`@Anyable` is designed to decode and encode any value that matches one of the types that you pre-configure. It is very handy when the value of API response will be sure one of the values that API sends.

### Usage

Using the default options of __CodableX__.

```swift
struct AnyableExample: Codable {
@Anyable var value: Any // Int, String, Bool or Double
}

let data = #"{ "value": 1 }"#.data(using: .utf8)!

let decoded = try JSONDecoder().decode(AnyableExample.self, from: data)

print(decoded) // AnyableExample(value: 1)
```

___Note: `DefaultOptions` only supports for `Int`, `String`, `Bool` and `Double`.___

Using the custom options.

```swift
struct Custom: AnyCodable {
let value: String
}

struct CustomOptions: OptionConfigurable {
static var options: [Option] = [
.init(Int.self),
.init(Custom.self),
// add more
]
}

struct AnyableExample: Codable {
@Anyable var value: Any // Int, Custom or types you specify
}
```
___Note: All the options of structs or classes must conform to `AnyCodable`.___

For the array of `Anyable` and the optional `Anyable`, you can use __`@ArrayAnyable`__ and __`@OptionalAnyable`__.

## @Forcable
All credits to __[BetterCodable](https://github.com/marksands/BetterCodable)__.

`@Forcable` is useful to force the value to be the specific type that you set when it decodes.

### Usage
```swift
struct ForceValue: Codable {
@Forcable var value: Bool
}

let data = #"{ "value": "true" }"#.data(using: .utf8)!

let decoded = try JSONDecoder().decode(ForceValue.self, from: data)

print(decoded) // ForceValue(value: true)
```

It allows you to customize the list of options just like `@Anyable`. It will find the type that match the data from API response from your list and then force to a specific type that you want.

For the array of `Forcable` and the optional `Forcable`, you can use __`@ArrayForcable`__ and __`@OptionalForcable`__.

## @Nullable

`@Nullable` serves as the traditional `Optional` (aka ?) of `Swift`. When encoding, it is able to encode `nil` as `null` in JSON.

### Usage
```swift
struct NullValue: Codable {
@Nullable var value: Int?
}

let data = #"{ "value": null }"#.data(using: .utf8)!

let decoded = try JSONDecoder().decode(NullValue.self, from: data)

print(decoded) // NullValue(value: nil)
```

## @Defaultable
`@Defaultable` provides the default value when the coding key is not found or the value is missing.

### Usage
For `Swift` built-in types, it will use the default `init()` method. For your custom structs or classes, you must make them conform to `DefaultCodable` and set the default value.

```swift
struct DefaultValue: Codable {
@Defaultable var value: String
}

let data = #"{ "value": null }"#.data(using: .utf8)!

let decoded = try JSONDecoder().decode(DefaultValue.self, from: data)

print(decoded) // DefaultValue(value: "")
```

If you want different default values of the same struct or class, or you need the custom default value for built-in types, __`@CustomDefaultable`__ will solve it.

```swift
struct CustomDefault: DefaultConfigurable {
static var defaultValue: String = "dope"
}

struct DefaultValue: Codable {
@CustomDefaultable var value: String
}

```

## @Compactable

`@Compactable` is designed to decode the array of optional values and store values that are not null. Its name comes from `compactMap(_:)` of Swift because it removes null and invalid values from array.

### Usage
```swift
struct CompactValue: Codable {
@Compactable var array: [Int]
}
```

## @Jsonable

`@Jsonable` is handy to decode data into JSON object structure using dictionary of `Swift`. Literally, it works like `JSON.parse()` in `JavaScript`.

### Usage
```swift
struct JsonValue: Codable {
@Jsonable var json: Any
}

```

## Author

__Dscyre Scotti__ (__[@dscyrescotti](https://twitter.com/dscyrescotti)__)

## Credits

__CodableX__ is inspired by __[BetterCodable](https://github.com/marksands/BetterCodable)__ and __[AnyCodable](https://github.com/levantAJ/AnyCodable)__.

## Contributions

__CodableX__ welcomes all developers to contribute if you have any idea to improve and open an issue if you find any kind of bug.

## License

CodableX is available under the MIT license. See the [LICENSE](LICENSE) file for more info.