View on GitHub

faast-path-to-beautiful-apps

Adobe I/O Lab - 2019

Lesson 2. Create your first Runtime Action

Learning Objectives

Lab Tasks


Runtime Hello World

GOAL: In this section, let’s familiarize with Runtime and the Adobe I/O CLI. Interacting with Adobe I/O Runtime currently requires the CLI (Command Line Interface). If you’ve completed the set up steps, you should have access to your own Runtime namespace.

Feel free to play with the CLI while I walk you through a few key concepts in Runtime.

1. Basic Hello World

Once you’ve configured the CLI, you can create your first function to make sure it’s working.

  1. Open a text editor, and start by creating a file called hello.js on your Desktop with the following content
     function main(params) {
       return {msg:  'Hello World!'};
     }
     exports.main = main
    
  2. Next, create the action on Runtime:
     $ cd ~/Desktop
     $ aio runtime action create hello ~/Desktop/hello.js
    
  3. Let’s list the actions to see the one you just created
     $ aio runtime action list
    

    should return

     actions                                                             
     /43611_xxxxx/hello                                private nodejs:10 
    
  4. Time to invoke the function:
     $ aio runtime action invoke hello --result
    

    You should see the following output:

     {
       "msg": "Hello World!"
     }
    
  5. You can also find out more about your activation by checking the activation log. Let’s invoke it again.
     $ aio runtime action invoke hello
    

    Upon invocation, you should also see an output that looks a bit like

     {
       "activationId": "4e159xxxxxxxxxxxxxx"
     }
    

    Copy the ID and let’s read the full activation log at

     $ aio runtime activation get <id>
    

2. Fun with Parameters

  1. Now that you’ve created and invoked your first action, let’s try to update it to take in dynamic input. Beginning with modifying your hello.js file.
     function main(params) {
       // log the parameters to stdout
       console.log('params:', params);
        
       // if a value for name is provided, use it else use a default
       var name = params.name || 'stranger';
        
       // if a value for place is provided, use it else use a default
       var place = params.place || 'somewhere';
        
       // construct the message using the values for name and place
       return {msg:  'Hello, ' + name + ' from ' + place + '!'};
     }
     exports.main = main;
    

    then update your action using

     $ aio runtime action update hello ~/Desktop/hello.js
    
  2. Now that we have an updated action that takes params, try invoking your action again, first without parameter to see the default response
     $ aio runtime action invoke hello --result
    

    You should see the following output:

     {
       "msg": "Hello, stranger from somewhere!"
     }
    
  3. Time to pass in some parameters!
     $ aio runtime action invoke hello --result --param name "Sarah" --param place "Canton"
    

    You should see the following output:

     {
         "msg": "Hello, Sarah from Canton!"
     }
    
  4. Sometimes it is helpful to invoke an action in a blocking style and receiving the activation record entirely instead of just the result. Try it:
     $ aio runtime action invoke hello --blocking
    

    You should see the full activation log

     ok: invoked /43611_56921/hello with id 352f8bf3eb3f4619af8bf3eb3f5619fc
     {
         "activationId": "352f8bf3eb3f4619af8bf3eb3f5619fc",
         "annotations": [
             {
                 "key": "limits",
                 "value": {
                     "concurrency": 1,
         ...
     }
    
    
  5. You can also bind default parameters to an action. Let’s bind a place to our hello action.
     $ aio runtime action update hello ~/Desktop/hello.js --param place Sydney
    

    Try to invoke it again without passing in any parameters, and you can see that even if you don’t pass in any parameters, the action still returns "Hello, stranger from Kansas!". Bound parameters can still be overwritten by specifying the parameter value at invocation time.

3. Understand web actions

  1. Web actions are OpenWhisk actions annotated to quickly enable you to build web based applications. Let’s now turn the action we built into a web action. Open hello.js and update the code as below
     function main(params) {
       // log the parameters to stdout
       console.log('params:', params);
        
       // if a value for name is provided, use it else use a default
       var name = params.name || 'stranger';
        
       // if a value for place is provided, use it else use a default
       var place = params.place || 'somewhere';
          
       // sample object returned in a web action
       var returnObject = {
         statusCode: 200,
         headers: {
             'Content-Type': 'application/json'
         },
         body: {msg:  'Hello, ' + name + ' from ' + place + '!'}
       };
        
       // construct the message using the values for name and place
       return returnObject;
     }
     exports.main = main;
    
  2. Update your hello action again, but with the --web true flag to indicate that this is a web action
     $ aio runtime action update hello ~/Desktop/hello.js --web true
    
  3. Now, let’s grab the url that we can use to call this actiON
     $ aio runtime action get hello --url
    

    This should return something that looks like https://adobeioruntime.net/api/v1/web/<NAMESPACE>/default/hello

  4. Let’s paste this url into your browser and see what you receive. It should be the same json response!
     // 20190307183813
     // https://adobeioruntime.net/api/v1/web/<NAMESPACE>/default/hello
        
     {
       "msg": "Hello, stranger from somewhere!"
     }
    
  5. Challenge: Can you figure out how to modify the url so that the response says “Hello, Dragos from Iaschi!”

Next:
Lesson 3 - Create your first Sequence

Return Home: Workbook Index