Görev (Task)
Paket yükleme&kaldırma ve benzeri tüm uzun süren işlemleri arkaplanda çalıştırıp arayüzde çıktıları göstermeyi kolaylaştıran Task(Görev) componentini öğreneceğiz.
Eklentinizde bazı durumlarda uzun süren işlemler yaptırmanız gerekebilir. Bu gibi durumlarda Task componentini kullanabilirsiniz.

Task Soyut Sınıfından Türeyen Bir Sınıf Oluşturmak

  • OOP eklenti klasör yapısında öncelikle app klasöründe Tasks isminde bir klasör oluşturuyoruz ve InstallPackage.php dosyası oluşturuyoruz.
  • Task soyut sınıfındaki değişkenleri yaptıracağımız işe göre override ediyoruz.
1
<?php
2
namespace App\Tasks;
3
4
use Liman\Toolkit\Formatter;
5
use Liman\Toolkit\RemoteTask\Task;
6
7
class InstallPackage extends Task
8
{
9
protected $command = "DEBIAN_FRONTEND=noninteractive apt install @{:package} -qqy";
10
protected $sudoRequired = true;
11
protected $control = "apt\|dpkg";
12
13
public function __construct(array $attributes = []){
14
if(!isset($attributes["package"])){
15
throw new \Exception("Package name is required");
16
}
17
$this->attributes = $attributes;
18
$this->logFile = Formatter::run(
19
"/tmp/install-package-{:package}.txt",
20
["package" => $attributes["package"]]
21
);
22
$this->checkCommand = Formatter::run(
23
"apt list --installed | grep {:package}",
24
["package" => $attributes["package"]]
25
);
26
}
27
}
Copied!
Değişken
Tip
Açıklama
$command
string
Çalıştırılacak komut metni.
$logFile
string
Komutun çıktılarının saklanacağı konum.
$sudoRequired
boolean
Sudo gerekli ise true olmalıdır. (opsiyonel)
$control
string
İşlemin bitip bitmediğini anlamak için gerekli grep kontrol deseni.
$attributes
array
Komut metninde değişken kullandıysanız değişkenlerin değerlerinin tanımlanması gereken dizi. (opsiyonel)
$checkCommand
string
İşlemin başarıyla bitip bitmediğinin kontrolünü sağlayan komut. (opsiyonel)

Görevleri Çalıştırmak

  • Controller içerisinde bir fonksiyon tanımlıyoruz ve routes.php içerisinde gerekli tanımlamaları yapıyoruz.
1
public function installPackage()
2
{
3
validate([
4
'package_name' => 'required|string',
5
]);
6
return respond(
7
view('task', [
8
'tasks' => [
9
0 => [
10
'name' => 'InstallPackage',
11
'attributes' => [
12
'package' => request('package')
13
]
14
]
15
]
16
]),
17
200
18
);
19
}
Copied!
  • Bu fonksiyon geriye task componentini çalıştırmanız için gerekli HTML verisini döndürür.
  • Birden fazla task tasks dizisi içerisinde tanımlanabilir böyle bir durumda görevler kuyruklanır ve sırayla çalıştırılır.

Blade İçerisinde Task Componentinin Kullanımı

  • Tercihe bağlı olarak Görev componenti bir Modal içerisinde gösterilebilir.
1
@component('modal-component',[
2
"id" => "taskModal",
3
"title" => "Görev İşleniyor",
4
])
5
@endcomponent
Copied!
  • Bu şekilde bir modal tanımlanabilir.
1
function installPackage(package_name){
2
showSwal('{{__("Yükleniyor...")}}', 'info');
3
let formData = new FormData();
4
formData.append("package_name", package_name);
5
request("{{API('install_package')}}", formData, function(response){
6
$('#taskModal').find('.modal-body').html(JSON.parse(response).message);
7
$('#taskModal').modal("show");
8
Swal.close();
9
}, function(response){
10
let error = JSON.parse(response);
11
showSwal(error.message, 'error', 2000);
12
});
13
}
Copied!
  • Görevi başlatmak için de bu şekilde javascript ile ajax çağrısı yapılır ve Task modal'ının içerisine eklenir.
Last modified 3mo ago