123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- ##@defgroup lodel2_leapi LeAPI
- #@brief Lodel2 Editorial API
- #
- #Provide access to datas via objects as defined in the Editorial Model
-
- ##@package lodel.leapi
- #@brief Lodel2 Editorial API
- #
- # Defines an API to access to objects as described by
- #@ref lodel.editorial_model "Editorial Model"
-
- ##@page lodel2_leapi_page LeAPI
- #@ingroup lodel2_leapi
- #
- # @section lodel2_leapi_base LeAPI (Lodel Editorial API)
- #
- # LeAPI is an API that provide access to datas as defined in an
- #@ref lodel2_em "Editorial Model".
- #
- #@subsection lodel2_leapi_gen LeAPI dynamic code & LeFactory
- #
- #LeAPI python code is programmaticaly generated by
- #@ref lodel.leapi.lefactory "LeFactory". LeFactory generates
- #@ref lodel.leapi.leobject.LeObject "LeObject" child classes.
- #
- #@par Example
- #<pre>
- #
- # from lodel.leapi.leobject import LeObject
- # from lodel.leapi.datahandlers.base_classes import DataField
- # from lodel.plugin.hooks import LodelHook
- #
- # class Abstract_Object(LeObject):
- # _abstract = True
- # _fields = None
- # _uid = []
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class User(LeObject):
- # _abstract = False
- # _fields = None
- # _uid = ['id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class Object(Abstract_Object):
- # _abstract = True
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class Entry(Object):
- # _abstract = True
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class Entitie(Object):
- # _abstract = True
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class Person(Object):
- # _abstract = False
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- # class Text(Entitie):
- # _abstract = True
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- #
- # class Publication(Entitie):
- # _abstract = False
- # _fields = None
- # _uid = ['lodel_id']
- # _ro_datasource = None
- # _rw_datasource = None
- # _datasource_name = 'default'
- # _child_classes = None
- #
- # Abstract_Object._set__fields({})
- # Abstract_Object._child_classes = (Section, Text, Object, Entry, Collection, Text_Person, Entitie, Indextheme, Person, Indexabs, Publication, Subsection,)
- # User._set__fields({
- # 'firstname': DataField.from_name('varchar')(**{ 'internal': False }),
- # 'lastname': DataField.from_name('varchar')(**{ 'internal': False }),
- # 'classname': DataField.from_name('LeobjectSubclassIdentifier')(**{ 'internal': True }),
- # 'login': DataField.from_name('varchar')(**{ 'internal': True, 'uniq': True }),
- # 'id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'password': DataField.from_name('password')(**{ 'internal': False })})
- # User._child_classes = tuple()
- # Object._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Object._child_classes = (Section, Text, Entry, Collection, Text_Person, Entitie, Indextheme, Person, Indexabs, Publication, Subsection,)
- # Entry._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Entry._child_classes = tuple()
- # Entitie._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Entitie._child_classes = (Section, Text, Text_Person, Collection, Publication, Subsection,)
- # Person._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'firstname': DataField.from_name('varchar')(**{ }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'linked_texts': DataField.from_name('list')(**{ 'nullable': True, 'default': None, 'allowed_classes': [Text], 'back_reference': (Text, 'linked_persons') }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'lastname': DataField.from_name('varchar')(**{ }),
- # 'fullname': DataField.from_name('Concat')(**{ 'field_list': ['firstname', 'lastname'], 'immutable': True }),
- # 'classname': DataField.from_name('LeobjectSubclassIdentifier')(**{ 'internal': True }),
- # 'alias': DataField.from_name('set')(**{ 'nullable': True, 'default': None, 'allowed_classes': [Person] }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Person._child_classes = tuple()
- # Text._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'subtitle': DataField.from_name('varchar')(**{ 'nullable': True, 'default': None }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'linked_persons': DataField.from_name('list')(**{ 'nullable': True, 'default': None, 'allowed_classes': [Person], 'back_reference': (Person, 'linked_texts') }),
- # 'indexes': DataField.from_name('list')(**{ 'nullable': True, 'default': None, 'allowed_classes': [Indexabs], 'back_reference': (Indexabs, 'texts') }),
- # 'title': DataField.from_name('varchar')(**{ 'nullable': True }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Text._child_classes = (Section, Subsection,)
- # Publication._set__fields({
- # 'date_update': DataField.from_name('datetime')(**{ 'now_on_update': True, 'internal': True }),
- # 'classname': DataField.from_name('LeobjectSubclassIdentifier')(**{ 'internal': True }),
- # 'lodel_id': DataField.from_name('uniqid')(**{ 'internal': True }),
- # 'collection': DataField.from_name('link')(**{ 'back_reference': (Collection, 'publications') }),
- # 'help_text': DataField.from_name('text')(**{ 'internal': True }),
- # 'date_create': DataField.from_name('datetime')(**{ 'internal': True, 'now_on_create': True })})
- # Publication._child_classes = tuple()
- #
- # #List of dynamically generated classes
- # dynclasses = [Abstract_Object, User, Object, Entry, Entitie, Person, Indexabs, Text, Publication, Collection, Indextheme, Text_Person, Section, Subsection]
- # #Dict of dynamically generated classes indexed by name
- # dynclasses_dict = {'Abstract_Object': Abstract_Object, 'User': User, 'Object': Object, 'Entry': Entry, 'Entitie': Entitie, 'Person': Person, 'Indexabs': Indexabs, 'Text': Text, 'Publication': Publication, 'Collection': Collection, 'Indextheme': Indextheme, 'Text_Person': Text_Person, 'Section': Section, 'Subsection': Subsection}
- #
- #
- # ##@brief Return a dynamically generated class given it's name
- # #@param name str : The dynamic class name
- # #@return False or a child class of LeObject
- # def name2class(name):
- # if name not in dynclasses_dict:
- # return False
- # return dynclasses_dict[name]
- #
- #
- # ##@brief Return a dynamically generated class given it's name
- # #@note Case insensitive version of name2class
- # #@param name str
- # #@retrun False or a child class of LeObject
- # def lowername2class(name):
- # name = name.lower()
- # new_dict = {k.lower():v for k,v in dynclasses_dict.items()}
- # if name not in new_dict:
- # return False
- # return new_dict[name]
- #
- #
- # ##@brief Trigger dynclasses datasources initialisation
- # @LodelHook("lodel2_plugins_loaded")
- # def lodel2_dyncode_datasources_init(self, caller, payload):
- # for cls in dynclasses:
- # cls._init_datasources()
- # from lodel.plugin.hooks import LodelHook
- # LodelHook.call_hook("lodel2_dyncode_loaded", __name__, dynclasses)
- #
- #
- #
- #</pre>
- #
|