Your SlideShare is downloading. ×
Developing a Google Wave Extension
Upcoming SlideShare
Loading in...5

Thanks for flagging this SlideShare!

Oops! An error has occurred.

Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

Developing a Google Wave Extension


Published on

Learn how to build a Wave robot from the ground up using Google App Engine, Java, and Eclipse. We walk through setting up your development environment, writing the extension, and deploying, …

Learn how to build a Wave robot from the ground up using Google App Engine, Java, and Eclipse. We walk through setting up your development environment, writing the extension, and deploying, troubleshooting, and packaging it. These slides are from a talk given at Silicon Valley Code Camp 2009.

Published in: Technology
  • Be the first to comment

No Downloads
Total Views
On Slideshare
From Embeds
Number of Embeds
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

No notes for slide


  • 1. Austin Chau and Brian Kennish Google Developer Relations Developing a Google Wave Extension Silicon Valley Code Camp 2009
  • 2. Topics Writing and Deploying Packaging Questions Introduction to Wave Setting Up Your Development Environment Troubleshooting
  • 3. Introduction to Wave
  • 4. Using Wave What would email look like if it was invented today, rather than 40 years ago? Wave combines email and many communication technologies since — instant messaging, bulletin boards, wikis, real-time document collaboration — in one place. It's also a  protocol  and  platform .
  • 5. Developing with Wave: The Protocol We want lots of Waves besides Google Wave, so we're drafting the protocol specification in public and open sourcing our client and server code.
  • 6. Developing with Wave: The Platform
    • Embeds bring Wave to the world.
    • Extensions  bring the world to Wave:
      • Gadgets  let you safely run untrusted code in a wave.
      • Robots are automated wave participants.
  • 7. Developing with Wave: Terminology wave  — A conversation and shared document in Wave. wavelet  — The unit of access control in a wave. blip  — A message in a wavelet.
  • 8. Setting Up Your Development Environment
  • 9. Tools Robots are currently required to use Google App Engine . You can sign up for an account at . Java robots are also required to use the Wave Java SDK (Python robots are possible too). You can download the latest JARs from wave-robot-java-client/downloads/list . Using Eclipse isn't required, but we recommend doing so because the Google Plugin makes it easy to create and deploy App Engine applications. You can install the plugin via .
  • 10. Writing and Deploying
  • 11. The Robot WAR File /war /WEB-INF/web.xml binds the robot servlets to the Wave endpoints . /war /WEB-INF/appengine-web.xml specifies the App Engine identifiers . /war /_wave/capabilities.xml subscribes the robot to Wave events .
  • 12. Sample Code: Hello-Worldy [email_address] Does "hello world"-type stuff. Appends text, echoes submitted blips, and implements form UI. browse/trunk/samples/extensions/robots/java/hello-worldy/
  • 13. Sample Code: Stocky [email_address] Replaces stock symbols with real-time quotes. Incorporates third-party data into Wave. browse/trunk/samples/extensions/robots/java/stocky/
  • 14. Sample Code: Embeddy [email_address] Generates code to embed a wave in your webpage. Features all three of the current Wave APIs and two-way robot- to-gadget communication. browse/trunk/samples/extensions/robots/java/embeddy
  • 15. Troubleshooting
  • 16. Tips Check your App Engine logs for errors. Go to http:// app-id   to see if your capabilities file is live. Make sure you updated your capabilities version string after adding events. Increase your log level in /war/WEB-INF/ , e.g., to ALL .
  • 17. Packaging
  • 18. The Extension Installer
    • Extension Hooks:
      • TOOLBAR
    • Extension Actions:
      • createNewWave
      • addParticipants
    <menuHook    location=&quot; TOOLBAR &quot;    iconUrl=&quot;;    text=&quot;Add Hello-Worldy&quot;>    < addParticipants >      <participant id=&quot;; />    </ addParticipants > </menuHook>
  • 19. Questions
  • 20. Contact Us Brian Kennish Google Wave and Chrome [email_address] Austin Chau Google Wave and YouTube [email_address]