Blog API example (#377)

This commit is contained in:
Travis Reeder
2017-09-29 15:59:39 -07:00
committed by GitHub
parent a491d1bfde
commit 35bcc4e658
39 changed files with 218 additions and 0 deletions

View File

@@ -0,0 +1,5 @@
source 'https://rubygems.org'
gem 'json', '> 2'
gem 'sequel'
gem 'mysql2'

View File

@@ -0,0 +1,5 @@
source 'https://rubygems.org'
gem 'json', '> 2'
gem 'sequel'
gem 'mysql2'

View File

@@ -0,0 +1,20 @@
require 'json'
require 'sequel'
DB = Sequel.connect("mysql2://docker.for.mac.localhost/blog?user=#{ENV['DB_USER']}&password=#{ENV['DB_PASS']}")
payload = STDIN.read
if payload == ""
puts ({"error" => "Invalid input"}).to_json
exit 1
end
payload = JSON.parse(payload)
# create a dataset from the items table
items = DB[:posts]
# populate the table
items.insert(:title => payload['title'], :body => payload['body'])
puts ({"status"=>"success", "message" => "Post inserted successfully."}).to_json

View File

@@ -0,0 +1,5 @@
version: 0.0.8
runtime: ruby
entrypoint: ruby func.rb
build_image: treeder/ruby-mysql
run_image: treeder/ruby-mysql

View File

@@ -0,0 +1,26 @@
{
"tests": [
{
"input": {
"body": {
"name": "Johnny"
}
},
"output": {
"body": {
"message": "Hello Johnny"
}
}
},
{
"input": {
"body": ""
},
"output": {
"body": {
"message": "Hello World"
}
}
}
]
}

View File

@@ -0,0 +1,14 @@
require 'json'
require 'sequel'
DB = Sequel.connect("mysql2://docker.for.mac.localhost/blog?user=#{ENV['DB_USER']}&password=#{ENV['DB_PASS']}")
items = DB[:posts]
rlist = []
items.each_with_index do |x,i|
STDERR.puts "item: #{x}"
rlist << x
end
r = {posts: rlist}
puts r.to_json

View File

@@ -0,0 +1,5 @@
version: 0.0.2
runtime: ruby
entrypoint: ruby func.rb
build_image: treeder/ruby-mysql
run_image: treeder/ruby-mysql

View File

@@ -0,0 +1,26 @@
{
"tests": [
{
"input": {
"body": {
"name": "Johnny"
}
},
"output": {
"body": {
"message": "Hello Johnny"
}
}
},
{
"input": {
"body": ""
},
"output": {
"body": {
"message": "Hello World"
}
}
}
]
}