mirror of
https://github.com/fnproject/fn.git
synced 2022-10-28 21:29:17 +03:00
examples: update guppy example with latest fn functionalities (#432)
* examples: update guppy example * examples: fix typo
This commit is contained in:
@@ -5,9 +5,7 @@ This example will show you how to test and deploy a SlackBot command to IronFunc
|
|||||||
```sh
|
```sh
|
||||||
# create your func.yaml file
|
# create your func.yaml file
|
||||||
fn init <YOUR_DOCKERHUB_USERNAME>/guppy
|
fn init <YOUR_DOCKERHUB_USERNAME>/guppy
|
||||||
# install dependencies, we need the json gem to run this
|
# build the function - install dependencies from json gem
|
||||||
docker run --rm -v "$PWD":/worker -w /worker iron/ruby:dev bundle install --standalone --clean
|
|
||||||
# build the function
|
|
||||||
fn build
|
fn build
|
||||||
# test it
|
# test it
|
||||||
cat slack.payload | fn run
|
cat slack.payload | fn run
|
||||||
@@ -16,7 +14,9 @@ fn push
|
|||||||
# Create a route to this function on IronFunctions
|
# Create a route to this function on IronFunctions
|
||||||
fn routes create slackbot /guppy
|
fn routes create slackbot /guppy
|
||||||
# Change the route response header content-type to application/json
|
# Change the route response header content-type to application/json
|
||||||
curl -X PUT http://127.0.0.1:8080/v1/apps/slackbot/routes/guppy -d '{ "route": { "headers": { "Content-type": ["application/json"] } } }'
|
fn routes headers set slackbot /guppy Content-Type application/json
|
||||||
|
# test it remotely
|
||||||
|
cat slack.payload | fn call slackbot /guppy
|
||||||
```
|
```
|
||||||
|
|
||||||
## Create a Slash Command integration in Slack
|
## Create a Slash Command integration in Slack
|
||||||
|
|||||||
@@ -1,5 +1,13 @@
|
|||||||
package langs
|
package langs
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
type RubyLangHelper struct {
|
type RubyLangHelper struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -8,14 +16,42 @@ func (lh *RubyLangHelper) Entrypoint() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (lh *RubyLangHelper) HasPreBuild() bool {
|
func (lh *RubyLangHelper) HasPreBuild() bool {
|
||||||
return false
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
// PreBuild for Go builds the binary so the final image can be as small as possible
|
|
||||||
func (lh *RubyLangHelper) PreBuild() error {
|
func (lh *RubyLangHelper) PreBuild() error {
|
||||||
|
wd, err := os.Getwd()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if !exists(filepath.Join(wd, "Gemfile")) {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
pbcmd := fmt.Sprintf("docker run --rm -v %s:/worker -w /worker iron/ruby:dev bundle install --standalone --clean", wd)
|
||||||
|
fmt.Println("Running prebuild command:", pbcmd)
|
||||||
|
parts := strings.Fields(pbcmd)
|
||||||
|
head := parts[0]
|
||||||
|
parts = parts[1:len(parts)]
|
||||||
|
cmd := exec.Command(head, parts...)
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
if err := cmd.Run(); err != nil {
|
||||||
|
return fmt.Errorf("error running docker build: %v", err)
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (lh *RubyLangHelper) AfterBuild() error {
|
func (lh *RubyLangHelper) AfterBuild() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func exists(name string) bool {
|
||||||
|
if _, err := os.Stat(name); err != nil {
|
||||||
|
if os.IsNotExist(err) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user