@@ -236,122 +236,122 @@ public class RemoteBlogSettings: NSObject {
236
236
237
237
/// Parses details from a JSON dictionary, as returned by the WordPress.com REST API.
238
238
@objc
239
- public init ( jsonDictionary json: NSDictionary ) {
240
- let rawSettings = json. object ( forKey : CodingKeys . settings. rawValue) as? NSDictionary ?? [ : ]
241
-
242
- name = json. string ( forKey : CodingKeys . name. rawValue)
243
- tagline = json. string ( forKey : CodingKeys . tagline. rawValue)
244
- privacy = rawSettings. number ( forKey : CodingKeys . privacy. rawValue)
245
- languageID = rawSettings. number ( forKey : CodingKeys . languageID. rawValue)
246
- iconMediaID = rawSettings. number ( forKey : CodingKeys . iconMediaID. rawValue)
247
- gmtOffset = rawSettings. number ( forKey : CodingKeys . gmtOffset. rawValue)
248
- timezoneString = rawSettings. string ( forKey : CodingKeys . timezoneString. rawValue)
249
-
250
- defaultCategoryID = rawSettings. number ( forKey : CodingKeys . defaultCategory. rawValue) ?? 1
251
- let defaultPostFormatValue = rawSettings. object ( forKey : CodingKeys . defaultPostFormat. rawValue)
239
+ public init ( jsonDictionary json: [ String : Any ] ) {
240
+ let rawSettings = json [ CodingKeys . settings. rawValue] as? [ String : Any ] ?? [ : ]
241
+
242
+ name = json [ CodingKeys . name. rawValue] as? String
243
+ tagline = json [ CodingKeys . tagline. rawValue] as? String
244
+ privacy = rawSettings [ CodingKeys . privacy. rawValue] as? NSNumber
245
+ languageID = rawSettings [ CodingKeys . languageID. rawValue] as? NSNumber
246
+ iconMediaID = rawSettings [ CodingKeys . iconMediaID. rawValue] as? NSNumber
247
+ gmtOffset = rawSettings [ CodingKeys . gmtOffset. rawValue] as? NSNumber
248
+ timezoneString = rawSettings [ CodingKeys . timezoneString. rawValue] as? String
249
+
250
+ defaultCategoryID = rawSettings [ CodingKeys . defaultCategory. rawValue] as? NSNumber ?? 1
251
+ let defaultPostFormatValue = rawSettings [ CodingKeys . defaultPostFormat. rawValue]
252
252
if let defaultPostFormatNumber = defaultPostFormatValue as? NSNumber , defaultPostFormatNumber == 0 ||
253
253
defaultPostFormatValue as? String == " 0 " {
254
254
defaultPostFormat = " standard "
255
255
} else {
256
- defaultPostFormat = rawSettings . string ( forKey : CodingKeys . defaultPostFormat . rawValue )
256
+ defaultPostFormat = defaultPostFormatValue as? String
257
257
}
258
- dateFormat = rawSettings. string ( forKey : CodingKeys . dateFormat. rawValue)
259
- timeFormat = rawSettings. string ( forKey : CodingKeys . timeFormat. rawValue)
260
- startOfWeek = rawSettings. string ( forKey : CodingKeys . startOfWeek. rawValue)
261
- postsPerPage = rawSettings. number ( forKey : CodingKeys . postsPerPage. rawValue)
262
-
263
- commentsAllowed = rawSettings. number ( forKey : CodingKeys . commentsAllowed. rawValue)
264
- commentsBlocklistKeys = rawSettings. string ( forKey : CodingKeys . commentsBlocklistKeys. rawValue)
265
- commentsCloseAutomatically = rawSettings. number ( forKey : CodingKeys . commentsCloseAutomatically. rawValue)
266
- commentsCloseAutomaticallyAfterDays = rawSettings. number ( forKey : CodingKeys . commentsCloseAutomaticallyAfterDays. rawValue)
267
- commentsFromKnownUsersAllowlisted = rawSettings. number ( forKey : CodingKeys . commentsKnownUsersAllowlist. rawValue)
268
- commentsMaximumLinks = rawSettings. number ( forKey : CodingKeys . commentsMaxLinks. rawValue)
269
- commentsModerationKeys = rawSettings. string ( forKey : CodingKeys . commentsModerationKeys. rawValue)
270
- commentsPagingEnabled = rawSettings. number ( forKey : CodingKeys . commentsPagingEnabled. rawValue)
271
- commentsPageSize = rawSettings. number ( forKey : CodingKeys . commentsPageSize. rawValue)
272
- commentsRequireManualModeration = rawSettings. number ( forKey : CodingKeys . commentsRequireModeration. rawValue)
273
- commentsRequireNameAndEmail = rawSettings. number ( forKey : CodingKeys . commentsRequireNameAndEmail. rawValue)
274
- commentsRequireRegistration = rawSettings. number ( forKey : CodingKeys . commentsRequireRegistration. rawValue)
275
- commentsSortOrder = rawSettings. string ( forKey : CodingKeys . commentsSortOrder. rawValue)
276
- commentsThreadingEnabled = rawSettings. number ( forKey : CodingKeys . commentsThreadingEnabled. rawValue)
277
- commentsThreadingDepth = rawSettings. number ( forKey : CodingKeys . commentsThreadingDepth. rawValue)
278
- pingbackOutboundEnabled = rawSettings. number ( forKey : CodingKeys . pingbackOutbound. rawValue)
279
- pingbackInboundEnabled = rawSettings. number ( forKey : CodingKeys . pingbackInbound. rawValue)
280
-
281
- relatedPostsAllowed = rawSettings. number ( forKey : CodingKeys . relatedPostsAllowed. rawValue)
282
- relatedPostsEnabled = rawSettings. number ( forKey : CodingKeys . relatedPostsEnabled. rawValue)
283
- relatedPostsShowHeadline = rawSettings. number ( forKey : CodingKeys . relatedPostsShowHeadline. rawValue)
284
- relatedPostsShowThumbnails = rawSettings. number ( forKey : CodingKeys . relatedPostsShowThumbnails. rawValue)
285
-
286
- ampSupported = rawSettings. number ( forKey : CodingKeys . ampSupported. rawValue)
287
- ampEnabled = rawSettings. number ( forKey : CodingKeys . ampEnabled. rawValue)
288
-
289
- sharingButtonStyle = rawSettings. string ( forKey : CodingKeys . sharingButtonStyle. rawValue)
290
- sharingLabel = rawSettings. string ( forKey : CodingKeys . sharingLabel. rawValue)
291
- sharingTwitterName = rawSettings. string ( forKey : CodingKeys . sharingTwitterName. rawValue)
292
- sharingCommentLikesEnabled = rawSettings. number ( forKey : CodingKeys . sharingCommentLikesEnabled. rawValue)
293
- sharingDisabledLikes = rawSettings. number ( forKey : CodingKeys . sharingDisabledLikes. rawValue)
294
- sharingDisabledReblogs = rawSettings. number ( forKey : CodingKeys . sharingDisabledReblogs. rawValue)
258
+ dateFormat = rawSettings [ CodingKeys . dateFormat. rawValue] as? String
259
+ timeFormat = rawSettings [ CodingKeys . timeFormat. rawValue] as? String
260
+ startOfWeek = rawSettings [ CodingKeys . startOfWeek. rawValue] as? String
261
+ postsPerPage = rawSettings [ CodingKeys . postsPerPage. rawValue] as? NSNumber
262
+
263
+ commentsAllowed = rawSettings [ CodingKeys . commentsAllowed. rawValue] as? NSNumber
264
+ commentsBlocklistKeys = rawSettings [ CodingKeys . commentsBlocklistKeys. rawValue] as? String
265
+ commentsCloseAutomatically = rawSettings [ CodingKeys . commentsCloseAutomatically. rawValue] as? NSNumber
266
+ commentsCloseAutomaticallyAfterDays = rawSettings [ CodingKeys . commentsCloseAutomaticallyAfterDays. rawValue] as? NSNumber
267
+ commentsFromKnownUsersAllowlisted = rawSettings [ CodingKeys . commentsKnownUsersAllowlist. rawValue] as? NSNumber
268
+ commentsMaximumLinks = rawSettings [ CodingKeys . commentsMaxLinks. rawValue] as? NSNumber
269
+ commentsModerationKeys = rawSettings [ CodingKeys . commentsModerationKeys. rawValue] as? String
270
+ commentsPagingEnabled = rawSettings [ CodingKeys . commentsPagingEnabled. rawValue] as? NSNumber
271
+ commentsPageSize = rawSettings [ CodingKeys . commentsPageSize. rawValue] as? NSNumber
272
+ commentsRequireManualModeration = rawSettings [ CodingKeys . commentsRequireModeration. rawValue] as? NSNumber
273
+ commentsRequireNameAndEmail = rawSettings [ CodingKeys . commentsRequireNameAndEmail. rawValue] as? NSNumber
274
+ commentsRequireRegistration = rawSettings [ CodingKeys . commentsRequireRegistration. rawValue] as? NSNumber
275
+ commentsSortOrder = rawSettings [ CodingKeys . commentsSortOrder. rawValue] as? String
276
+ commentsThreadingEnabled = rawSettings [ CodingKeys . commentsThreadingEnabled. rawValue] as? NSNumber
277
+ commentsThreadingDepth = rawSettings [ CodingKeys . commentsThreadingDepth. rawValue] as? NSNumber
278
+ pingbackOutboundEnabled = rawSettings [ CodingKeys . pingbackOutbound. rawValue] as? NSNumber
279
+ pingbackInboundEnabled = rawSettings [ CodingKeys . pingbackInbound. rawValue] as? NSNumber
280
+
281
+ relatedPostsAllowed = rawSettings [ CodingKeys . relatedPostsAllowed. rawValue] as? NSNumber
282
+ relatedPostsEnabled = rawSettings [ CodingKeys . relatedPostsEnabled. rawValue] as? NSNumber
283
+ relatedPostsShowHeadline = rawSettings [ CodingKeys . relatedPostsShowHeadline. rawValue] as? NSNumber
284
+ relatedPostsShowThumbnails = rawSettings [ CodingKeys . relatedPostsShowThumbnails. rawValue] as? NSNumber
285
+
286
+ ampSupported = rawSettings [ CodingKeys . ampSupported. rawValue] as? NSNumber
287
+ ampEnabled = rawSettings [ CodingKeys . ampEnabled. rawValue] as? NSNumber
288
+
289
+ sharingButtonStyle = rawSettings [ CodingKeys . sharingButtonStyle. rawValue] as? String
290
+ sharingLabel = rawSettings [ CodingKeys . sharingLabel. rawValue] as? String
291
+ sharingTwitterName = rawSettings [ CodingKeys . sharingTwitterName. rawValue] as? String
292
+ sharingCommentLikesEnabled = rawSettings [ CodingKeys . sharingCommentLikesEnabled. rawValue] as? NSNumber
293
+ sharingDisabledLikes = rawSettings [ CodingKeys . sharingDisabledLikes. rawValue] as? NSNumber
294
+ sharingDisabledReblogs = rawSettings [ CodingKeys . sharingDisabledReblogs. rawValue] as? NSNumber
295
295
}
296
296
297
297
@objc
298
- public var dictionaryRepresentation : NSDictionary {
299
- let parameters = NSMutableDictionary ( )
298
+ public var dictionaryRepresentation : [ String : Any ] {
299
+ var parameters : [ String : Any ] = [ : ]
300
300
301
301
// name and tagline/description use different keys...
302
- name . ifSome { parameters. setValue ( $0 , forKey : " blogname " ) }
303
- tagline . ifSome { parameters. setValue ( $0 , forKey : " blogdescription " ) }
304
-
305
- privacy . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . privacy. rawValue) }
306
- languageID . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . languageID. rawValue) }
307
- iconMediaID . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . iconMediaID. rawValue) }
308
- gmtOffset . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . gmtOffset. rawValue) }
309
- timezoneString . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . timezoneString. rawValue) }
310
-
311
- defaultCategoryID . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . defaultCategory. rawValue) }
312
- defaultPostFormat . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . defaultPostFormat. rawValue) }
313
- dateFormat . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . dateFormat. rawValue) }
314
- timeFormat . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . timeFormat. rawValue) }
315
- startOfWeek . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . startOfWeek. rawValue) }
316
- postsPerPage . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . postsPerPage. rawValue) }
317
-
318
- commentsAllowed . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsAllowed. rawValue) }
319
- commentsBlocklistKeys . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsBlocklistKeys. rawValue) }
320
- commentsCloseAutomatically . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsCloseAutomatically. rawValue) }
321
- commentsCloseAutomaticallyAfterDays . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsCloseAutomaticallyAfterDays. rawValue) }
322
- commentsFromKnownUsersAllowlisted . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsKnownUsersAllowlist. rawValue) }
323
- commentsMaximumLinks . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsMaxLinks. rawValue) }
324
- commentsModerationKeys . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsModerationKeys. rawValue) }
325
- commentsPagingEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsPagingEnabled. rawValue) }
326
- commentsPageSize . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsPageSize. rawValue) }
327
- commentsRequireManualModeration . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsRequireModeration. rawValue) }
328
- commentsRequireNameAndEmail . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsRequireNameAndEmail. rawValue) }
329
- commentsRequireRegistration . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsRequireRegistration. rawValue) }
330
- commentsSortOrder . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsSortOrder. rawValue) }
331
- commentsThreadingEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsThreadingEnabled. rawValue) }
332
- commentsThreadingDepth . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . commentsThreadingDepth. rawValue) }
333
-
334
- pingbackOutboundEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . pingbackOutbound. rawValue) }
335
- pingbackInboundEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . pingbackInbound. rawValue) }
302
+ parameters [ " blogname " ] = name
303
+ parameters [ " blogdescription " ] = tagline
304
+
305
+ parameters [ CodingKeys . privacy. rawValue] = privacy
306
+ parameters [ CodingKeys . languageID. rawValue] = languageID
307
+ parameters [ CodingKeys . iconMediaID. rawValue] = iconMediaID
308
+ parameters [ CodingKeys . gmtOffset. rawValue] = gmtOffset
309
+ parameters [ CodingKeys . timezoneString. rawValue] = timezoneString
310
+
311
+ parameters [ CodingKeys . defaultCategory. rawValue] = defaultCategoryID
312
+ parameters [ CodingKeys . defaultPostFormat. rawValue] = defaultPostFormat
313
+ parameters [ CodingKeys . dateFormat. rawValue] = dateFormat
314
+ parameters [ CodingKeys . timeFormat. rawValue] = timeFormat
315
+ parameters [ CodingKeys . startOfWeek. rawValue] = startOfWeek
316
+ parameters [ CodingKeys . postsPerPage. rawValue] = postsPerPage
317
+
318
+ parameters [ CodingKeys . commentsAllowed. rawValue] = commentsAllowed
319
+ parameters [ CodingKeys . commentsBlocklistKeys. rawValue] = commentsBlocklistKeys
320
+ parameters [ CodingKeys . commentsCloseAutomatically. rawValue] = commentsCloseAutomatically
321
+ parameters [ CodingKeys . commentsCloseAutomaticallyAfterDays. rawValue] = commentsCloseAutomaticallyAfterDays
322
+ parameters [ CodingKeys . commentsKnownUsersAllowlist. rawValue] = commentsFromKnownUsersAllowlisted
323
+ parameters [ CodingKeys . commentsMaxLinks. rawValue] = commentsMaximumLinks
324
+ parameters [ CodingKeys . commentsModerationKeys. rawValue] = commentsModerationKeys
325
+ parameters [ CodingKeys . commentsPagingEnabled. rawValue] = commentsPagingEnabled
326
+ parameters [ CodingKeys . commentsPageSize. rawValue] = commentsPageSize
327
+ parameters [ CodingKeys . commentsRequireModeration. rawValue] = commentsRequireManualModeration
328
+ parameters [ CodingKeys . commentsRequireNameAndEmail. rawValue] = commentsRequireNameAndEmail
329
+ parameters [ CodingKeys . commentsRequireRegistration. rawValue] = commentsRequireRegistration
330
+ parameters [ CodingKeys . commentsSortOrder. rawValue] = commentsSortOrder
331
+ parameters [ CodingKeys . commentsThreadingEnabled. rawValue] = commentsThreadingEnabled
332
+ parameters [ CodingKeys . commentsThreadingDepth. rawValue] = commentsThreadingDepth
333
+
334
+ parameters [ CodingKeys . pingbackOutbound. rawValue] = pingbackOutboundEnabled
335
+ parameters [ CodingKeys . pingbackInbound. rawValue] = pingbackInboundEnabled
336
336
337
337
// Note: releatedPostsAllowed was not set in the Objective-C implementation.
338
338
// There was no comment about it, so I assumed it was simply something that was never noticed.
339
- relatedPostsAllowed . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . relatedPostsAllowed. rawValue) }
340
- relatedPostsEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . relatedPostsEnabled. rawValue) }
341
- relatedPostsShowHeadline . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . relatedPostsShowHeadline. rawValue) }
342
- relatedPostsShowThumbnails . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . relatedPostsShowThumbnails. rawValue) }
339
+ parameters [ CodingKeys . relatedPostsAllowed. rawValue] = relatedPostsAllowed
340
+ parameters [ CodingKeys . relatedPostsEnabled. rawValue] = relatedPostsEnabled
341
+ parameters [ CodingKeys . relatedPostsShowHeadline. rawValue] = relatedPostsShowHeadline
342
+ parameters [ CodingKeys . relatedPostsShowThumbnails. rawValue] = relatedPostsShowThumbnails
343
343
344
344
// Note: ampSupported was not set in the Objective-C implementation.
345
345
// There was no comment about it, so I assumed it was simply something that was never noticed.
346
- ampSupported . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . ampSupported. rawValue) }
347
- ampEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . ampEnabled. rawValue) }
346
+ parameters [ CodingKeys . ampSupported. rawValue] = ampSupported
347
+ parameters [ CodingKeys . ampEnabled. rawValue] = ampEnabled
348
348
349
- sharingButtonStyle . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingButtonStyle. rawValue) }
350
- sharingLabel . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingLabel. rawValue) }
351
- sharingTwitterName . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingTwitterName. rawValue) }
352
- sharingCommentLikesEnabled . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingCommentLikesEnabled. rawValue) }
353
- sharingDisabledLikes . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingDisabledLikes. rawValue) }
354
- sharingDisabledReblogs . ifSome { parameters. setValue ( $0 , forKey : CodingKeys . sharingDisabledReblogs. rawValue) }
349
+ parameters [ CodingKeys . sharingButtonStyle. rawValue] = sharingButtonStyle
350
+ parameters [ CodingKeys . sharingLabel. rawValue] = sharingLabel
351
+ parameters [ CodingKeys . sharingTwitterName. rawValue] = sharingTwitterName
352
+ parameters [ CodingKeys . sharingCommentLikesEnabled. rawValue] = sharingCommentLikesEnabled
353
+ parameters [ CodingKeys . sharingDisabledLikes. rawValue] = sharingDisabledLikes
354
+ parameters [ CodingKeys . sharingDisabledReblogs. rawValue] = sharingDisabledReblogs
355
355
356
356
return parameters
357
357
}
@@ -374,12 +374,3 @@ public class RemoteBlogSettings: NSObject {
374
374
private static let AscendingStringValue = " asc "
375
375
private static let DescendingStringValue = " desc "
376
376
}
377
-
378
- private extension Optional {
379
-
380
- func ifSome( _ body: ( Wrapped ) -> Void ) {
381
- guard case . some( let value) = self else { return }
382
-
383
- body ( value)
384
- }
385
- }
0 commit comments