Skip to content

A lightweight pure Swift SDK for the Storyblok Content Delivery and Management APIs

License

Notifications You must be signed in to change notification settings

regiolix-solutions/storyblok-swift-sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Storyblok Swift SDK - 0.1.10

Version License Platform

TL;DR

This is a Swift SDK/Wrapper around the Storyblok Delivery API and the Storyblok Management API. As of now, only Story fetching, creation and deletion is supported. Additionally there is are Utility and Model classes for resolving RichText Objects from Storyblok (As of now there is only an Implementation for transforming the object to an HTML String)

Version 0.1.10

  • Fixed startDataTaskWithCheckedThrowingContinuation method on RXSDataConnection class not calling resume method on session dataTask to trigger the request.

Version 0.1.9

  • Fixed StoryVersion query which was passing the query as 'Draft'/'Published' instead of 'draft'/'published' as is required by the Storyblok API.

Version 0.1.7

  • Queries with date related parameters weren't sending the date according to Storyblok API specs. Date queries are properly formatted now.

Version 0.1.5

  • Fixed cocoapods source files path
  • Fixed Multi story parameters fix (when searching for slugs or uuids)

Version 0.1.2

  • Added a SingleStory struct so it processes correctly single stories.
  • Fixed the single story fetch methods so they fetch properly even when no custom dataConnection is configured.
  • Added Swift Package Manager support

Version 0.1.1

  • Added Utility and Model classes for resolving RichText Objects from Storyblok
  • The SDK's Minimum Deployment Target is now iOS 13.0
  • Resolved some minor issues

Version 0.1.0

  • Added static Storyblok class for Client Management.
    • Configure and use the shared Client for basic use cases that only require 1 Client.
    • Create new Content Delivery or Management Clients managed by the static Storyblok class and retrieve them at a later time using an identifier.
    • Create new Content Delivery or Management Clients and manage them yourself.
  • Added Storyblok Delivery API for fetching stories.
    • Fetch a single story, optionally applying a StoryblokSingleStoryQuery.
    • Fetch multiple stories, optionally applying a StoryblokMultipleStoryQuery.
  • Added Storyblok Management API for creating and deleting stories.
    • Create a new story.
    • Delete a story by Id.

What is Storyblok?

Installation

RXSStoryblokClient is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod 'RXSStoryblokClient'

Examples And Usage

Initialize Storyblok SDK

For a single Space

The simplest and most common use case would be to access only a single space. This can easily be done by configuring the shared client exposed by the static Storyblok class. You can do so by calling the following function on the shared client.

For Content Delivery Access (Fetching Data)

Storyblok.shared.configureForContentDeliveryAccess(apiKey: String)

For Management Access (Fetching & Manipulating Data)

Storyblok.shared.configureForManagementAccess(apiKey: String, oAuthToken: String, spaceId: String)

For multiple Spaces

If your use case requires access to more than 1 space, you can use the client management functions exposed by the static Storyblok class to initialize new ContentDelivery or Management Clients and optionally let them be retained and managed by the static Storyblok class by adding an identifier upon creation.

For creating a Content Delivery Client you need to manage yourself

Storyblok.shared.contentDeliveryClient(forApiKey apiKey: String) -> StoryblokClient

For creating a Content Delivery Client managed by the static Storyblok class

Storyblok.shared.contentDeliveryClient(forApiKey apiKey: String, identifiedBy identifier: String) -> StoryblokClient

For retrieving a Content Delivery Client managed by the static Storyblok class

Storyblok.shared.contentDeliveryClient(identifiedBy identifier: String) -> StoryblokClient

For creating a Management Client you need to manage yourself

Storyblok.shared.managementClient(forApiKey apiKey: String, withOAuthToken token: String, andSpaceId spaceId: String) -> StoryblokClient

For creating a Management Client managed by the static Storyblok class

Storyblok.shared.managementClient(forApiKey apiKey: String, withOAuthToken token: String, andSpaceId spaceId: String, identifiedBy identifier: String) -> StoryblokClient

For retrieving a Management Client managed by the static Storyblok class

Storyblok.shared.managementClient(identifiedBy identifier: String) -> StoryblokClient

Custom Client

By default these functions will return a new instance of the RXSStoryblokClient class which conforms to the StoryblokClient protocol. If for some reason you feel the need to implement custom logic for the communication with the Storyblok API you could create your own StoryblokClient. All of the functions above are generic and will create a new instance of the infered Type.

Example for using a custom StoryblokClient

let client: MyStoryblokClient = Storyblok.shared.contentDeliveryClient<Client: StoryblokClient>(forApiKey apiKey: String, identifiedBy identifier: String) -> Client

Usage

Whatever method you choose for creating and managing your StoryblokClients, for actually retrieving and manipulating data the StoryblokClient protocol exposes the following functions

Fetching a single Story

func fetchStory<T: StoryContent>(identifiedBy identifier: StoryIdentifier) async throws -> SingleStory<T>?
func fetchStory<T: StoryContent>(identifiedBy identifier: StoryIdentifier, applying query: StoryblokSingleStoryQuery) async throws -> SingleStory<T>?

Fetching multiple Stories

func fetchStories<T: StoryContent>(applying query: StoryblokMultiStoryQuery) async throws -> Stories<T>?

Creating a Story

func createStory<T: StoryContent>(_ story: ManagementStory<T>) async throws -> ManagementStory<T>?

Updating a Story

func updateStory<T: StoryContent>(_ story: ManagementStory<T>) async throws -> ManagementStory<T>?

Deleting a Story

func deleteStory(withId id: Int64) async throws

Examples

This is an example for basic usage of the SDK

//Create a task to call async functions
Task(){
    do{
        //Configure the shared StoryblokClient for Content Delivery Access
        Storyblok.shared.configureForContentDeliveryAccess(apiKey: "3nogoFf7qI8bbvrwtaXQAQtt")
        
        //Explicitely add your expected data type to make sure Swift can infer the generic type for the function call
        //Fetch multiple stories, adding a query that only loads stories that have full slugs starting with "blog"
        if let response: Stories<StoryContent> = try await Storyblok.shared.fetchStories(applying:
                .queryForStories()
                .startingWith("blog")
        ){
            //Do something with the retrieved data
            stories = response.stories
        }
    } catch {
        //Handle error
    }
}

Configuration

You can configure the SDK on a global level by setting the static configurationDelegate property in the Storyblok class. To do so, the object you assign has to conform to the StoryblokConfigurationDelegate. Note that all of the protocol's functions have default implementations and are therefor not required.

Custom DataConnection

If you - for example - already use Alamofire in your project you can return your own implementation of the DataConnection protocol here.

func dataConnection() -> DataConnection

Timeouts

func timeoutIntervalForRequest() -> TimeInterval
func timeoutIntervalForResource() -> TimeInterval

Cellular Data for Background Downloads

func allowsCellularAccessForBackgroundDownloads() -> Bool

Richtext Resolving

This SDK contains Utility and Model classes for resolving a RichText Object from Storyblok.

RichTextNode

The RichTextNode struct defines the structure of a RichText Object as received by Storyblok's APIs and can be de-/serialized for communication with said APIs.

RichTextSchema

The RichTextSchema protocol defines a function used to transform a given RichTextNode to any other usable format.

HtmlSchema

The HtmlSchema class is an implementation of the RichTextSchema protocol that transforms a given RichTextNode to an HTML String.

RichTextResolver

The RichTextResolver class implements the following function, which can be used to transform a given RichTextNode to some other format using any RichTextSchema Implementation.

public static func resolveNode<Schema: RichTextSchema>(_ node: RichTextNode, applyingSchema schema: Schema.Type, into initialValue: inout Schema.T)

Author

Medweschek Michael, [email protected]

License

RXSStoryblokClient is available under the MIT license. See the LICENSE file for more info.

About

A lightweight pure Swift SDK for the Storyblok Content Delivery and Management APIs

Resources

License

Stars

Watchers

Forks

Packages

No packages published