メインコンテンツまでスキップ
バージョン: v20 R4

Qodly Studio

デベロッパー・プレビュー

4D の Qodly Studio は現在、デベロッパー・プレビュー の段階です。 本番環境で使用すべきではありません。

Qodly Studio は、設計・テスト・公開がすべて Qodlyクラウドでおこなわれる Webビジネスアプリケーションの開発に特化した Qodly プラットフォーム の一部です。

4D v20 R2 では、 4D から直接 Qodly Studio を使用して、モダンで洗練された Webインターフェースをビルドし、既存の 4Dプロジェクトに簡単に統合して、オンプレミス で運用することができます。

Qodly Studio では、全く新しい WebUI を使い、データソースの概念に慣れ、次の操作を学ぶことができます:

  • ページ上にコンポーネントを配置して Webフォームを作成する
  • コンポーネントをデータにマッピングする
  • イベントを設定して 4Dコードをトリガーする
  • さらに沢山のことが可能です
info

4D で Qodly Studio を使用するには、専用のライセンスが必要です。 ライセンスが有効化されていない場合、Qodly Studio に関するオプションやメニュー項目は表示されません。

設定

要件

ブラウザー

Qodly Studio は、以下の Webブラウザーをサポートしています:

  • Chrome
  • Edge
  • FireFox

推奨解像度は 1920x1080 です。

4Dアプリケーション

  • 開発: 4D v20 R2 以上
  • 運用: 4D Server v20 R2 以上
  • Qodly Studio は 4Dプロジェクトでのみ動作します (バイナリデータベースはサポートされていません)。

Qodly Studio へのアクセスを有効化する

デフォルトでは、Qodly Studio へのアクセスは許可されていません。

Qodly Studioは、WebAdmin Webサーバー によって提供され、表示される 4Dプロジェクトのデータは 4D Webサーバー によって処理されます。

Qodly Studio へのアクセスを有効化するには、2つのレベルで明示的に許可する必要があります:

  • 4Dレベルで (4D または 4D Server)
  • プロジェクトレベルで

2つのレベルのいずれか (または両方) が有効でない場合、Qodly Studio へのアクセスは拒否されます (403ページが返されます)。

4Dレベルで

最初のセキュリティレベルとして、WebAdmin Webサーバーで Qodly Studio へのアクセスを許可 する必要があります。

この設定は、ホストマシンの 4Dアプリケーション (4D または 4D Server) が対象となります。 つまり、その 4Dアプリケーションで開くすべてのプロジェクトで、この設定が適用されます。

アプリケーション上で Qodly Studio へのアクセスを許可しない場合は、このオプションをオフにします。

このオプションにチェックを入れると、Qodly Studio にアクセスできるようになります。 さらに、各プロジェクトのレベルでも許可が必要です。

さらに、WebAdmin Webサーバーの HTTP/HTTPS ポートを設定 することもできます。

これらの設定を変更した後、新しい設定を有効にするには、WebAdmin Web サーバー を再起動する必要があります。

プロジェクトレベルで

4Dレベルで Qodly Studio へのアクセスを有効にした後、アクセスできるプロジェクトをそれぞれ明示的に指定する必要があります。 Qodly Studio へのアクセスを有効化する オプションは、プロジェクト設定の Web機能ページ で有効にする必要があります。

ユーザー設定 はいくつかのレベルで定義でき、優先順位が適用されることに留意してください。

認証を有効化する

WebAdmin Webサーバーでの認証には、アクセスキーを使用します。 詳しくは、アクセスキー を参照ください。

レンダリングを有効化する

Qodly Studio で作成した Webフォームのレンダリングを有効にするには、以下のオプションを設定する必要があります。

Qodly Studio で Webフォームをレンダリングする際、レンダラーは設定により、WebAdmin Webサーバー と同じ HTTP/HTTPS 接続パターンに従って、HTTP または HTTPS で 4D Webサーバーに接続します。

info

Qodly で Webフォームをレンダリングする方法については このページ を参照ください。

"新しいタブでプレビュー" ボタンをクリックすると、マシン上で IP:port/$lib/renderer/?w=WebFormName のタブが開くことに注意してください。

Qodly Studio は、4D WebAdmin Webサーバーを通して動作することに留意してください。 開発者として Qodly Studio を使用する場合、Webフォームをプレビューするには、4D WebAdmin Webサーバーを使用することになります。 これにより、たとえば RESTリソースとして公開されていないデータクラス、関数、属性を (グレーアウトされた状態で) 見ることができます。

しかし、実際の Webフォームのレンダリングは 4D Web Studio の外でおこなわれ、標準の 4D Webサーバーによって処理されます。 このような状況では、Webアプリケーションは RESTリソースとして公開されていないデータにアクセスできません。 公開vs非公開関数 および テーブルの公開 を参照ください。

設定オプションが有効になっていない場合、レンダラー ボタン は非表示です。

WebAdminサーバーと運用

運用には、WebAdminサーバーは必要ありません。 Qodly Studio で作成された Webアプリケーションへのエンドユーザーアクセスは、4D RESTプロトコルに基づいているため、従来の 4Dリモートアプリケーションと同様に動作します。

プロジェクトメソッドを使用する

推奨される方法は、プロジェクトメソッドではなく、クラス関数を使用することです。 コンポーネントから呼び出すことが可能なのは、クラス関数のみです。 それでも、次の 2つの方法で、Qodly Studio でもプロジェクトメソッドを使用できます:

  • クラス関数からメソッドを呼び出すことができます。
  • Qodly Explorer から直接 メソッドを実行 できます。

Qodly Studio を開く

Qodly Studio ページは、WebAdmin Webサーバーが起動されており、認証が有効化されている場合に使用できます (上述参照)。

Qodly Studio にアクセスするには 2つの方法があります:

  • 4Dシングルユーザーアプリケーションから、デザイン > Qodly Studio... を選択します。 WebAdmin Webサーバーがすでに起動されている場合は、その設定に応じて、デフォルトのブラウザーが IPaddress:HTTPPort/studio または IPaddress:HTTPSPort/studio を開きます。 それ以外の場合は、最初に WebAdmin Webサーバーを起動するかどうかを尋ねるメッセージが表示されます。

  • 4D または 4D Server から WebAdmin Webサーバーが起動されている状態で、ブラウザーに次のアドレスを入力します:

IPaddress:HTTPPort/studio

または:

IPaddress:HTTPSPort/studio

たとえば、ポート7080 でローカルWebサーバーを起動した後、ブラウザーに次のアドレスを入力します:

localhost:7080/studio

すると、Qodly Studio にアクセスするための アクセスキー の入力を求められます。

Qodly Studio を使う

公式の Qodly Studio ドキュメントは、Qodly ドキュメント Webサイト から入手できます。

Webフォームを利用した Webアプリケーションを開発するには、このドキュメントとその関連リソースを参照ください。 ただし、実装の段階に応じて、4Dデベロッパーは Qodly Studio または 4D IDE を使用します。

info

4D で実装されたアプリと Qodly で実装されたアプリの間に直接の互換性はありません。

機能の比較

4D IDE を使用する 4Dデベロッパー向けの Qodly StudioQodlyデベロッパー向けの Qodly Studio
テーブル (データクラス)、フィールド (属性)、リレーションの表示および編集4Dストラクチャーエディター(1)Qodly Studio Model Editor
WebフォームQodly Studio Webform EditorQodly Studio Webform Editor
デスクトップフォーム4D IDEサポートされていません
プログラミング言語4Dランゲージ (ORDA を使用)QodlyScript (ORDA を使用)
コーディング IDE4D IDE コードエディター / VS Code と 4D拡張機能 (2)Qodly Studio コードエディター
デバッガー4D IDE デバッガーQodly Studio デバッガー
REST/Web ロールとアクセス権roles.json の直接編集 / Qodly Studio ロールとアクセス権エディターQodly Studio ロールとアクセス権エディター

(1) Qodly Studio で Model ボタンをクリックしても、何も起こりません。 (2) Qodly Studio で 4Dコードを開くと、シンタックスの配色がサポートされておらず、"Lsp not loaded" という警告が表示されます。

プロジェクト管理

4Dプロジェクトの管理上、以下の使用法のみがサポートされます:

  • Qodly Studio での開発は 4D (シングルユーザー) でおこなう必要があります。
  • Qodly Webフォームを利用した 4Dアプリケーションの運用は、4D Server でおこなう必要があります。

QodlyScript から 4Dランゲージへ

Qodly Studio ドキュメント を使用して、4Dデベロッパーは、Qodly Studio で Webフォームを設計する方法を学ぶことができます。 コードの例は QodlyScript で提供されていますが、QodlyScript は 4Dランゲージから継承しているため、困ることはありません。 QodlyScript コードを 4Dランゲージに変換するのは簡単で、いくつかの調整が必要なだけです:

変数名

QodlyScript はローカル変数のみをサポートするため、QodlyScript の例題では、変数に $ という接頭辞が付きません。 4Dコードでは、4D によってローカル変数として識別されるように、変数名の前には必ず $ を付けてください

記号とキーワード

一部の基本的な記号、演算子、キーワードは QodlyScript では異なるため、4Dランゲージ用に変換する必要があります。 以下に一覧を示します:

QodlyScript4Dランゲージ説明
,;引数の区切り文字
=:=代入演算子
===比較演算子
declare#Declare
switchCase of
constructorClass constructor
extendsClass extends
endEnd for, End For each, End if, End case, End use, End while
forEachFor each
stringText変数の型
numberReal変数の型

他の一部の項目では文字の大小が異なりますが (例: thisThis)、4Dコードに直接貼り付けることができます。

コマンド名

QodlyScript のコマンド名は、スペースを入れずにキャメルケースで記述されます。 これらのコマンドを 4Dランゲージに変換する必要がある場合があります。

  • 通常は、単に名前を変換するだけで十分です。 たとえば、QodlyScript の newCollection は 4Dランゲージの New collection です。
  • ただし、コンプライアンス向上のため、一部のコマンドでは名前が変更されました。 以下に一覧を示します:
QodlyScript4Dランゲージ
atanArctan
highestProcessNumberCount tasks
callChainGet call chain
objectClassOB Class
objectCopyOB Copy
objectEntriesOB Entries
instanceOfOB Instance of
objectIsDefinedOB Is defined
objectIsEmptyOB Is empty
objectIsSharedOB Is shared
objectKeysOB Keys
objectRemoveOB REMOVE
objectValuesOB Values
sqrtSquare root

例題

  • QodlyScript コード:
 declare(entitySelection : 4D.EntitySelection)  
var dataClass : 4D.DataClass
var entity, duplicate : 4D.Entity
var status : object
dataClass=entitySelection.getDataClass()
forEach(entity,entitySelection)
duplicate=dataClass.new()
duplicate.fromObject(entity.toObject())
duplicate[dataClass.getInfo().primaryKey]=null
status=duplicate.save()
end
  • 上に相当する 4Dランゲージのコード:
 #DECLARE ( $entitySelection : 4D.EntitySelection )  
var $dataClass : 4D.DataClass
var $entity; $duplicate : 4D.Entity
var $status : Object
$dataClass:=$entitySelection.getDataClass()
For each($entity;$entitySelection)
$duplicate:=$dataClass.new()
$duplicate.fromObject($entity.toObject())
$duplicate[$dataClass.getInfo().primaryKey]:=Null
$status:=$duplicate.save()
End for each

オフラインでの使用

コンピュータがインターネットに接続されていない状態でも、Qodly Studio を使って開発することができます。 ただしこの場合、以下の機能は使用できません:

  • テンプレート: テンプレートライブラリは空です。
  • UI Tips: alt-textアイコンをクリックしても表示されません。

ライセンスの使用について

Webフォームをレンダリングするには、プロジェクトデータベースのメインの Webサーバーでセッションが開かれるため、使用可能なライセンスが必要です。

URLスキーム

Qodly Studio の URLスキーム設定 (HTTP および HTTPS) によって、Webフォームのレンダリング時に使用されるライセンスの数が決まります。 適切な設定により、不要なライセンスの使用を回避できます。

設定 セクションで説明したように、WebAdmin Webサーバーは Qodly Studio へのセキュアな Webアクセスを提供します。 一方、レンダラー は RESTリクエストを使用してデータベースの 4D Webサーバーと通信します。 そのため、従来の 4Dクライアントと同じように動作します。 そのため、従来の 4Dクライアントと同じように動作します。

Qodly Studio からレンダラーを実行する際、これら 2つの Webサーバーに同じ URLスキーム (HTTP または HTTPS) 経由でアクセスしていない場合には、ライセンスのカウントが正しくおこなわれない可能性があります。

例題

  1. Qodly Studio を HTTPS URLスキームで実行します (例: https://127.0.0.1:7443/studio/)

  2. データベースの Webサーバーは HTTPポート上でのみ起動します。

alt-text

  1. Qodly Studioで、レンダリング アイコンをクリックします。 2つの Webサーバーが異なるスキームで起動されていることを警告されますが、それにもかかわらず、Confirm ボタンをクリックします。

alt-text

結果、2つのライセンスが使用されます。

Qodly Studio のユーザー設定で、レンダラーのポップオーバーについて表示/非表示を切り替えることができます。

SameSite 属性

先に説明したふるまいは、4D Webサーバーのセッションcookie によるものです。 このセッションcookie には、SameSite 属性があり、セッションcookie が Webサーバーに送信されるかどうかを決定します。

SameSite 属性の値が Strict (デフォルト) の場合、セッションcookie は Webサーバーに送信されないため、ページが表示されたり更新されたりするたびに新しいセッションが開かれます。

SameSite 属性の詳細については、このブログ記事 を参照ください。

推奨事項

必要以上のライセンスを使用しないため、次のいずれかをお勧めします:

  • 別のブラウザータブでレンダラーを実行します (Webフォームがレンダリングされた URL IP:port/$lib/renderer/?w=WebFormName を入力します)。
  • Qodly Studio とデータベースが同じ URLスキームでアクセスされていることを確認します。
  • プロジェクトデータベースの Webサーバーの セッションcookie には、Lax の値を使用してください。

Hello, World

この 5分間のビデオでは "Hello World" の例を説明します。まず、Qodly Studio へのアクセスを有効にし、基本的なインターフェースを作成して、ユーザー名を使って挨拶をするイベントを設定します。