fluentd-plugin-lets-chatを作った
fluentdのプラグインを作るために色々調べたので備忘録。
背景
Gitbucketを遊びで使ってて、Gitbucketの飛ばすWebhookをLets Chatに飛ばしたかった。
- Let's ChatのREST APIではリクエストパラメータのJSONの中にtextフィールドを持ってなきゃいけない
- Messages · sdelements/lets-chat Wiki
- => なので、textフィールド付きでリクエストするOutputプラグイン書いた
- fluentdに対して `json={}` でない形式でデータを送った時に、fluentdのin_httpプラグインだと解析してくれない(ように見えた)
- Gitbucketの飛ばすwebhookの内容が大量なので、必要な情報だけをフィルターかけてLets Chatに飛ばしたかった
こう書くとFilterプラグインが必要そうだけど、Filterプラグインの使い方がいまいち掴めなかったので、InputプラグインとOutputプラグインでほげほげしてる。
調べたこと
Fluentdプラグインの書き方については下記を参考にした。
fluentdのためのプラグインをイチから書く手順(bundler版) - たごもりすメモ
- 自分の環境(Ruby2.0.0)では、上記のやり方に加えて development_dependencyに test-unit を追加する必要があった。
途中、プラグインをインストールしているはずなのに、Fluentd(td-agent)がプラグインを見つけてくれない問題が起こった時には、下記サイトのやり方で原因を見つけた。
Fluentdの自作プラグインがロードできないのでソースの中身を追ってみる… - kk_Atakaの日記
HttpInputプラグインを拡張するやり方、およびテストの書き方については fluent-plugin-heroku-syslog を参考にした
また、本家のin_http.rbなども参考にした。
おわりに
Let's ChatはUIもモダンな感じだし、簡易的だけどREST APIも付いてるので自分でホストできるチャットツールとしては優秀だと思う。
SlackやらHipChatを使える人はそっちで十分だと思うけど、色んなしがらみによって外部ツールが使いづらいひとは試してみてはどうでしょう(主にSIer方面)。
Fluentプラグインはコード量が多くならないし、Github見ればいくつもサンプルが転がってるのでコーディング方面ではあまり躓かないけど、どういう動きをしてるのかを掴むまでは辛いものがあった。
まぁ、そこら辺はFluentdのコード読めな話なので精進が足りなかったということで。
蛇足
Royal Thunder良い。
ログインフォームを使ってログインするようなページへのアクセ
Go-lang勉強。
ログインフォームのあるようなサイトにGo-langのhttpパッケージを使ってログインする。
ログインしたいのは Log in - Swipe。
フォームの情報送るにはPostForm使うと楽っぽいけど、今回は
- リファラを設定しないとログインさせてくれない
- cookieJar使ってログイン情報持ち回りたい
という背景があったので、PostFormだと上記が満たせない感じ。
なので、Request作ってフォームの情報はbodyに流し込む下記のような方法で。
package main import ( "net/http" "net/http/cookiejar" "io/ioutil" "bytes" ) func main() { cookieJar, _ := cookiejar.New(nil) client := &http.Client { Jar: cookieJar, } // Login to swipe.to var str = []byte("Email=hogehoge%40example.com&Password=foobar") req, _ := http.NewRequest("POST", "https://www.swipe.to/login", bytes.NewBuffer(str)) req.Header.Set("Referer", "https://www.swipe.to/home") req.Header.Set("Content-Type", "application/x-www-form-urlencoded") res, _ := client.Do(req) // Create New Doc req2, _ := http.NewRequest("POST", "https://www.swipe.to/edit/create", nil) req2.Header.Set("Referer", "https://www.swipe.to/home") res2, _ := client.Do(req2) body, _ := ioutil.ReadAll(res2.Body) defer res2.Body.Close() println(string(body)) }
なんか勘違いしてる感が拭えない。
社内勉強会でGradle布教活動をしてきた
結果
「Gradle使おうぜ!」 => 失笑
資料
次のステップとして、今のプロジェクトがEclipseな感じなので、akhikhl/wuff をベースにTychoとかOSGI周りとか良いかもしれない
compare-gradle-buildsプラグインについて
Gradle in ActionやGradle徹底入門で紹介されてて気になったので触って見てる。
checkstyleの設定ファイルが違った時にどのぐらいチェック結果が変わるのかを見れるかと思ったが、現在のバージョンだとZipアーカイブの比較しか出来ないっぽい。
64.2.2. Supported build outcomes Only support for comparing build outcomes that are zip archives is supported at this time. This includes jar, war and ear archives. Future versions will provide support for comparing outcomes such as test execution (i.e. which tests were executed, which tests failed, etc.)
今後に期待。
しかし、GradleないしGroovyは今後大丈夫だろうか。。。
Groovy 2.4 And Grails 3.0 To Be Last Major Releases Under Pivotal Sponsorship | Pivotal P.O.V.
ちなみに、compare-gradle-buildsプラグインでの比較時にデフォルトで実行されるのは
gradle clean assemble
だが、実行するタスクを変更するにはホストに下記のようなbuild.gradleを書けば良い。
apply plugin: 'compare-gradle-builds' compareGradleBuilds { sourceBuild { projectDir "Hoge" tasks = ["hoge","check"] } targetBuild { projectDir "Fuga" tasks = ["check"] } }
起動中のEC2インスタンスにリダイレクトするアプリ書
Node.js使ってEC2の起動中のインスタンスにリダイレクトするWebアプリ書いてみた。
Herokuに立てておけば、起動するたびに変わるPublic IPアドレスも気にならない。
使い方は上記GithubリポジトリのHerokuボタンからデプロイページへ行き、AWSのaccess_keyあたりを入力するだけ。
(Herokuのevn入力時にrequireの指定とかって出来るのかな)
AWS_FRONT_TAGSの所に key=value 形式でEC2インスタンスのタグを指定したフィルタリングできる。
もちろんAWSには静的IPをEC2インスタンスに割り当てるElastic IPあるので、普通はコッチを使う。
Elastic IP アドレス(EIP) - Amazon Elastic Compute Cloud
今回は書き辺りを目的として、自分で作ってみたりした。
- Heroku Buttonの素振り
- HerokuでNodeアプリを動かしてみる
- lodashを触ってみる
Heroku Buttonのデプロイページでenvをrequiredで無くする設定は普通にあった。
app.json env values required by default | Heroku Dev Center
node-webkit-builderを実行できない
備忘。
mllrsohn/node-webkit-builder をnpm installして実行しようとするとエラーとなる。
env: node\r: No such file or directory
これは既知の問題のようで、GithubのIssuesではvimのコマンドで解決する方法が紹介されていた。
env: node\r: No such file or directory
-
- -
ただ、viのコマンドをコマンドラインで実行できるか分からなかったので、.travis.ymlでは下記を参考に sed コマンドで改行コードを変換する処理を事前にやっておくことでとりあえず解決したようだ。
linux - How to convert DOS/Windows newline to Unix newline in bash script? - Stack Overflow
sed $'s/\r$//' # DOS to Unix
sed コマンドで元のファイルに上書き保存する方法は下記を参考に。
sedコマンドでファイルを上書き編集 | OpenGroove
-
-
- -
-
.travis.ymlのafter_successはこんな感じになった。
after_success: - npm install -g bower - npm install - sed -i -e $'s/\r$//' node_modules/node-webkit-builder/bin/nwbuild - "./build.sh"
Heroku Buttonを試すためにアンケートアプリを作ってみた
Githubに公開してあるソースをボタンひとつでHerokuにデプロイ出来る Heroku Button を試すために、アンケートアプリを作りました。
ので、作成過程の備忘録。
動作してるもの
enquete
Heroku Buttonの設置はREADMEにボタンを書いて、app.jsonを用意するだけなのでとてもお手軽。
app.jsonには使用するアドオンなんかも指定できるので、DB使ったアプリとかも問題なしですね。
Heroku Buttonはリファラを見てアクセス元のリポジトリからコードを取得しているようなので、Github上でブランチ生やして、そのブランチ上でHeroku Buttonをクリックすればブランチ上のコードからアプリをデプロイできる。
そこら辺上手く使えると便利そう。
アンケートアプリ自体は、ちゃんと作り込んだ訳ではないので怪しい部分は多々あり。
アンケート作成画面のライブプレビューがちゃんと動かなかったり。。。
Live Preview Error · Issue #18 · kaakaa/Enquete
中身の話
フレームワークはSinatra / Haml / ActiveRecord。
Markdown形式でアンケートが書けると良いなぁということで、StackOverflowのエディタであるwmdを使用しています。
(現在、wmdはpagedownとして公開されているようです pagedown - A JavaScript Markdown converter and editor - Google Project Hosting)
元々wmdにform要素を記述する機能は無かったようなのですが、Github上でformタグが記述できるように拡張したフォークが存在したのでそれを使用しています。
さらにSinatraから使えるように少し修正を加えました。
kaakaa/wmd
結果の集計画面は Highcharts による円グラフ等を使用しています。
Highchartsは手軽に使えるので良いですね。
備忘録
作ってる内に躓いた点を備忘として残しておきます。
- RubyのTimeで◯日後などを取得するにはActiveSupportが便利
- アンケートの回答を集計する
- mapとかinjectとか、まだまだ苦手だけど使えると便利そう
- Hamlからヘルパーメソッドを呼び、ヘルパー内でjavascriptコードを生成する