Swiftpack.co - orlandos-nl/BSON as Swift Package

Swiftpack.co is a collection of thousands of indexed Swift packages. Search packages.
See all packages published by orlandos-nl.
orlandos-nl/BSON 8.0.10
Native Swift library for BSON (http://bsonspec.org)
⭐️ 104
🕓 1 year ago
iOS macOS linux macOS iOS
.package(url: "https://github.com/orlandos-nl/BSON.git", from: "8.0.10")

BSON

A fast BSON library, compliant to the whole BSON specification test suite. The library parses the binary data on-demand, delaying copies until the last second.

BSON is parsed and generated as specified for version 1.1 of the BSON specification.

Be sure to read our full documentation and API reference.

Installation

BSON uses the Swift Package Manager. Add BSON to your dependencies in your Package.swift file:

.package(url: "https://github.com/orlandos-nl/BSON.git", from: "8.0.0")

Also, don't forget to add "BSON" as a dependency for your target.

Basic Usage

Create Documents using Dictionary Literals:

var userDocument: Document = [
  "username": "Joannis",
  "online": true,
  "age": 20,
  "pi_constant": 3.14,
  "profile": [
    "firstName": "Joannis",
    "lastName": "Orlandos"
  ]
]

let favouriteNumbers: Document = [1, 3, 7, 14, 21, 24, 34]

userDocument["favouriteNumbers"] = favouriteNumbers

Access values in an array like you would in Swift Arrays and values in an object like a Dictionary.

let favouriteNumber = favouriteNumbers[0]
let usernameValue = userDocument["username"]

Extract types with simplicity:

let username = String(userDocument["username"]) // "Joannis"
let isOnline = Bool(userDocument["online"]) // true
let age = Int(userDocument["age"]) // 20
let pi = Double(userDocument["pi_constant"]) // 3.14

Chain subscripts easily to find results without a hassle as shown underneath using this JSON structure (assuming this is represented in BSON):

{
  "users": [
    {
      "username": "Joannis",
      "profile": {
        "firstName": "Joannis",
        "lastName": "Orlandos"
      }
    },
    {
      "username": "Obbut",
      "profile": {
        "firstName": "Robbert",
        "lastName": "Brandsma"
      }
    }
  ]
}
let obbutLastName = String(object["users"][1]["profile"]["lastName"]) // "Brandsma"

Nested Documents

Complex array and dictionary literals may confuse the Swift type system. If this happens to you, make the literal explicitly a Document type:

var userDocument: Document = [
  "username": "Joannis",
  "online": true,
  "age": 20,
  "pi_constant": 3.14,
  "profile": [
    "firstName": "Joannis",
    "lastName": "Orlandos",
    "pets": [
        [
          "name": "Noodles",
          "type": "Parrot"
        ] as Document,
        [
          "name": "Witje",
          "type": "Rabbit"
        ]
      ] as Document
    ] as Document
]

Codable

Document can be instantiated from SwiftNIO's ByteBuffer or Foundation.Data. You can validate the formatting of this document manually using the .validate() function. This will also specify where the data was found corrupt.

If you pass a Document or Primitive into the BSONDecoder you can decode any Decodable type if the formats match. Likewise, BSONEncoder can encode your Swift types into a Document.

GitHub

link
Stars: 104
Last commit: 5 days ago
Advertisement: IndiePitcher.com - Cold Email Software for Startups

Dependencies

Release Notes

8.0.9
1 year ago
  • Fix a crash that could occur when converting a double into an integer, with the double being out of the integer's bounds.
  • Support implicit number conversion in FastBSONDecoder, as it's a common use case

Full Changelog: https://github.com/orlandos-nl/BSON/compare/8.0.8...8.0.9

Swiftpack is being maintained by Petr Pavlik | @ptrpavlik | @swiftpackco | API | Analytics