Backport(バックポート) #4385
完了Bug(バグ) #3510: opConfig::get() の $default に null 以外を指定すると sns_config.yml のデフォルト値が使用されない
opConfig::get() の $default に null 以外を指定すると sns_config.yml のデフォルト値が使用されない
100%
説明
Overview (現象)¶
sns_config.yml には下記のようにデフォルト値を設定する項目があり、例えば opConfig::get('sns_name')
とした場合に sns_config テーブルに該当する値が存在しない場合は 'MySNS'
が返るようになっている。また、sns_config.yml でデフォルト値が定義されていない項目については opConfig::get() の第二引数 $default の値が返る。
general:
sns_name:
Name: "sns_name"
Caption: "SNS名"
FormType: "input"
ValueType: "text"
Default: "MySNS"
IsRequired: true
しかし opConfig::get() の第二引数 $default に null 以外の値を指定すると、sns_config テーブルに存在しない設定項目について sns_config.yml に記述されている Default の値は無視され $default の値が返ってしまう。
Causes (原因)¶
public static function get($name, $default = null)
{
$setting = self::getConfigurationSetting();
$result = null;
$result = Doctrine::getTable('SnsConfig')->get($name, $default);
if (isset($setting[$name]))
{
if (is_null($result))
{
$result = self::getDefaultValue($name);
}
}
return $result;
}
SnsConfigTable::get() の第二引数に $default を指定しているため、sns_config テーブル内に該当するレコードが存在しない場合に is_null($result)
が false となり、$result が sns_config から取得された値なのか区別ができなくなってしまうことが原因。
Way to fix (修正内容)¶
SnsConfigTable::get() の第二引数には null を指定し、最後の return $result;
の箇所で $default を使用するか否かの判定を行う。
kaoru n さんが3年以上前に更新
- ステータス を New(新規) から Pending Review(レビュー待ち) に変更
- 進捗率 を 0 から 50 に変更
https://github.com/openpne/OpenPNE3/pull/639
にてプルリクエストしました
Rimpei Ogawa さんが3年以上前に更新
- ステータス を Pending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
- 進捗率 を 50 から 70 に変更