Use key().name() instead of link_id
This is now possible because key_name is constructed purely from the
key fields of an entity. It is not sufficient to use just link_id,
that works only for single-scoped entities (e.g., those that either
do not have a scope, or that have a scope which itself does not have
a scope). It would break if there was an entity that has a scoped
scope (it would only include the scope's link_id in the url, which
made it impossible to look up the scope as we missed the link_id of
the scope's scope).
Patch by: Sverre Rabbelier
#!/usr/bin/python2.5## Copyright 2008 the Melange authors.## 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."""Group (Model) query functions."""__authors__ = [ '"Sverre Rabbelier" <sverre@rabbelier.nl>', ]from soc.logic.models import baseimport soc.models.groupclass Logic(base.Logic): """Logic methods for the Group model. """ def __init__(self, model=soc.models.group.Group, base_model=None, scope_logic=None): """Defines the name, key_name and model for this entity. """ super(Logic, self).__init__(model, base_model=base_model, scope_logic=scope_logic) def getKeyValues(self, entity): """Extracts the key values from entity and returns them. The default implementation for Groups assumes that the Group is site-wide and thus has no scope. Such Groups include Sponsors and Clubs. Any Group that exists per-Program or per-Year will need to override this method. Args: entity: the entity from which to extract the key values """ return [entity.link_id] def getKeyValuesFromFields(self, fields): """Extracts the key values from a dict and returns them. The default implementation for Groups assumes that the Group is site-wide and thus has no scope. Such Groups include Sponsors and Clubs. Any Group that exists per-Program or per-Year will need to override this method. Args: fields: the dict from which to extract the key values """ return [fields['link_id']] def getKeyFieldNames(self): """Returns an array with the names of the Key Fields. The default implementation for Groups assumes that the Group is site-wide and thus has no scope. Such Groups include Sponsors and Clubs. Any Group that exists per-Program or per-Year will need to override this method. """ return ['link_id'] def isDeletable(self, entity): """Returns whether the specified Group entity can be deleted. Generically, a Group can always be deleted. Subclasses of group.Logic should add their own deletion prerequisites. Args: entity: an existing Group entity in the Datastore """ return Truelogic = Logic()