14
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Dockerでサクッと試すローコード開発 -「iPLAss」

Last updated at Posted at 2022-05-13

本記事では、Dockerで「iPLAss」をインストールし、簡単に機能を試すまでの手順をまとめます。
近年開発手法として注目される「ノーコード開発」や「ローコード開発」ですが、iPLAssが提供するローコード開発の形をDockerでサクッと体験してみてください!

iPLAssとは

「iPLAss」は、オープンソースのローコード開発プラットフォームです(OSS版のライセンスは、AGPL v3になります)。

以下のような特徴を持ちます。

  • ノーコード開発
    GUI操作によるノンプログラミングでのデータ定義やその他の各種定義(認証ポリシーや画面表示に関する設定など)を行うことでアプリケーションの構築が可能です。また、データ定義を行うことで自動的に当該データのCRUD(登録/参照/更新/削除)機能を持った汎用管理画面を構成します。

    Admin Console という管理者向けのWebコンソールで各種定義が行えます。
    image.png
    ▼ 上記画像のデータ定義で実際に自動構成された新規登録/編集画面です。
    image.png

  • ローコード開発
    「ローコード開発プラットフォーム」を謳う通り、コーディングによる柔軟な拡張・カスタマイズを可能とします。
    Java/Groovyのコーディングによる柔軟なカスタマイズ組み込みが可能なほか、コンシューマ向けサイト等のフルカスタマイズされた画面/機能開発が可能なMVCパターンのフレームワーク提供、WebAPI提供などを行っています。
    Groovy/Groovy Template(GroovyベースのJSPライクなテンプレート言語)でロジックを作成した場合、変更反映の為にコンパイル・warデプロイは必要ありません。また、それらのロジックはAdmin Consoleから直接ブラウザ上のエディタで記述可能です。

    ▼ 例えば、データ操作イベント時に独自の処理を実行するEventListenerを自由にコーディングできます。
    image.png

  • 豊富な汎用機能
    上記に挙げた以外にも、認証/認可機能ID連携機能帳票出力機能メール通知機能多言語対応といったアプリケーションで必要になることの多い汎用機能を標準で提供します。

▼ iPLAssの詳細については、以下ホームページ/開発ドキュメントをご参照ください。

▼ GitHubのリンクは以下になります。

事前準備

本手順はDockerがインストール済みであることを前提としています。
Dockerのインストールがまだの場合は、お使いのOSに合わせてインストールを行ってください。

また、必要に応じて、iPLAssの設定定義ファイルやLOBデータなどを配置するiPLAssのホームディレクトリを作成してください(ホストマシン側にファイルを配置することで、設定定義ファイルの編集やバージョンアップが容易になります)。

DockerでiPLAssをインストール

1. Dockerイメージをダウンロード

以下のコマンドを実行して、iPLAssのDockerイメージをダウンロードしてください。

docker pull iplass/iplass-standalone

ダウンロードしたDockerイメージは、Web/APサーバに Tomcat、DBサーバにMySQLをバンドルし、iPLAssの動作に必要なアプリケーション及びライブラリをパッケージングしたiPLAssのDockerイメージです。

2. コンテナの作成と起動

以下のコマンドを実行して、コンテナの作成と起動を行ってください。
パスワードには、6文字以上の英数字のみ入力可能です。

docker run -p 8080:8080 -e IPLASS_TENANT_ADMIN_PASSWORD=[管理者パスワード] iplass/iplass-standalone

事前準備でiPLAssのホームディレクトリを作成した場合は、-v [作成したディレクトリの絶対パス]:/var/lib/iplassをコマンドに追加してください。同様の手順でMySQLのデータディレクトリをホストマシン側にバインドマウントすることも可能です。
また、上記コマンドで設定した環境変数以外にも、設定可能な環境変数がいくつか存在します。詳しくは、 Docker Hubに記載のドキュメント をご参照ください。

3. Webアクセス & ログイン

コンテナ起動後、Webブラウザでhttp://localhost:8080/iplassにアクセスしてください。アクセスすると、iPLAssのインストールが自動で開始されます。
ログイン画面が表示されたら、IDにadminを、パスワードにコンテナ作成時に指定したパスワードを入力して、ログインしてみてください。

image.png

image.png

動作確認

0. 用語説明

動作確認前の前提知識として、iPLAssの用語について簡単に説明します。

iPLAssでは、管理するデータ定義をEntity(エンティティ)と呼びます。エンティティはRDB上でのテーブルと同義のものです。更に、エンティティはプロパティ(属性)= RDB上でのカラムと同義を持ちます。また、定義されたエンティティをどのように画面に表示するか(入力フィールドなのか、プルダウンなのか、項目並び順、表示有無など)も設定可能です。

これら、アプリケーションで扱うデータや振る舞いを定義する設定情報をメタデータと呼びます。先に記したEntity定義の他にも、以下のようなメタデータが存在します。

メタデータ 説明
エンティティ定義 エンティティとそのプロパティ(属性)を定義します。 エンティティに定義されるプロパティのデータ型や制約、またエンティティ間のリファレンス(参照)を定義することが可能です。
エンティティビュー定義 エンティティのCRUD機能を持った汎用画面に関する定義です。エンティティの各プロパティ(属性)について、その表示有無や表示形式(テキストフィールド、ラジオボタン、リッチテキストエディタなど)、初期値などを定義することが可能です。
認証ポリシー定義 パスワードの有効期限、複雑度、ユーザロックなど、ユーザ認証の方法やそのポリシーを定義することが可能です。
メールテンプレート定義 パスワードリセット時の通知メールといったiPLAssが送信するシステムメール、カスタムロジック内で送信するメールのテンプレートを定義することが可能です。テンプレート文面にユーザ情報などを埋め込むことも可能です。
メニュー定義/トップビュー定義 サイドメニューに表示する項目や、ログイン後のトップ画面に表示する項目を定義することが可能です。
Template定義 カスタムで作成された画面の定義、およびその画面生成ロジックを定義することが可能です。テンプレート定義にはいくつかの種類があります。 主にHTMLなどのテキストデータを出力する為のJspTemplate、GroovyTemplateやバイナリ出力用のTemplate、帳票出力用のTemplateなどが存在します。
WebAPI定義 カスタマイズで作成したCommandをRESTful形式などのWebAPI経由で呼び出す為の定義です。また、Entityに対するCRUD操作やメタデータ定義に対するCRUD操作、 バイナリファイルのアップロード/ダウンロードを行うWebAPIを標準提供します。

これらのメタデータを標準提供、AdminConsole上(XMLファイルやJavaのアノテーションで設定可能な定義もあります)で設定していくことにより、最小限のコーディング量によるアプリケーション構築を可能にしています。

1. データ定義の作成

前置きが長くなりましたが、いよいよ動作確認です。

以下のような、商品を管理する商品マスタEntityを生成することを考えます。
※ エンティティには、標準プロパティ(ID、名前など)やシステムプロパティ(作成日や更新日、作成者、更新者など)がデフォルトで定義されている為、商品IDのようなプロパティは作成しません。

プロパティ名 表示名 必須 or 任意
name 名前 String 必須
description 説明  String 任意
price 価格 Integer 必須
releaseDate 発売日 Date 任意

以下の手順で商品マスタEntityを定義します。

  1. AdminConsoleを開く
    open_adminconsole.gif

  2. エンティティ定義を作成する
    create_newentity.gif

  3. 各プロパティを定義する

    1. 商品価格プロパティの定義(必須チェックのような汎用的なバリデーションを標準提供しています。Requiredにチェックを入れることで必須チェックが有効化されます。)
      create_property_price.gif

    2. 発売日プロパティの定義
      create_property_releaseDate.gif

2. CRUD機能を持った汎用画面の動作確認

作成したエンティティ定義が、汎用画面でどのように自動構成されているかを確認しましょう。
汎用画面に戻り、画面をリロードすると、サイドメニューに「商品マスタ」が追加されています。
image.png

「商品マスタ」を押下すると、商品マスタのデータを検索する為の検索画面が表示されます。この検索画面から新規登録/編集画面、詳細画面へと遷移することが可能です。

以下に各画面の例を載せます。今回の動作確認では実施しませんが、データ定義により自動生成されたエンティティビュー定義を編集することで、プロパティの表示有無や表示形式、初期値などを細かに設定することが可能です。

  • 新規登録/編集画面
    image.png

  • 詳細画面
    image.png

  • 検索画面
    image.png

3. 検証ロジックのカスタマイズ

iPLAssでは、データ登録時/更新時にデータ検証を行うことが可能であり、必須チェックやLengthチェックなどの汎用的なValidatorを標準で提供しています。

今回は、Groovyのコーディングで、「商品を新規登録する場合、発売日は登録日の翌日以降のみ指定可能とする」というカスタムの検証ロジックを実装することを考えます。

AdminConsoleで以下のようにカスタムのValidaterを定義します。エラー時のメッセージは柔軟にカスタマイズ可能であり、多言語にも対応しています。

customize.gif

image.png

実際のGroovyコードは以下の通りです。OIDというのは、Entity定義内のデータのIDです。

// 新規登録の場合は、oidがnull
def oid = entity.oid

if (oid == null) {
    def releaseDate = value
    def currentDate = new Date()
    return currentDate.before(releaseDate)
} else {
    return true
}

最後に

今回の記事では、Dockerで「iPLAss」をインストールし、簡単に動作確認するまでの手順をまとめました。

よりiPLAssの機能を理解していただく為、高度なカスタマイズをお試しいただく為にチュートリアルECサイトを模したサンプルアプリを用意しています。気になった方は是非ご確認ください!

最後までお読みいただき、ありがとうございました!
今後ともiPLAssをよろしくお願いいたします。

14
13
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
14
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?