Creative Commons Attribution- NonCommercial-ShareAlike 2.5 License Sakai Programmer's Café Sakai development and app/tool tips Aaron Zeckoski
2 Where to get information and development tips URL:
3 Sakai foundation website The main website for the Sakai foundation and Sakai project is: – Find information about upcoming Sakai conferences and other Sakai related news Find out what schools are using Sakai Figure out why it is called Sakai
4 Programmers Cafe The best source of information for developers wanting to work in Sakai is the programmers café website – Info you can find there: –Tutorials –Tips –Documentation –Sample code
5 Sakai Collab The Sakai Collab server runs a current version of Sakai and provides a place for the community to collaborate using Sakai, demo Sakai, or try out toolsSakai Collab serverSakai The collab server is also used to manage all the Sakai mailing lists and to manage some documentation –
6 sakai-dev list The sakai-dev list is a great place to ask development questions How sign up for sakai-dev list 1.Create account on Sakai Collab and login – 2.Click Membership link on left 3.Click Joinable Sites link at top 4.Click Join link for DG: Development Send to the list at:
7 Sakai Confluence and JIRA Sakai uses Confluence (an enterprise Wiki) to document projects and Sakai related activityConfluence – Sakai uses JIRA (bug tracker) for issue and bug tracking related to Sakai developmentJIRA –
8 Sakai source code The Sakai source code is stored in a Subversion repository Subversion –Main Sakai source Includes the entire Sakai source plus provisional tools –Sakai Contrib (contribution) Includes contributed source for various Sakai projects
9 Eclipse The vast majority of Sakai developers use Eclipse for development Eclipse –You can use other development environments but Eclipse has some advantages: Supported (eclipse files in the Sakai code base) Well understood (support docs and knowledge) Extended tools (appbuilder plugin) Can get commercial support if desired: – URL:
10 Development Environment Getting a good development environment setup is critical to working with Sakai code Complete step by step instructions are available in the programmers café: –Development Setup WalkthroughDevelopment Setup Walkthrough Include various tips that will make developing in Sakai easier
11 Sakai API Javadocs The Sakai API Javadocs are available with the release documents here:Javadocs – The link to the Javadocs is a little over halfway down (link named “JavaDocs”) –Here is the link for the current release (2.3.0) Javadocs for the trunk are available –
12 More Sakai javadocs You can build javadocs for the Sakai source code you have checked out Run the following command from the root directory of your copy of the Sakai source –maven sakai:javadoc The javadocs will be generated here – /target/sakai-javadoc.zip URL:
13 Naming Best Practices and Tips
14 Sakai tool environment Many tools exist in a typical Sakai installation –As a developer, you have to be careful when working in a large scale environment The primary issue is with naming collisions –Some names must be unique in the Sakai instance (not used by any other installed tools) Tools have many interconnections and use a custom request cycle so some programming practices must be followed
15 Namespace collisions Most namespace collisions will cause an error to occur on tomcat startup Typically you will see that part of the spring tree died and therefore all spring beans are destroyed Sometimes Sakai will still load but the offending tool will not Tip: Watch tomcat logs when starting up new tools URL:
16 Sakai tool xml file naming The tool id (e.g. sakai.tasklist) in the tool xml file must be unique –Typical id is sakai.toolname –Tool xml file located in tool/src/webapp/tools/ Typical filename is sakai.toolname.xml <tool id="sakai.tasklist" title="Programmer's Cafe - Task List" description="Programmer's Cafe - Task List">
17 Sakai project.xml naming The id (e.g. sakai-tasklist-tool) in each project.xml file must be unique –Typical id is sakai-toolname-location –Maven project.xml files are located throughout a typical Sakai app 3../../master/project.xml Programmer's Cafe - Task List sakaiproject sakai-tasklist-tool ${sakai.version}...
18 Spring bean naming The id ( e.g. org.sakaiproject.logic.CrudPlusLogic ) of each bean in components.xml must be unique –Convention for the id is to use the fully qualified classpath of the interface for the class –component.xml must be located in impl/pack/src/webapp/WEB-INF/ <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" " <bean id="org.sakaiproject.crudplus.logic.CrudPlusLogic" class="org.sakaiproject.crudplus.logic.impl.CrudPlusLogicImpl" init-method="init">
19 Database table naming Database table names have to be unique since Sakai shares a common schema (or database) Convention is to prefix the table name with the tool name (e.g. TOOLNAME_TABLE) –Good names: SAM_ANSWER, EVAL_ANSWER, GB_GRADES –Bad names: ANSWER, GRADE, CONFIG
20 Hibernate HBM files All Hibernate HBM files have to have unique names since Sakai uses one common Hibernate SessionFactory Convention is to prefix the hbm filename with the tool name (e.g. ToolnameItem.hbm.xml) –Good names: EvalAnswer.hbm.xml, TasklistTask.hbm.xml –Bad names: Answer.hbm.xml, Task.hbm.xml, Item.hbm.xml
21 Hibernate Persistent Classnames All Hibernate persistent classes must have unique classnames (this does not include the fully qualified classpath) Convention is to prefix the class name with the tool name (e.g. ToolnameItem.java) –Good: EvalAnswer.java, TasklistTask.java –Bad: Answer.java, Task.java
22 web.xml servlet name The servlet-name in the web.xml file must match the tool id from the tool xml file –web.xml is located in tool/src/webapp/WEB-INF –If this does not match you will get an uninformative NPE (Null Pointer Exception) in the tomcat log and the tool will fail to load sakai.tasklist org.sakaiproject.tool.tasklist.TasklistTool 1
23 Questions?