Files
RestKit/Code/ObjectMapping/RKRelationshipMapping.m
Blake Watters 4c39918fdb Implement support for flexible metdata mapping. closes #582, #688
* Metadata mapping is implemented via an `NSProxy` object that stands in for the `sourceObject` of each `RKMappingOperation`
* Key paths that are prefixed with `@metadata.` are mapped against the `metadata` dictionary of the operation, else they hit the `sourceObject`.
* Metadata is implemented by merging a dictionary of data in from `RKObjectRequestOperation`, through to `RKResponseMapperOperation`, into `RKMapperOperation`, and all the way down into the `RKMappingOperation`, where it is available to each object. By convention, metdata is namespaced into subdictionaries.
2013-01-24 16:31:19 -05:00

68 lines
2.1 KiB
Objective-C

//
// RKRelationshipMapping.m
// RestKit
//
// Created by Blake Watters on 5/4/11.
// Copyright (c) 2009-2012 RestKit. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#import "RKRelationshipMapping.h"
#import "RKMapping.h"
@interface RKRelationshipMapping ()
@property (nonatomic, copy, readwrite) NSString *sourceKeyPath;
@property (nonatomic, copy, readwrite) NSString *destinationKeyPath;
@property (nonatomic, strong, readwrite) RKMapping *mapping;
@end
@implementation RKRelationshipMapping
+ (instancetype)relationshipMappingFromKeyPath:(NSString *)sourceKeyPath toKeyPath:(NSString *)destinationKeyPath withMapping:(RKMapping *)mapping
{
RKRelationshipMapping *relationshipMapping = [self new];
relationshipMapping.sourceKeyPath = sourceKeyPath;
relationshipMapping.destinationKeyPath = destinationKeyPath;
relationshipMapping.mapping = mapping;
return relationshipMapping;
}
- (id)init
{
self = [super init];
if (self) {
self.assignmentPolicy = RKSetAssignmentPolicy;
}
return self;
}
- (id)copyWithZone:(NSZone *)zone
{
RKRelationshipMapping *copy = [super copyWithZone:zone];
copy.mapping = self.mapping;
copy.assignmentPolicy = self.assignmentPolicy;
return copy;
}
- (BOOL)isEqualToMapping:(RKRelationshipMapping *)otherMapping
{
if (! [otherMapping isMemberOfClass:[RKRelationshipMapping class]]) return NO;
if (! [super isEqualToMapping:otherMapping]) return NO;
if (self.mapping == nil && otherMapping.mapping == nil) return YES;
return [self.mapping isEqualToMapping:otherMapping.mapping];
}
@end