<?php namespace App\Models; /** * Row in a data table * * @property int $id * @property object|\RowData $data - JSONB, always containing _id */ class Row extends BaseModel { protected $casts = [ 'data' => 'object', ]; protected $guarded = []; public $timestamps = false; public function getRowIdAttribute() { return $this->data->_id; } public function setRowIdAttribute($value) { $this->data->_id = $value; } /** * Allocate a single Global Row ID, application-unique. * * GRIDs are used to uniquely identify existing or proposed new rows, * and are preserved after row modifications, to ensure change proposals have * a clear target. * * @return int */ public static function allocateRowID() { return \DB::selectOne("SELECT nextval('global_row_id_seq') AS rid;")->rid; } /** * Allocate a block of Global Row IDs, application-unique. * * @see Row::allocateRowID() * * @return int[] first and last */ public static function allocateRowIDs($count) { $last = \DB::selectOne("SELECT multi_nextval('global_row_id_seq', ?) AS last_id;", [$count])->last_id; return [$last - $count + 1, $last]; } /** * Allocate a single Global Column ID, application-unique. * * GCIDs are used to uniquely identify existing or proposed new columns, * and are preserved after column modifications, to ensure change proposals have * a clear target. This is the column equivalent of GRID. * * @return int */ public static function allocateColID() { return \DB::selectOne("SELECT nextval('global_column_id_seq') AS cid;")->cid; } /** * Allocate a block of Global Column IDs, application-unique. * * @see Row::allocateColID() * * @return int[] first and last */ public static function allocateColIDs($count) { $last = \DB::selectOne("SELECT multi_nextval('global_column_id_seq', ?) AS last_id;", [$count])->last_id; return [$last - $count + 1, $last]; } }