You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LuticateUsersDataAccess.php 1.0KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. <?php
  2. namespace Luticate\Auth\DataAccess;
  3. use Luticate\Utils\LuDataAccess;
  4. use Luticate\Auth\DataAccess\Models\LuticateUsers;
  5. use Luticate\Auth\DBO\LuticateUsersDbo;
  6. class LuticateUsersDataAccess extends LuDataAccess {
  7. protected static function getModel()
  8. {
  9. return new LuticateUsers();
  10. }
  11. protected static function getOrderBy()
  12. {
  13. return array(array("username", "ASC"));
  14. }
  15. protected static function getQueryPredicate($query)
  16. {
  17. return array(array("username", "ilike", "%" . $query . "%", "or"),
  18. array("firstname", "ilike", "%" . $query . "%", "or"),
  19. array("lastname", "ilike", "%" . $query . "%", "or"));
  20. }
  21. /**
  22. * @param $username string
  23. * @return LuticateUsersDbo|null
  24. */
  25. public static function getByUsernameOrEmail($username)
  26. {
  27. $user = LuticateUsers::where("username", "=", $username)->orWhere("email", "=", $username)->first();
  28. if (is_null($user))
  29. return null;
  30. return $user->toDbo();
  31. }
  32. }