Я хочу использовать RestKit для приложения, которое должно работать как во время работы, так и в автономном режиме.Онлайн и автономная поддержка приложений RestKit iOS
Возможно, я не понимаю, как работает RestKit, но я думал, что это было (справедливо) легко реализовать.
В тестовой царапанию IOS приложение, которое я установить вещи следующим образом:
// setup the client
NSString* URL = @"http://10.211.55.5:3000/api";
RKClient* client = [RKClient clientWithBaseURL:URL];
client.username = @"[email protected]";
client.password = @"password";
// setup caching
client.cachePolicy = RKRequestCachePolicyLoadIfOffline | RKRequestCachePolicyLoadOnError | RKRequestCachePolicyTimeout;
client.requestCache.storagePolicy = RKRequestCacheStoragePolicyPermanently;
// setup managed object store
RKObjectManager* objectManager = [RKObjectManager objectManagerWithBaseURL:URL];
RKManagedObjectStore* objectStore = [RKManagedObjectStore objectStoreWithStoreFilename:@"RestKitCoreDataTest.sqlite"];
// connect my cache implementation
MyCache* cache = [[MyCache alloc] init];
objectStore.managedObjectCache = cache;
objectManager.objectStore = objectStore;
// setup mapping
RKManagedObjectMapping* userMapping = [RKManagedObjectMapping mappingForClass:[User class]];
[userMapping mapKeyPath:@"id" toAttribute:@"identifier"];
[userMapping mapKeyPath:@"email" toAttribute:@"email"];
[userMapping mapKeyPath:@"firstname" toAttribute:@"firstname"];
[userMapping mapKeyPath:@"surname" toAttribute:@"surname"];
userMapping.primaryKeyAttribute = @"identifier";
[objectManager.mappingProvider setMapping:userMapping forKeyPath:@""];
// setup routes
RKObjectRouter* router = [objectManager router];
[router routeClass:[User class] toResourcePath:@"https://stackoverflow.com/users/:identifier"];
Объект пользователя осуществляется в соответствии с требованиями для поддержки CoreData:
@interface User : NSManagedObject
@property (nonatomic, retain) NSNumber * identifier;
@property (nonatomic, retain) NSString * email;
@property (nonatomic, retain) NSString * firstname;
@property (nonatomic, retain) NSString * surname;
@end
@implementation User
@dynamic identifier;
@dynamic email;
@dynamic firstname;
@dynamic surname;
@end
Вот MyCache. Обратите внимание, что я не удосуживаюсь проверить resourcePath
, так как это просто для того, чтобы попробовать что-то, и у меня есть один путь.
@implementation MyCache
- (NSArray*)fetchRequestsForResourcePath:(NSString*)resourcePath
{
NSFetchRequest* fetchRequest = [User fetchRequest];
return [NSArray arrayWithObject:fetchRequest];
}
-(BOOL)shouldDeleteOrphanedObject:(NSManagedObject *)managedObject
{
return true;
}
@end
Я тогда сделать вызов на сервер, чтобы получить пользователь с идентификатором 123, на пути "/ API/пользователей/123":
User* user = [User object];
user.identifier = [NSNumber numberWithInt:123];
RKObjectManager* manager = [RKObjectManager sharedManager];
[manager getObject:user delegate:self];
Это прекрасно работает. Но, когда я отключу Wi-Fi на своем Mac, приведенный выше код не извлекает пользователя из базы данных sqlite.
я получаю следующее сообщение об ошибке, а не в objectLoader:didFailWithError
делегата:
2012-03-01 11:44:09.402 RestKitCoreDataTest[1989:fb03] error: Error Domain=NSURLErrorDomain Code=-1001 "The request timed out." UserInfo=0x6b89aa0 {NSErrorFailingURLStringKey=http://10.211.55.5:3000/api/users/123, NSErrorFailingURLKey=http://10.211.55.5:3000/api/users/123, NSLocalizedDescription=The request timed out., NSUnderlyingError=0x6b81ac0 "The request timed out."}
Я думал, что в силу указания, что кэш должен быть использован, когда есть тайм-аут, с: «RKRequestCachePolicyTimeout», я бы ожидал пользователь должен быть извлечен из локального кеша.
Кэш содержит запись пользователя с идентификатором 123 - в таблице ZUSER с 123 в столбце ZIDENTIFIER.
Есть ли какой-то шаг, который мне не хватает, чтобы заставить это работать? Может быть, еще один метод делегирования, который необходимо обработать , или вызывается, когда кэш попадает после таймаута ? Или я пытаюсь сделать что-то, что не обязательно что-то, что вы получите «из коробки» с помощью RestKit?
Cheers.
Привет , Я пытаюсь сделать то же самое с RestKit 0.20.1 - любое обновление по этому вопросу? Вы получили эту работу? Ответ, который вы проверили, кажется, не отвечает на ваш вопрос ... Спасибо! – Diego
Я проверил ответ ниже как правильный, потому что я взял предложение Джулиана использовать класс достижимости, чтобы проверить, был ли я онлайн или офлайн. Позже я закончил использование RestKit для онлайновых сообщений, а CoreData - для автономного хранения. – dbarros
ОК спасибо! Я думаю, что я попытаюсь централизовать это в appdelegate - хотя для этого мне кажется, что лучше создать ядро HTTP-операции, которое я тогда анализирую каждый раз, когда требуется синхронизация (возможно, периодически). – Diego