123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- <?php
-
- /**
- * AUTO GENERATED BY LUTICATE GENERATOR
- * ANY CHANGES WILL BE OVERWRITTEN
- */
-
- namespace App\Http\DataAccess\SP;
-
- use Luticate\Utils\LuSpDbo;
- use Luticate\Utils\LuMultipleDbo;
- use Luticate\Utils\LuStringUtils;
- use Illuminate\Support\Facades\DB;
-
- class SpGetDomainRecords extends LuSpDbo {
-
- /**
- * @param $dam
- * @return \App\Http\DataAccess\SP\SpGetDomainRecords|null
- */
- protected static function damToDbo($dam)
- {
- if (is_null($dam))
- return null;
- $dbo = new SpGetDomainRecords();
-
- $dbo->setRecords(LuStringUtils::convertJsonString($dam->records));
-
- return $dbo;
- }
-
-
- /**
- * @param $domain_id integer
- * @param $query string
- * @return \App\Http\DataAccess\SP\SpGetDomainRecords[];
- */
- public static function execute($domain_id, $query)
- {
- $values = DB::select('SELECT to_json(data.records) AS records FROM sp_get_domain_records(:domain_id, :query) data', array(":domain_id" => $domain_id, ":query" => $query));
- $dboValues = array();
- foreach ($values as $value)
- $dboValues[] = self::damToDbo($value);
- return $dboValues;
- }
-
- /**
- * @param $domain_id integer
- * @param $query string
- * @param $page int The page number, 0 based
- * @param $perPage int The number of items per page
- * @return \Luticate\Utils\LuMultipleDbo;
- */
- public static function getMultipleJson($domain_id, $query, $page, $perPage)
- {
- $values = DB::select('SELECT (SELECT count(*) FROM sp_get_domain_records(:domain_id, :query)) as count, (SELECT json_agg(q) FROM (SELECT * FROM sp_get_domain_records(:domain_id, :query) OFFSET (:page::int * :perPage::int) LIMIT :perPage) q) as data',
- array(":domain_id" => $domain_id, ":query" => $query, ":page" => $page, ":perPage" => $perPage));
- $value = $values[0];
- if (is_null($value->data))
- {
- $value->data = '[]';
- }
- $data = LuStringUtils::convertJsonString($value->data);
- return new LuMultipleDbo($value->count, $data);
- }
-
- public function jsonSerialize()
- {
- return array(
- "Records" => $this->_records
- );
- }
-
- public static function jsonDeserialize($json)
- {
- $dbo = new SpGetDomainRecords();
- if (isset($json["Records"])) {
- $dbo->setRecords($json["Records"]);
- }
- return $dbo;
- }
-
- public static function generateSample()
- {
- $dbo = new SpGetDomainRecords();
- $dbo->setRecords("sample string");
- return $dbo;
- }
-
-
- /**
- * @var USER-DEFINED
- */
- protected $_records;
- public function getRecords()
- {
- return $this->_records;
- }
- public function setRecords($value)
- {
- $this->_records = $value;
- }
- }
|