Files
lucent-laravel/src/Record/RecordRepo.php
T

64 lines
1.4 KiB
PHP
Raw Normal View History

2023-10-02 23:10:49 +03:00
<?php
namespace Lucent\Record;
use Illuminate\Support\Facades\DB;
class RecordRepo
{
2023-10-06 18:47:50 +03:00
public function __construct()
{
}
2023-10-02 23:10:49 +03:00
public static function create(Record $record): void
{
$recordToDB = $record->toDB();
2023-10-22 16:09:36 +03:00
2023-10-02 23:10:49 +03:00
DB::table("records")->insert($recordToDB);
}
/**
* @param array<string> $ids
*/
2023-10-04 13:32:30 +03:00
public static function updateStatusBulk(Status $status, array $ids): void
2023-10-02 23:10:49 +03:00
{
DB::table("records")->whereIn("id", $ids)->update([
2023-10-04 13:32:30 +03:00
'status' => $status->value
2023-10-02 23:10:49 +03:00
]);
}
public static function update(Record $record): void
{
$recordToDB = $record->toDB();
DB::table("records")->where("id", $record->id)->update($recordToDB);
}
/**
* @param string[] $ids
*/
2023-10-06 18:47:50 +03:00
public function deleteMany(
2023-10-02 23:10:49 +03:00
array $ids,
): void
{
2023-10-15 19:14:07 +03:00
DB::table("records")->whereIn("id", $ids)->delete();
2023-10-02 23:10:49 +03:00
DB::table("edges")->whereIn("source", $ids)->delete();
DB::table("edges")->whereIn("target", $ids)->delete();
DB::table("revisions")->whereIn("recordId", $ids)->delete();
}
2023-10-15 23:40:34 +03:00
public function deleteTrashedBySchema(
string $schemaName,
): void
{
$ids = DB::table("records")
->where("schema", $schemaName)
->where("status", Status::TRASHED->value)
->get()->pluck("id")->toArray();
$this->deleteMany($ids);
}
2023-10-02 23:10:49 +03:00
}