Skip to content

Latest commit

 

History

History
355 lines (244 loc) · 16 KB

CHANGELOG.md

File metadata and controls

355 lines (244 loc) · 16 KB

Change Log

All notable changes to this project will be documented in this file. This project adheres to Semantic Versioning starting from 1.x releases.

Merged, but not yet released

All recent changes are published


Table of contents

1.x Releases

0.x Releases


Released on 2017-01-31

Fixed

  • String extension to generate an image url that didn't always prepend the "https" scheme to the url.

Released on 2017-01-25

Added

Fixed

  • Shared static localization context on the Client which caused issues if a new client connected to a different space was instantiated.
  • HTTP status codes not being exposed.

Released on 2017-01-09

Added

  • Instance method for mutating a query by appending a LinkQuery

Fixed

  • When generating a url from the helper methods that append ImageOptions, the 'https' scheme will always be applied.
  • The Location type is now an Objective-C that conforms to NSCoding class so that it may be stored in CoreData as an attribute on an NSManagedObject

Released on 2017-12-19

Fixed

  • Accessibility identifiers for the width and height properties of the ImageInfo for an Asset are now public so they can be used. Thanks to @ErikLuimes for the pull request: #157

Released on 2017-11-27

Fixed

  • Issue where true would be decoded to Int with value 1 when decoding JSON to [String: Any]. The SDK now attempts to decode Bool before Int to prevent this error.

Released on 2017-11-03

Fixed

  • Deprecation warnings that appeared starting with Xcode9.1
  • Incorrect assertion that asserted that all link were resolved since it is possible for unresolvable links to retured from CDA
  • If an entry was of a content type not known to the Client, the SDK would enter an infinite loop.

Released on 2017-10-24

No more breaking changes will be made before 1.0.0 release. Following this point, the project will strictly adhere to Semantic Versioning.

Added

  • ResourceQueryable protocol to enable safer queries via the QueryOn query type.
  • SyncSpace.SyncableType enum for specifying which Contentful types should be synced.
  • A description property to ContentType
  • A ContentTypeQuery for syncing content types.
  • ArrayResponseError type as a member of all array responses to inform you when your links are not resolvable because the target resources are unpubished.

Improved

  • All Error types now have better debug descriptions so that the most relevant info is given to you while debugging.

Fixed

  • Multiple link resolution callbacks can now be stored for one link in case multiple entries are linking to the same resource.

Changed

  • BREAKING: The helper methods for resolving links on the fields JSON container no longer requires passing in the current locale.
  • BREAKING: The parameter names have been made consistent accross all fetch method names. The parameter signatures for all fetch methods are now: (matching:then:).
  • BREAKING: All query initializers have been changed to static methods so that the syntax exactly matches the syntax of the instance methods.
  • BREAKING: Various methods for creating and mutating queries no longer throw errors and so the need to call them in a do catch block has been obviated.
  • BREAKING: QueryOperation is now called Query.Operation.

Removed

  • BREAKING: All fetch methods that previously took dictionary arguments have been removed. Use fetch methods that take query types instead.
  • BREAKING: Now unnecessary QueryErrors.

Released on 2017-10-10

Changed

  • BREAKING: EntryModellable is now called EntryDecodable and extends Decodable from the Swift 4 Foundation standard library. There are convenience methods for deserializing fields in the "fields" container for an entry.
  • BREAKING: The MappedContent type no longer exists. If requesting heterogeneous collections (by hitting "/entries" with no query paramters for intance), you will get a Result<MixedMappedArrayResponse> and it is up to you to filter the array by the contained types.

Fixed

  • #132 EntryDecodable not synthesizing arrays of links
  • #133 EntryDecodable not allowing properties that are implicit optionals

Released on 2017-10-06

Fixed

  • Compile error due to incorrect protection level setting

Released on 2017-10-03

Added

  • API for retreiving a JSONDecoder from the SDK and configuring it with localization information from your Contentful space.

Fixed

  • Array's of links not being decoded.

Released on 2017-10-02

Changed

  • BREAKING: The project is now compiled using Swift 4 and therefore must be developed against with Xcode 9. Backwards compatibility with Swift 3 is not possible as the SDK now uses Swift 4 features like JSON decoding via the Decodable protocol in Foundation.
  • BREAKING: CLLocationCoordinate2D has been replaced with Location type native to the SDK so that linking with CoreLocation is no longer necessary. If you have location enabled queries, you'll need to migrate your code. • Resource is now a protocol and is no longer the base class for Asset and Entry. LocalizableResource is the new base class.
  • ObjectMapper has been pruned and is no longer a dependency of the SDK. If managing your dependencies with Carthage, make sure to manually remove ObjectMapper if you aren't using it yourself.

Released on 2017-09-08

Fixed

  • Ensured all functions and instance members had an explicit protection level set.

Added

  • Xcode 8 and 9 are now tested on Travis CI for iOS, macOS, and tvOS in a matrix build. You can now rest easy knowing that if you are developing for one of these platforms, the SDK will work for you!
  • The Swift playground has been migrated from it's former home to live here, with the main SDK. Instructions have been added to the README.
  • DataDelegate protocol to receive callbacks from SDK which contain raw Data from fetches to the API.

Released on 2017-08-16

Fixed

  • Corrupt reference to AppKit extensions in xcodeproj which prevented compilation on macOS. In order to prevent future regressions, travis now runs unit tests for tvOS and macOS.
  • Initializer for ContentModel which was implicitly internal. The initializer is now exposed as public.

Added

  • Convenience methods for extracting typed values, including Entrys and Assets, from fields dictionaries.
  • Ability to make Querys on specific content types without conforming to EntryModellable.

Released on 2017-08-11

Added


Released on 2017-08-09

Changed

  • BREAKING: Modellable protocol now splits mapping of regular (non-relationship) fields, and link fields into two separate methods.

Fixed

  • #108 circular link references causing recursive loops. Also, duplicate objects being mapped by the system is now fixed. Thanks to @AntonTheDev for help scoping the fix.

Released on 2017-07-26

Fixed

  • Project configuration so that contentful.swift may be built from source without warnings. Thanks to @brentleyjones for the help and guidance. Implications for this change are that:
    • Dependencies are still managed with carthage but with the --use-submodules flag and the source (i.e. Carthage/Checkouts) is now tracked in git
    • Now travis doesn't install carthage or use it at all to build the project and Contentful.xcodeproj framework search paths are cleared.
  • #100 enabling the usage of contentful.swift in app extensions.

Added

  • The previously private persistenceIntegration instance variable is now a public var which means it can be set anytime after Client initialization.

Released on 2017-07-24

Added

  • String extension methods to generate urls for the Contentful Images API.

Released on 2017-07-19

Fixed


Released on 2017-07-18

Changed

  • Simplified and optimized sending messages to types conforming to PersistenceIntegration.

Released on 2017-07-17

Fixed

  • Deleted Links in Contentful that were not propagating to CoreData as nullfied managed relationships.

Released on 2017-07-17

Fixed

  • Delta messages from /sync endpoint were only being sent for last page when a sync was returned on multiple pages.

Released on 2017-07-12

Added

  • LocalizationContext is now a public variable on Space so that SDK consumers can direclty initialize Entry or Asset instances from bundled JSON.

Released on 2017-06-20

Fixed

  • Delta messages were not always forwarded to PersistenceIntegration when calling Client.nextSync() and Client.initialSync() in #71

Released on 2017-06-19

Changed

  • BREAKING: Subsequent sync is now a method on the Client called nextSync rather than being a method on SyncSpace.

Added

  • PersistenceIntegration protocol. Client can now be initialized with a persisistenceIntegration which will receive messages when Assets & Entrys are ready to be transformed to a persistable format and cached in persistent store such as CoreData. Note that this only works for the initialSync and nextSync operations.
  • The updatedAt and createdAt properties of the Sys type are now stored as Date objects instead of as Strings.
  • Integration protocol to append information about external integrations to Contentul HTTP user-agent headers.
  • A ContentModel type used to contain mapped ContentModellable (user-defined types) instances rather than Entry & Assets.
  • Support for initialSync when using the Content Preview API.

Released on 2017-06-12

Fixed

  • ImageOption that changed background using `Fit.pad(with: Color) now generates the correct URL.
  • Build error for watchOS caused by file from test target being added to watch target.

Released on 2017-06-12

Added

  • Support for mirroring API fallback locale logic in the SDK for scenarios when all locales are returned (i.e. when using the /sync endpoint or specifing locale=*)
  • Support for HTTP rate limit headers

Fixed


Released on 2017-05-31

Added


Released on 2017-05-23.

Fixed

  • Potential crash during sync callback due to unretained SyncSpace instance

Released on 2017-05-18.

Added

  • Swift'ier API for Contentful Delivery API Search Parameters
  • Mechanism for mapping responses to user-defined Swift types when using QueryOn queries.
  • Improved link resolving via the new Link type
  • Swift 3.1, Xcode 8.3 support.

Changed

  • BREAKING: Contentful.Array is now called ArrayResponse to avoid clashing with native Swift arrays.
  • BREAKING: fetch methods no longer return tuples of (URLSessionTask?, Observable) and now simply return the observable.

Released on 2017-02-03.

Added

  • Support for installation via Carthage on all of iOS, macOS, tvOS, & watchOS.

Released 2017-01-08.

Changed

  • BREAKING: Upgrade to Swift 3 and Xcode 8. Versions of Swift < 3 and Xcode < 8 no longer supported.