これは、サンプルAPI呼び出しとそれらを連結して単純なアクションを完了する方法に関する指示を含むシンプルなAPIシナリオです。APIを介して設定できるオプションは広範囲にわたります。利用可能なすべてのオプションについては、REST APIドキュメントの該当セクションを参照してください。
シナリオを作成するためにPostman APIプラットフォームが使用されました。
これらの例では、標準リクエストURLはhttps://cloud.memsource.comで始まります。米国データセンターの組織がAPIを使用する場合、リクエストURLはhttps://us.cloud.memsource.comで始まる必要があります。
シナリオ
-
認証
ユーザーは認証されます(APIのログインに相当します)。
-
作成
シンプルなプロジェクトの作成、アップロードされたジョブ、およびメール通知付きのリンギスト割り当て。
-
翻訳
APIシナリオの外で行われる翻訳作業(任意のエディタで)。
-
API機能
割り当てが完了すると(リンギストによって完了としてマークされる)、プロジェクトのステータスは完了に設定され、完成したドキュメントがプロジェクトからダウンロードされます。
方法論
各個別のREST API呼び出しには、適切なメソッドがリストされています。不正なメソッドを使用すると(例:プロジェクト作成呼び出しでPOSTの代わりにGET)、API呼び出しが失敗します。
ステップ1:認証
認証方法は2つあります:
このシナリオでは、認証API呼び出しが使用されます。生成されたトークンはすべての次のAPI呼び出しに必要であり、例のパラメータにはリストされていません。
必要なパラメータを使用してログインAPIを認証に使用してください。この場合、ユーザー名とパスワードが必要です。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v3/auth/login
-
リクエストボディ:
{ "userName":"username", "password":"password"} -
レスポンス
認証トークン。
複数のTMS組織のメンバーは、複数のアカウントに対して同じユーザー名とパスワードを持っています。この場合、userUidをリクエストボディに追加して、ユーザーがログインしたい組織を指定する必要があります。指定されていない場合、ユーザーは指定されたユーザー名とパスワードに関連付けられたデフォルトのアカウントにログインしています。
ステップ2:プロジェクトの作成、インポート、および割り当て
プロジェクトの作成
プロジェクト API コールを使用して、必須パラメータ 名前、ソース言語、および ターゲット言語 を使用してプロジェクトを作成します。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v3/projects
-
リクエストボディ
{ "name":"My project", "sourceLang":"en", "targetLangs":[ "de","fr" ]} -
レスポンス
プロジェクト UID (例:KmtNyVlz1skQd2aMVEipp7)
最後のコールからのプロジェクト UID を使用して、プロジェクトテンプレートを作成 API コールを使用してプロジェクトテンプレートを作成することができます。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v1/projectTemplates
-
リクエストボディ
{ "project": { "uid": "string" }, "name": "string", "importSettings": { "uid": "string" }, "useDynamicTitle": true, "dynamicTitle": "string" } -
レスポンス
プロジェクトテンプレート UID (例:AmtNyVlz1skQd2aMVEipp8)
プロジェクトを作成する最も効率的な方法は、プロジェクトテンプレートを使用することです。最後のコールからのプロジェクトテンプレート UID を使用して、テンプレートからプロジェクトを作成を使用して、プロジェクトテンプレートの設定に基づいて新しいプロジェクトを作成します。
式 {templateUid} は、取得したプロジェクトテンプレート UID が挿入されるリクエスト URL のプレースホルダーとして機能します。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v2/projects/applyTemplate/oNQiljwTGHpd2l1nnQRiu4
-
リクエストボディ
{ "name": "string", "sourceLang": "string", "targetLangs": [ "string" ], "workflowSteps": [ { "id": "string" } ], "dateDue": "2019-08-24T14:15:22Z", "note": "string", "client": { "id": "string" }, "businessUnit": { "id": "string" }, "domain": { "id": "string" }, "subDomain": { "id": "string" }, "costCenter": { "id": "string" } }{ "project": { "uid": "string" }, "name": "string", "importSettings": { "uid": "string" }, "useDynamicTitle": true, "dynamicTitle": "string" } -
レスポンス
プロジェクト UID (例:BmtNyVlz1skQd2aMVEipp9)
ジョブの作成
最後のコールからのプロジェクト UID を使用して、新しく作成されたプロジェクトに直接新しいジョブを追加することができます。ジョブを作成を使用します。
式 {projectUid} は、取得したプロジェクト UID が挿入されるリクエスト URL のプレースホルダーとして機能します。ジョブ作成 API コールを使用する場合、リクエストの ヘッダー を Phrase が要求するものに一致するように変更する必要があります(他のコールでは、Postman が自動的にリクエストに適切なヘッダーを追加します)。
すべてのインポートパラメータは、カスタム Memsource ヘッダーに挿入する必要があります。
Content-Disposition ヘッダーには、インポートリクエストを正しく処理するために、事前定義された形式のファイル名を含める必要があります。
ソースファイルをインポートするには、本文に移動し、を選択すると、オプションが表示されます。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v1/projects/KmtNyVlz1skQd2aMVEipp7/jobs
-
(ヘッダー) コンテンツ-ディスポジション
filename*=UTF-8''file.txt -
(ヘッダー) メムソース
{"targetLangs":["de","fr"]} -
(ヘッダー) コンテンツ-タイプ
application/octet-stream
-
レスポンス
ジョブUID(例:dOYgeXzAdAbj4xFjuEVZP2)
非同期リクエストUID
ジョブ作成呼び出しからの非同期リクエストUIDを使用して、非同期リクエストを取得し、ジョブが正常に作成され、機能していることを確認します。
返されたジョブUIDは、プロジェクトの各ワークフローステップでユニークです。したがって、ジョブがワークフローを持つプロジェクトで作成されると、応答は各ワークフローステップに対してユニークなジョブUIDを返します。
再利用可能なインポート設定は、インポート設定を作成呼び出しで構成できます。ジョブ作成呼び出しで使用できるインポート設定UIDが応答で受信されます。
ジョブにプロバイダを割り当てるには(ジョブ作成呼び出しで直接割り当てられていない限り)、ジョブを編集呼び出しを使用します。
呼び出しに挿入されたプロバイダのIDは、2つの方法で取得できます:
-
フレーズアプリケーションからIDを取得するには、次の手順に従います:
-
使用する ユーザー一覧 API呼び出し。
このAPI呼び出しには特定のパラメータは必要なく、アカウント内のすべてのユーザーのリストが返されます。レスポンスにはユーザー名とIDの両方が含まれています。
オプションのパラメータ、ユーザー名をクエリに追加することで、特定のユーザー名を持つユーザーのみを一覧表示できます。
割り当てられたユーザーに通知
ジョブUIDは、割り当てられたユーザーに通知呼び出しのオプションのパラメータとして使用でき、使用するメールテンプレートのIDを表すメールテンプレートパラメータと共に使用されます。これは、メールテンプレートの一覧呼び出しを使用することで取得できます。
-
リクエストURL
https://cloud.memsource.com/web/api2/v1/projects/KmtNyVlz1skQd2aMVEipp7/jobs/notifyAssigned
-
レスポンス
空欄(ステータス204:コンテンツなし)
ここが翻訳者がプロファイルで作業を開始する場所であり、Phrase UIが使用されているかのように作業します。ジョブが完了すると、担当のPMが通知を受け取り、シナリオの次の部分が開始されます。コールバックは、ウェブフックを介してインターセプトされ、シナリオの次の部分を自動的に開始できますが、これはこの例では扱いません。
ステップ3:翻訳された(完了)ファイルをダウンロードし、プロジェクトを完了として設定します。
翻訳されたファイルをダウンロード
このシナリオは、翻訳者が自分の任務を完了する(ジョブを完了としてマークする)という前提で機能しますが、完了したファイルはいつでもダウンロードでき、ジョブは完了ステータスである必要はありません。
翻訳されたファイルをダウンロードするには、2つのAPI呼び出しが必要です:ターゲットファイルをダウンロード(非同期)と非同期リクエストに基づいてターゲットファイルをダウンロード呼び出し。
最初のステップは、ターゲットファイルをダウンロード(非同期)をプロジェクトUIDとジョブUIDパラメータで呼び出すことです。複数のワークフローステップを持つプロジェクトから完了したファイルをダウンロードする場合は、完了したファイルをダウンロードしたい特定のワークフローステップからのジョブUIDを使用してください。例えば、リビジョンワークフローステップです。
-
特定のワークフローステップのジョブUIDをPhraseアプリケーションから取得するには、次の手順に従ってください:
-
プロジェクトを開きます。
-
ジョブテーブルで、完了したファイルをダウンロードしたいワークフローステップに切り替えます。
-
ブラウザから/jobの後のURLのユニークな部分をコピーします。
-
-
使用する ジョブの一覧 API呼び出し。
このエンドポイントは、指定されたプロジェクト内のジョブの一覧を返します。
ワークフローレベルクエリパラメータを使用して呼び出します。このパラメータは、返されたジョブが属するワークフローステップを示す非ゼロベースのパラメータです。指定しない場合、その値はデフォルトで1(= 最初のワークフローステップ) に設定されます。例えば、リビジョンステップからジョブを取得する必要がある場合、そのステップの番号をクエリパラメータに指定します。すなわち2。
ダウンロード対象ファイル (非同期) 呼び出しは、翻訳を含む対象ファイルを生成してダウンロードする非同期リクエストを開始します。レスポンス内に対象ファイルを直接提供するのではなく、次の呼び出しに必要な asyncRequestId を提供します。
-
メソッド
PUT
-
リクエストURL
https://cloud.memsource.com/web/api2/v2/projects/KmtNyVlz1skQd2aMVEipp7/jobs/dOYgeXzAdAbj4xFjuEVZP2/targetFile
-
レスポンス
非同期リクエストID
レスポンスからの asyncRequestID を使用して、非同期リクエストを取得 します。リクエストが完了しているか確認します。非同期リクエストが完了したら、非同期リクエストに基づいて対象ファイルをダウンロード 呼び出しを使用して対象ファイルをダウンロードできます。asyncRequestId は一度だけ使用できます。ダウンロードが開始されると、asyncRequestId は今後の使用のために無効になります。
-
メソッド
GET
-
リクエストURL
https://cloud.memsource.com/web/api2/v2/projects/KmtNyVlz1skQd2aMVEipp7/jobs/dOYgeXzAdAbj4xFjuEVZP2/downloadTargetFile/1291716982
-
レスポンス
完了したファイル自体のバイナリレスポンス
プロジェクトを完了に設定
プロジェクト内のジョブが完了したら、プロジェクトステータスを編集 呼び出しを使用して、必須パラメータ projectUid と status を指定し、プロジェクト全体のステータスを 完了 に変更します。この変更は手動ですが、プロジェクトステータス自動化 が使用されると、ステータスは自動的に変更されます。ウェブフックを待機し、受信したコールバックに基づいて他のアクションを開始することも可能です。
-
メソッド
POST
-
リクエストURL
https://cloud.memsource.com/web/api2/v1/projects/KmtNyVlz1skQd2aMVEipp7/setStatus
-
リクエストボディ
{ "status": "COMPLETED"} -
レスポンス
空欄(ステータス204:コンテンツなし)