LoginSignup
3
1

More than 5 years have passed since last update.

Azure Functionsを使ってサーバーレス環境でnem2-sdkによる定期送金をしてみる

Last updated at Posted at 2018-08-24

概要

Azure Functionsでnem2-sdkを使う方法をざっくりと書きます。

デフォルトではnem2-sdkが使えないので、インストールします。ただし、Functionsのバージョンがv2でないとライブラリのインストールができません。

インストールは、Web画面上のコンソールで行います。それが終わったら、関数を作成し、コードを入力します。内容は、あるアカウントから別のアカウントへの送金です。

関数は、トリガーをタイマーにして、定期的に起動するようにします。

例えば、お昼休みになると自動的にお昼ご飯代が振り込まれるといった使い方ができるかもしれません。

リソース作成

  1. リソースの作成
  2. Compute
  3. Function App

image.png

項目 説明
アプリ名 任意の名前
サブスクリプション 選べるやつどれか
リソースグループ わからなかったら新規作成
OS とりあえずWindows
場所 任意
Storage わからなかったら新規作成
Application Insights オン
Application Insightsの場所 任意
  1. リソースグループ
  2. (作成したリソースグループ)をクリック
  3. 4つのリソースが作成された

image.png

Functions App 設定

これをクリック

image.png

  1. (作成したFunction App)
  2. プラットフォーム機能
  3. アプリケーション設定

image.png

下の方にスクロール

FUNCTIONS_EXTENSION_VERSIONbetaにする。

WEBSITE_NODE_DEFAULT_VERSION10.6.0とか8.11.1とか、nem2-sdkが要求しており、Azure Functionsが対応しているNode.jsのバージョンにする。

image.png

上の方にスクロール

保存する

image.png

Azure Functionsが対応しているNode.jsのバージョン

  1. (作成したFunction App)
  2. プラットフォーム機能
  3. 高度なツール(Kudu)

image.png

Runtime Versions

image.png

nem2-sdkインストール

  1. プラットフォーム機能
  2. コンソール

image.png

コマンドを入力。

遅いです。5分くらいかかります。コーヒーでも飲みましょう。

echo { "dependencies": { "nem2-sdk": "^0.10.1" } } > package.json
npm install

image.png

関数の作成

  1. 関数の横の+マーク
  2. TimeTriggerのJavaScript

image.png

作成します

image.png

もしくは、この画面が出たら、

  1. 関数の横の+マーク
  2. タイマー
  3. JavaScript
  4. この関数を作成する

image.png

この箇所に、以下のコードで置き換え、保存する。

image.png

以下のコード
module.exports = function (context, myTimer) {
    var timeStamp = new Date().toISOString();

    if(myTimer.isPastDue)
    {
        context.log('JavaScript is running late!');
    }
    context.log('JavaScript timer trigger function ran!', timeStamp);   

    const nem2Sdk = require("nem2-sdk");

    const Address = nem2Sdk.Address,
        Deadline = nem2Sdk.Deadline,
        Account = nem2Sdk.Account,
        UInt64 = nem2Sdk.UInt64,
        NetworkType = nem2Sdk.NetworkType,
        PlainMessage = nem2Sdk.PlainMessage,
        TransferTransaction = nem2Sdk.TransferTransaction,
        TransactionHttp = nem2Sdk.TransactionHttp,
        XEM = nem2Sdk.XEM;

    const recipientAddress = 'SB2Y5ND4FDLBIO5KHXTKRWODDG2QHIN73DTYT2PC';

    const transferTransaction = TransferTransaction.create(
        Deadline.create(),
        Address.createFromRawAddress(recipientAddress),
        [XEM.createRelative(1)],
        PlainMessage.create('Welcome To NEM'),
        NetworkType.MIJIN_TEST,
    );

    const privateKey = '7808B5B53ECF24E40BE17B8EC3D0EB5F7C3F3D938E0D95A415F855AD4C27B2A4';
    const account = Account.createFromPrivateKey(privateKey,NetworkType.MIJIN_TEST);
    const signedTransaction = account.sign(transferTransaction);
    context.log("hash: " + signedTransaction.hash);

    const transactionHttp = new TransactionHttp('http://catapult48gh23s.xyz:3000');
    transactionHttp.announce(signedTransaction).subscribe(
        x => {
            context.log(x);
            context.done();
            },
        err => {
            context.log.error(err);
            context.done();
        }
    );
};

関数の実行

実行ボタンを押すと、即座に実行できる。

完了まで1分くらいかかります。

image.png

タイマー設定

毎分起動

image.png

結果

image.png

ずっと動いているとは限りません

使用したアカウントとか

使用したアカウント

  Sender:
    private: 7808B5B53ECF24E40BE17B8EC3D0EB5F7C3F3D938E0D95A415F855AD4C27B2A4
    public: 5D9513282B65A12A1B68DCB67DB64245721F7AE7822BE441FE813173803C512C
    address: SBWEUWON6IBHCW5IC4EI6V6SMTVJGCJWGLF57UGK
  Reciever:
    private: 31B96EEB0C7FD6F8FB6B4ED09A9EB142A42B194AFBEB9EB52F0B79889F22326E
    public: 3390BF02D2BB59C8722297FF998CE89183D0906E469873284C091A5CDC22FD57
    address: SB2Y5ND4FDLBIO5KHXTKRWODDG2QHIN73DTYT2PC

使用したネットワーク

使用した蛇口

3
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
1