2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

GASでもハードコーディングは避けよう(自戒)

Posted at

プログラミングってなんの言語からはじめるといいですか?という質問に私がお勧めしているのはGASなのですが(業界的にはニッチ)、環境構築の手間がなくてとっつきやすい分、思わぬ失敗も経験しやすいと思うんですよね。
GASをお勧めする理由としてはまた別に記事にしようと思います。

思わぬ失敗として思いつくのが、ハードコーディング(重要な情報を直接コードに書いちゃう。)

const token = "token情報をここにペースト"

みたいな説明の記事ってよく見ると思うんですけど、ダブルクォーテーションマークは付けるの?付けないの?といった疑問も初心者(の頃の僕)は抱いていました。
それに、よっしゃこれで動くコード作れた!commitしてpushしよ!ってなって勢いのままtoken情報載ったコードをGithubに挙げてしまうことも経験しています(あくまで練習用のプロジェクトだけど)。

一般的に、重要な情報は直接コードに書き込まず、例えばenvファイルに切り出してgithubやデプロイ先には上げないようにするというのが言われますね。
でもGASだとenvファイルとして役割を持つ者がなかったり、別ファイルからのインポートという概念がないため(ファイル分けても自動的に変数や関数がまとめられて実行される)、ちょっとした工夫が必要になります。

その工夫として用意されているのが、PropertiesServiceクラスです。
基本的には、エディタの設定画面からスクリプトプロパティを保存して呼び出すことが推奨です。

1キャプチャ.PNG

設定から下の方にスクロールしていくと見つかります。
2キャプチャ.PNG

ここに自分で値を用意していくこともできますが、プログラムによるsetも可能です。
例えば、スプレッドシートでIDとかTokenとかを書いてもらうことを想定しましょう。任意のユーザーが元のファイルをコピーして、C2セルに情報を入力すれば、その情報に基づいてプログラムが実行できるといった具合です。

キャプチャ.PNG

この時、GASエディタからスクリプトプロパティに値をsetするにはこのようなコードになります。

// スプレッドシートのセルから値を取得してGASのスクリプトプロパティに保存する
function setIdData(){
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const targetSheet = ss.getActiveSheet();
  
  const tokenData = targetSheet.getRange(2,3).getValue();
  PropertiesService.getScriptProperties().setProperty("token", tokenData);
  return
}

これを実行することで、
3キャプチャ.PNG
こんな感じでプロパティと値が保存されるようになります。setしたらスプレッドシートの方は「入力済み」とか値を削除してしまうとSecurity的には安心ですよね。

ちなみに開発側だと以下の画像のように自分で登録していくこともできます。
4キャプチャ.PNG

じゃあ無事に登録したら今度はどうやって呼び出して使うねんってことでGetしていきます。
一つの値を取得するにはこんな感じ。実行ログもスクショしてます。
6キャプチャ.PNG

そして複数の値を取得するにはちょっと手間がかかりますがこんな感じ。
7キャプチャ.PNG
取得したデータはそれぞれこんな感じになります。

keys:
[
  "api-key",
  "token"
]

properties:
{
  "token": "tesutoyounopuropathidesu-tokuntokawotukautokinibenri!",
  "api-key": "apinojouhoumodaijidayone"
}

propertiesArray:
[
  "apinojouhoumodaijidayone",
  "tesutoyounopuropathidesu-tokuntokawotukautokinibenri!"
]

formattedProperties:
[
  {
    "Key": "api-key",
    "Value": "apinojouhoumodaijidayone"
  },
  {
    "Key": "token",
    "Value": "tesutoyounopuropathidesu-tokuntokawotukautokinibenri!"
  }
]

今回の全体コードはこんな感じ。

// スプレッドシートのセルから値を取得してGASのスクリプトプロパティに保存する
function setIdData(){
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const targetSheet = ss.getActiveSheet();
  
  const tokenData = targetSheet.getRange(2,3).getValue();
  PropertiesService.getScriptProperties().setProperty("token", tokenData);
  return
}

// GASのスクリプトプロパティから値を取得して利用する:一つの値
function getIdData(){
  const property = PropertiesService.getScriptProperties().getProperty("token");
  console.log(`property:${property}`)
}

// GASのスクリプトプロパティから値を取得して利用する:複数の値を配列として取得
function getIdDatas(){
  const keys = PropertiesService.getScriptProperties().getKeys() // これは配列として取得する
  const properties = PropertiesService.getScriptProperties().getProperties()  //これはキー・値のオブジェクトとして取得する

  // 値だけの配列にする
  const propertiesArray = keys.map((key) => properties[key]);

  // キー・値ごとの配列にする
  const formattedProperties = keys.map( (key) => ({
    "Key": key,
    "Value": properties[key]
  }))

  console.log(`keys:\n${JSON.stringify(keys, null, 2)}`)
  console.log(`properties:\n${JSON.stringify(properties, null, 2)}`)
  console.log(`propertiesArray:\n${JSON.stringify(propertiesArray, null, 2)}`)
  console.log(`formattedProperties:\n${JSON.stringify(formattedProperties, null, 2)}`)
}

これで安心安全のGASライフがはじめられますね!

今回のリポジトリ

2
2
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
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?