mirror of
				https://github.com/nextcloud/passman.git
				synced 2025-10-25 12:56:04 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			96 lines
		
	
	
		
			No EOL
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			No EOL
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Created by PhpStorm.
 | |
|  * User: wolfi
 | |
|  * Date: 24/09/16
 | |
|  * Time: 14:20
 | |
|  * This file is part of passman, licensed under AGPLv3
 | |
|  */
 | |
| 
 | |
| namespace OCA\Passman\Db;
 | |
| 
 | |
| 
 | |
| use OCP\AppFramework\Db\Mapper;
 | |
| use OCP\IDBConnection;
 | |
| use OCP\IUser;
 | |
| use OCA\Passman\Utility\Utils;
 | |
| 
 | |
| class SharingACLMapper extends Mapper {
 | |
|     const TABLE_NAME = '*PREFIX*passman_sharing_acl';
 | |
| 
 | |
|     public function __construct(IDBConnection $db, Utils $utils) {
 | |
|         parent::__construct($db, 'passman_sharing_acl');
 | |
|         $this->utils = $utils;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Gets all the credential data for the given user
 | |
|      * @param $userId
 | |
|      * @param $item_guid
 | |
|      * @return SharingACL[]
 | |
|      */
 | |
|     public function getCredentialPermissions(IUser $userId, $item_guid){
 | |
|         $sql = "SELECT * FROM ". self::TABLE_NAME ." WHERE user_id = ? AND item_guid = ?";
 | |
| 
 | |
|         return $this->findEntities($sql, [$userId, $item_guid]);
 | |
|     }
 | |
| 
 | |
|     public function createACLEntry(SharingACL $acl){
 | |
|         return $this->insert($acl);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Gets the currently accepted share requests from the given user for the given vault guid
 | |
|      * @param $user_id
 | |
|      * @param $vault_id
 | |
|      * @return SharingACL[]
 | |
|      */
 | |
|     public function getVaultEntries($user_id, $vault_id) {
 | |
|         $q = "SELECT * FROM ". self::TABLE_NAME ." WHERE user_id = ? AND vault_guid = ?";
 | |
|         return $this->findEntities($q, [$user_id, $vault_id]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Gets the acl for a given item guid
 | |
|      * @param $user_id
 | |
|      * @param $item_guid
 | |
|      * @return SharingACL
 | |
|      */
 | |
|     public function getItemACL($user_id, $item_guid) {
 | |
|         $q = "SELECT * FROM " . self::TABLE_NAME . " WHERE item_guid = ? AND ";
 | |
|         $filter = [$item_guid];
 | |
|         if ($user_id === null){
 | |
|             $q .= 'user_id is null';
 | |
|         }
 | |
|         else {
 | |
|             $q .= 'user_id = ? ';
 | |
|             $filter[] = $user_id;
 | |
|         }
 | |
|         return $this->findEntity($q, $filter);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Update the acl for a given item guid
 | |
|      * @param $user_id
 | |
|      * @param $item_guid
 | |
|      * @return SharingACL
 | |
|      */
 | |
|     public function updateCredentialACL(SharingACL $sharingACL) {
 | |
|         return $this->update($sharingACL);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Gets the currently accepted share requests from the given user for the given vault guid
 | |
|      * @param $user_id
 | |
|      * @param $vault_id
 | |
|      * @return SharingACL[]
 | |
|      */
 | |
|     public function getCredentialAclList($item_guid) {
 | |
|         $q = "SELECT * FROM ". self::TABLE_NAME ." WHERE item_guid = ?";
 | |
|         return $this->findEntities($q, [$item_guid]);
 | |
|     }
 | |
| 
 | |
|     public function deleteShareACL(SharingACL $ACL){
 | |
|     	return $this->delete($ACL);
 | |
| 	}
 | |
| } |