mirror of
https://github.com/jonathan-martz/pocketbase-php-sdk.git
synced 2026-04-03 07:27:42 +00:00
add logic to auth as admin
This commit is contained in:
@@ -6,6 +6,7 @@ class Collection
|
|||||||
{
|
{
|
||||||
private string $collection;
|
private string $collection;
|
||||||
private string $url;
|
private string $url;
|
||||||
|
private static string $token = '';
|
||||||
|
|
||||||
|
|
||||||
public function __construct(string $url, string $collection)
|
public function __construct(string $url, string $collection)
|
||||||
@@ -28,11 +29,44 @@ class Collection
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create(array $bodyParams = [], array $queryParams = []){
|
public function create(array $bodyParams = [],array $queryParams = []){
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
if(self::$token != ''){
|
||||||
|
$headers = array(
|
||||||
|
'Content-Type:application/json',
|
||||||
|
'Authorization: '.self::$token
|
||||||
|
);
|
||||||
|
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
|
||||||
}
|
}
|
||||||
public function update(string $recordId, array $bodyParams = [],array $queryParams = []){
|
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $this->url . "/api/collections/".$this->collection."/records");
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($bodyParams));
|
||||||
|
$output = curl_exec($ch);
|
||||||
|
var_dump($output);
|
||||||
|
curl_close($ch);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update(string $recordId, array $bodyParams = [],array $queryParams = []){
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
if(self::$token != ''){
|
||||||
|
$headers = array(
|
||||||
|
'Content-Type:application/json',
|
||||||
|
'Authorization: '.self::$token
|
||||||
|
);
|
||||||
|
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $this->url . "/api/collections/".$this->collection."/records/".$recordId);
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PATCH');
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($bodyParams));
|
||||||
|
$output = curl_exec($ch);
|
||||||
|
var_dump($output);
|
||||||
|
curl_close($ch);
|
||||||
}
|
}
|
||||||
public function delete(string $recordId, array $queryParams = []){
|
public function delete(string $recordId, array $queryParams = []){
|
||||||
|
|
||||||
@@ -42,9 +76,20 @@ class Collection
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function authWithPassword()
|
public function authWithPassword(string $email, string $password)
|
||||||
{
|
{
|
||||||
$data = json_decode($this->json, JSON_FORCE_OBJECT);
|
$ch = curl_init();
|
||||||
var_dump($data);
|
|
||||||
|
$bodyParams['identity'] = $email;
|
||||||
|
$bodyParams['password'] = $password;
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $this->url . "/api/admins/auth-with-password");
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, $bodyParams);
|
||||||
|
$output = curl_exec($ch);
|
||||||
|
$json = json_decode($output, JSON_FORCE_OBJECT);
|
||||||
|
self::$token = $json['token'];
|
||||||
|
curl_close($ch);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user