2012-03-11 7 views
4

Я скопировал данные пространства имен из x1 в x2 с использованием удаленных api и низкоуровневых хранилищ данных api.Приложение x1 не может получить доступ к данным приложения x2

я доступ приложения x2, чтобы получить следующее сообщение об ошибке для некоторых данных

 
java.lang.IllegalArgumentException: app x1 cannot access app x2's data 
    at com.google.appengine.api.datastore.DatastoreApiHelper.translateError(DatastoreApiHelper.java:36) 
    at com.google.appengine.api.datastore.DatastoreApiHelper$1.convertException(DatastoreApiHelper.java:76) 
    at com.google.appengine.api.utils.FutureWrapper.get(FutureWrapper.java:106) 
    at com.google.appengine.api.datastore.FutureHelper$CumulativeAggregateFuture.get(FutureHelper.java:145) 

ответ

0

Вам необходимо исправить ключи, так что они имеют право идентификатора приложения в них.

Вот немного Python я использую:

key = db.Key(k) 
    if key.app() == appname: 
    return db.get(key) 
    logging.info("Fixing up key from old app %s (%s=%s)" % (key.app() , key_attr , k)) 
    fixed_key = db.Key.from_path(*key.to_path()) 
1

Как сказано в этом сообщении: Migration to HRD - How to convert string-encoded keys to new application все ключи сущности содержат ссылку на приложение-идентификатор. Если вы используете ключи, закодированные как String, эта ссылка не будет обновляться при копировании данных в новое приложение. Но вы можете сделать это сами.

Просто запустите запрос в новой среде, чтобы обновить каждый ключ, чтобы указать на новый идентификатор приложения. В этом примере я полагаю, что каждый объект реализует этот интерфейс:

Interface Entity{ 
    public Key getKey(); 
    public void setKey(Key key); 
} 

теперь я могу использовать метод как это:

//... 

List<Entity> entities = //... your query 

for (Entity entity : entities){ 
    entity.setKey(generateNewKey(entity.getKey()); 
} 

//... 

//Method written by Nikolay Ivanov in the other post, that recursive generate a new key respecting to parents 

private Key generateNewKey(Key key) { 
    Key parentKey = key.getParent(); 
    if(parentKey == null){ 
     return KeyFactory.createKey(key.getKind(), key.getId()); 
    }else{   
     Key newParentKey = generateKey(parentKey);   
     return KeyFactory.createKey(newParentKey, key.getKind(), key.getId()); 
    } 
} 
Смежные вопросы