ユーザーに従業員のアクセス許可があるかどうかをチェックしたいと思います。PHPの関数に対して論理エラーを返すベストプラクティスは何ですか
function hasEmployeePermission($employeeID, $userKey)
{
$usersID = DB::table('users')->where('key', $userKey)->value('id');
if($userID != null) {
$employeeID = DB::table('employees')->where('user_id', $userID)->value('id');
if($mployeeID != null)
return true;
else
return false;
}
return false;
}
私は、戻り値は例外を投げるような、より表現力になりたいです。論理的なエラーで例外を投げるのはベストプラクティスではないと思います。私はエラーを返すようにコードを修正する方法を知りたがりません。
'リターン "のエラーメッセージ";'? error_logでレポートしたい場合は、returnの前に 'error_log(" ERROR MESSAGE ");を実行することもできます。そして、あなたはまた、何のリターンもせずにページを殺すことができます。 'die(" ERROR MESSAGE ");' – GrumpyCrouton
'hasEmployeePermission'はyes/noのように聞こえるので、ブール値はおそらくあなたがこの関数を返すことができる最も表現力のあるものです。間違った引数が渡された場合、それは例外です – apokryfos
@GrumpyCroutonそれは危険でしょうか?コーダーが(hasEmployeeAccess())を使用する場合、エラー状況を渡します。 –