# カスタム トランスフォーマーを使用した GitHub Actions Importer の拡張

GitHub Actions Importer では、組み込みのマッピングを拡張できます。

## カスタム トランスフォーマーについて

GitHub Actions Importer では、カスタム トランスフォーマーを作成することで組み込みのマッピングを拡張できます。 カスタム トランスフォーマーを使うと、次のことができます。

* GitHub Actions Importer が自動的に変換しない項目を変換したり、項目の変換方法を変更したりする。 詳細については、「[項目のカスタム トランスフォーマーの作成](#creating-custom-transformers-for-items)」を参照してください。
* ランナーへの参照を変えて、異なるランナーラベルを使用する。 詳細については、「[ランナーのカスタム トランスフォーマーの作成](#creating-custom-transformers-for-runners)」を参照してください。
* 環境変数の値を既存のパイプラインから GitHub Actions ワークフローに変換する。 詳細については、「[環境変数のカスタム トランスフォーマーの作成](#creating-custom-transformers-for-environment-variables)」を参照してください。

## GitHub Actions Importer でのカスタム トランスフォーマーの使用

カスタム トランスフォーマーには、GitHub Actions Importer がプラグイン、タスク、ランナーのラベル、または環境変数を GitHub Actions で動作するように変換するために使えるマッピング ロジックが含まれています。 カスタム トランスフォーマーは、Ruby に基づいて構築されるドメイン固有言語 (DSL) を使って記述され、`.rb` ファイル拡張子を持つファイル内で定義されます。

```
          `--custom-transformers` CLI オプションを使うと、`audit`、`dry-run`、`migrate` コマンドで使うカスタム トランスフォーマー ファイルを指定できます。
```

たとえば、`transformers.rb` という名前のファイルにカスタム トランスフォーマーが定義されている場合は、次のコマンドを使うことでそれらを GitHub Actions Importer で使用できます。

```shell
gh actions-importer ... --custom-transformers transformers.rb
```

または、glob パターン構文を使って、複数のカスタム トランスフォーマー ファイルを指定することもできます。 たとえば、`transformers` という名前のディレクトリ内に複数のカスタム トランスフォーマー ファイルがある場合は、次のコマンドを使ってそれらすべてを GitHub Actions Importer に指定できます。

```shell
gh actions-importer ... --custom-transformers transformers/*.rb
```

> \[!NOTE]
> カスタム トランスフォーマーを使う場合、そのカスタム トランスフォーマーのファイルは、`gh actions-importer` コマンドの実行元と同じディレクトリ、またはサブディレクトリ内に存在している必要があります。

## アイテムのカスタム トランスフォーマーの作成

既存のビルド ステップまたはトリガーを、GitHub Actions Importer でそれに相当するものに変換するときに GitHub Actions が使う、カスタム トランスフォーマーを作成できます。 これは、次の場合に特に便利です。

* GitHub Actions Importer が自動的に項目を変換しない。
* GitHub Actions Importer による項目の変換方法を変更したい。
* 既存のパイプラインでカスタムまたは独自の拡張機能が使用されており (Jenkins の共有ライブラリなど)、これらのステップが GitHub Actions でどのように機能するかを定義する必要がある。

GitHub Actions Importer では、Ruby に基づいて構築される DSL を使って定義されたカスタム トランスフォーマーが使用されます。 ビルド ステップとトリガー用のカスタム トランスフォーマーを作成するには:

* 各カスタム トランスフォーマー ファイルには、少なくとも 1 つの `transform` メソッドを含める必要があります。
* 各 `transform` メソッドは、`Hash`、`Hash` の配列、または `nil` を返す必要があります。 この戻り値は、YAML で定義されているアクションに対応します。 アクションの詳細については、「[GitHub Actionsについて](/ja/actions/learn-github-actions/understanding-github-actions)」を参照してください。

### ビルド ステップ用のカスタム トランスフォーマーの例

次の例では、"buildJavaScriptApp" 識別子を使うビルド ステップを変換して、さまざまな `npm` コマンドを実行します。

```ruby copy
transform "buildJavaScriptApp" do |item|
  command = ["build", "package", "deploy"].map do |script|
    "npm run #{script}"
  end

  {
    name: "build javascript app",
    run: command.join("\n")
  }
end
```

上記の例では、次の GitHub Actions ワークフロー ステップが生成されます。 これは、変換済みの `buildJavaScriptApp` 識別子を持っていたビルド ステップで構成されています。

```yaml
- name: build javascript app
  run: |
    npm run build
    npm run package
    npm run deploy
```

```
          `transform` メソッドでは、ソース CI/CD インスタンスのビルド ステップの識別子を引数で使用します。 この例では、識別子は `buildJavaScriptLibrary` です。 コンマ区切りの値を使って、複数の識別子を `transform` メソッドに渡すこともできます。 たとえば、「 `transform "buildJavaScriptApp", "buildTypeScriptApp" { |item| ... }` 」のように入力します。
```

> \[!NOTE]

```
          `item` のデータ構造は、CI/CD プラットフォームと変換される項目の種類によって異なります。
```

## ランナーのカスタム トランスフォーマーの作成

ソース CI/CD インスタンス内のランナーと、それらに相当する GitHub Actions のランナー間のマッピングをカスタマイズできます。

GitHub Actions Importer では、Ruby に基づいて構築される DSL を使って定義されたカスタム トランスフォーマーが使用されます。 ランナー用のカスタムトランスフォーマーを作成するには:

* カスタム トランスフォーマー ファイルには、少なくとも 1 つの `runner` メソッドを含める必要があります。
* `runner` メソッドには 2 つのパラメーターを指定できます。 最初のパラメーターはソース CI/CD インスタンスのランナーのラベルで、2 番目のパラメーターは対応する GitHub Actions のランナーのラベルです。 GitHub Actions ランナーについては、「[GitHub ホステッド ランナー](/ja/actions/using-github-hosted-runners/about-github-hosted-runners#supported-runners-and-hardware-resources)」を参照してください。

### ランナー用カスタムトランスフォーマーの例

次の例は、1 つのランナー ラベルを、結果のワークフローで 1 つの GitHub Actions のランナー ラベルに変換する `runner` メソッドを示しています。

```ruby copy
runner "linux", "ubuntu-latest"
```

また、`runner` メソッドを使って、1 つのランナー ラベルを、結果のワークフローで GitHub Actions の複数のランナー ラベルに変換することもできます。

```ruby copy
runner "big-agent", ["self-hosted", "xl", "linux"]
```

GitHub Actions Importer は、ランナー ラベルをできるだけ最適にマップしようとします。 それができない場合は、`ubuntu-latest` ランナー ラベルが既定値として使用されます。
`runner` メソッドで特別なキーワードを使うと、この既定値を制御できます。 たとえば、次のカスタム トランスフォーマーでは、`macos-latest` ではなく `ubuntu-latest` を既定のランナーとして使うように GitHub Actions Importer に指示します。

```ruby copy
runner :default, "macos-latest"
```

## 環境変数のカスタム トランスフォーマーの作成

ソース CI/CD パイプライン内の環境変数から、それらの GitHub Actions での値へのマッピングをカスタマイズできます。

GitHub Actions Importer では、Ruby に基づいて構築される DSL を使って定義されたカスタム トランスフォーマーが使用されます。 環境変数のカスタム トランスフォーマーを作成するには:

* カスタム トランスフォーマー ファイルには、少なくとも 1 つの `env` メソッドを含める必要があります。
* `env` メソッドには 2 つのパラメーターを指定できます。 最初のパラメーターは元のパイプラインの環境変数の名前で、2 番目のパラメーターは GitHub Actions 用に更新された環境変数の値です。 GitHub Actions 環境変数の詳細については、「[変数に情報を格納する](/ja/actions/learn-github-actions/variables)」を参照してください。

### 環境変数のカスタム トランスフォーマーの例

環境変数をマップするカスタム トランスフォーマーを設定するには、いくつかの方法があります。

* 次の例では、`OCTO` という名前の既存の環境変数の値を、パイプラインの変換時に `CAT` に設定します。

  ```ruby copy
  env "OCTO", "CAT"
  ```

  特定の環境変数の出現箇所をすべて削除して、GitHub Actions ワークフローに変換されないようにすることもできます。 次の例では、`MONA_LISA` という名前のすべての環境変数を削除します。

  ```ruby copy
  env "MONA_LISA", nil
  ```

* 既存の環境変数をシークレットにマップすることもできます。 たとえば、次の `env` メソッドは、`MONALISA` という名前の環境変数を `OCTOCAT` という名前のシークレットにマップします。

  ```ruby copy
  env "MONALISA", secret("OCTOCAT")
  ```

  これにより、変換されたワークフローでは `OCTOCAT` という名前のシークレットへの参照が設定されます。 シークレットを機能させるには、GitHub リポジトリにシークレットを作成する必要があります。 詳しくは、「[GitHub Actions でのシークレットの使用](/ja/actions/security-guides/using-secrets-in-github-actions#creating-secrets-for-a-repository)」をご覧ください。

* 正規表現を使って、複数の環境変数の値を一度に更新することもできます。 たとえば、次のカスタム トランスフォーマーでは、変換されたワークフローからすべての環境変数を削除します。

  ```ruby copy
  env /.*/, nil
  ```

  次の例では、正規表現の一致グループを使って、環境変数の値を動的に生成されたシークレットに変換します。

  ```ruby copy
  env /^(.+)_SSH_KEY/, secret("%s_SSH_KEY)
  ```

  > \[!NOTE]
  > 各 `env` メソッドを定義する順序は、正規表現を使う場合に重要となります。 環境変数名と一致する最初の `env` トランスフォーマーは、後続の `env` メソッドよりも優先されます。 最も具体的な環境変数のトランスフォーマーを最初に定義する必要があります。

## 法務上の通知

MIT ライセンスのもとで <https://github.com/github/gh-actions-importer/> から一部を引用しています。

```text
MIT License

Copyright (c) 2022 GitHub

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
```