class: split-30 nopadding background-image: url(https://cloud.githubusercontent.com/assets/4231611/11257863/47c745ae-8e87-11e5-9753-9d4a321766b6.jpg) .column_t2.center[.vmiddle[ .fgtransparent[ #
] ]] .column_t2[.vmiddle.nopadding[ .shadelight[.boxtitle1[ # GAE - Python ### [Eueung Mulyana](https://github.com/eueung) ### http://eueung.github.io/EL6240/gae #### Python CodeLabs | [Attribution-ShareAlike CC BY-SA](https://creativecommons.org/licenses/by-sa/4.0/) #### ]] ]] --- class: column_t1 middle .fonth2[ .tab1.fullwidth[ | Agenda | |:-------------:| | GAE Basics | | Example - Guestbook | ]] --- class: split-30 nopadding background-image: url(https://cloud.githubusercontent.com/assets/4231611/11257863/47c745ae-8e87-11e5-9753-9d4a321766b6.jpg) .column_t2.center[.vmiddle[ .fgtransparent[ #
] ]] .column_t2[.vmiddle.nopadding[ .shadelight[.boxtitle1[ # GAE Python Basics #### ]] ]] --- class: split-50 nopadding .column_t2[.vmiddle[ ## Getting Started #### .figstyle1[ data:image/s3,"s3://crabby-images/54691/546918bd7815fa62ba1ea551cb56f82547b79c1f" alt="" ] .center[GAE Launcher : Add New Application] ]] .column_t1[.vmiddle[ .figstyle1[ data:image/s3,"s3://crabby-images/9b736/9b73641c287acbe2323de3c0995fd5e4e5ffae0f" alt="" ] .figstyle1[ data:image/s3,"s3://crabby-images/a38c9/a38c909da57e2fa40fc7e820ff61afefffa330dd" alt="" ] .center[GAE Launcher - Idle vs. Running App] ]] --- class: split-50 nopadding .column_t1[.vmiddle[ .figstyle1[ data:image/s3,"s3://crabby-images/97be1/97be180cab336164e440c5dd0a4250e653aa8890" alt="" ] .center[GAE Launcher -> Browse] ]] .column_t2[.vmiddle[ .figstyle1[ data:image/s3,"s3://crabby-images/744a5/744a5d611f1296ad50615988bc101c242fc5ca3e" alt="" ] .center[GAE Launcher -> SDK Console] ]] --- class: split-50 nopadding .column_t2[.vmiddle[ ``` import webapp2 #---------------------------------------- class MainHandler(webapp2.RequestHandler): def get(self): self.response.write('Hello world!') #---------------------------------------- app = webapp2.WSGIApplication([ ('/', MainHandler) ], debug=True) ``` .figstyle1[ data:image/s3,"s3://crabby-images/912c7/912c766322cf48e5eafc400c4da12313b2395806" alt="" ] ]] .column_t1[.vmiddle[ ## Generated Structure/Codes ```yaml application: hello version: 1 runtime: python27 api_version: 1 threadsafe: yes handlers: - url: /favicon\.ico static_files: favicon.ico upload: favicon\.ico - url: .* script: main.app libraries: - name: webapp2 version: "2.5.2" ``` .center[app.yaml] ]] --- class: column_t2 middle center .figstyle1[ data:image/s3,"s3://crabby-images/f1cf4/f1cf49b23bf4758ce6b972ed24f436a4f4a3fd65" alt="" ] ### https://console.cloud.google.com -> Create Project --- class: column_t1 middle center .figstyle1[ data:image/s3,"s3://crabby-images/2561e/2561ed599768fd43096b0e9d7d6dba8f3c8abfc9" alt="" ] ### https://console.cloud.google.com/home/dashboard --- class: column_t2 middle center .figstyle1[ data:image/s3,"s3://crabby-images/374bf/374bf329491eeb05375aa94e8751b0671e927e54" alt="" ] ### GAE Launcher -> Dashboard --- class: split-50 nopadding .column_t1[.vmiddle[ ## Uploading #### .figstyle1[ data:image/s3,"s3://crabby-images/bad08/bad084d554c3028ba0fc1e4d12eca7964e7bd5aa" alt="" ] .center[GAE Launcher -> Deploy] ]] .column_t2[.vmiddle[ ```yaml *application: hello-gae-1156 version: 1 runtime: python27 api_version: 1 threadsafe: yes handlers: - url: /favicon\.ico static_files: favicon.ico upload: favicon\.ico - url: .* script: main.app libraries: - name: webapp2 version: "2.5.2" ``` .center[app.yaml] ]] --- class: column_t2 middle center .figstyle1[ data:image/s3,"s3://crabby-images/8a2c2/8a2c2d8c8fe1066eba989ab5f55c64a70a7f2545" alt="" ] ### Deployed | GAE Launcher -> Dashboard --- class: column_t1 middle center .figstyle1[ data:image/s3,"s3://crabby-images/413fe/413fe16082b97340c15b396440223e8589e586cd" alt="" ] ### Live - http://hello-gae-1156.appspot.com --- class: split-30 nopadding background-image: url(https://cloud.githubusercontent.com/assets/4231611/11257863/47c745ae-8e87-11e5-9753-9d4a321766b6.jpg) .column_t2.center[.vmiddle[ .fgtransparent[ #
] ]] .column_t2[.vmiddle.nopadding[ .shadelight[.boxtitle1[ # Example - Guestbook #### ]] ]] --- class: split-50 nopadding .column_t2[.vmiddle[ ## A (Minimal) Guestbook ```html *An anonymous person wrote:
test dua dua dua dua dua
An anonymous person wrote:
test satu
*
*
``` .center[source] ]] .column_t1[.vmiddle[ .figstyle1[ data:image/s3,"s3://crabby-images/da562/da56248596c8ce2c62c180f3d6f7a688d0e7d4be" alt="" ] .figstyle1[ data:image/s3,"s3://crabby-images/ffb88/ffb88c44ee5c83d3f51152e22bcc18d8b41fc60b" alt="" ] .center[Local] ]] --- class: column_t1 middle center .figstyle1[ data:image/s3,"s3://crabby-images/b75aa/b75aaca0dea45de963d63698cb1929e1e4b609ef" alt="" ] ### Admin | GAE Launcher -> SDK Console --- class: column_t2 middle center .figstyle1[ data:image/s3,"s3://crabby-images/d7661/d76616872b0651e2beb6bbc1f646c37fc8e470c1" alt="" ] ### Admin | GAE Launcher -> SDK Console --- class: split-50 nopadding .column_t1[.vmiddle[ ### guestbook.py ``` import cgi import datetime import webapp2 #--------------------------------------- from google.appengine.ext import ndb from google.appengine.api import users #--------------------------------------- guestbook_key = ndb.Key('Guestbook', 'default_guestbook') #--------------------------------------- *class Greeting(ndb.Model): author = ndb.UserProperty() content = ndb.TextProperty() date = ndb.DateTimeProperty(auto_now_add=True) #--------------------------------------- *class Guestbook(webapp2.RequestHandler): def post(self): greeting = Greeting(parent=guestbook_key) if users.get_current_user(): greeting.author = users.get_current_user() greeting.content = self.request.get('content') greeting.put() self.redirect('/') ``` ]] .column_t2[.vmiddle[ ``` *class MainPage(webapp2.RequestHandler): def get(self): self.response.out.write('') #--------------------------------------- greetings = ndb.gql('SELECT * ' 'FROM Greeting ' 'WHERE ANCESTOR IS :1 ' 'ORDER BY date DESC LIMIT 10', guestbook_key) #--------------------------------------- for greeting in greetings: if greeting.author: self.response.out.write('
%s
wrote:' % greeting.author.nickname()) else: self.response.out.write('An anonymous person wrote:') self.response.out.write('
%s
' % cgi.escape(greeting.content)) #--------------------------------------- self.response.out.write("""
""") #--------------------------------------- *app = webapp2.WSGIApplication([ * ('/', MainPage), * ('/sign', Guestbook) *], debug=True) ``` ]] --- class: split-50 nopadding .column_t2[.vmiddle[ ```yaml *application: guestbook-test-1156 version: 1 runtime: python27 api_version: 1 threadsafe: yes handlers: - url: .* * script: guestbook.app libraries: - name: webapp2 version: "2.5.2" ``` ]] .column_t1[.vmiddle[ ### app.yaml ]] --- class: column_t1 middle center .figstyle1[ data:image/s3,"s3://crabby-images/453b0/453b0684950a1d78389ce0266619c36257bf95a8" alt="" ] ### Live --- class: column_t2 middle center .figstyle1[ data:image/s3,"s3://crabby-images/e947d/e947d69e0cdeee28a79ab9b9c44a9f4e68822346" alt="" ] ### Dashboard --- # References 1. [Hello, World! in 5 minutes - Python — Google Cloud Platform](https://cloud.google.com/appengine/docs/python/) 1. [Introduction - Python — Google Cloud Platform](https://cloud.google.com/appengine/docs/python/gettingstartedpython27/introduction) --- class: split-30 nopadding background-image: url(https://cloud.githubusercontent.com/assets/4231611/11257863/47c745ae-8e87-11e5-9753-9d4a321766b6.jpg) .column_t2.center[.vmiddle[ .fgtransparent[ #
] ]] .column_t2[.vmiddle.nopadding[ .shadelight[.boxtitle1[ # END ### [Eueung Mulyana](https://github.com/eueung) ### http://eueung.github.io/EL6240/gae #### Python CodeLabs | [Attribution-ShareAlike CC BY-SA](https://creativecommons.org/licenses/by-sa/4.0/) #### ]] ]]