gwsn / sharepoint-sdk
Connect to sharepoint drive with PHP
Installs: 11 510
Dependents: 1
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 7
Open Issues: 0
Requires
- php: ^8.0
- guzzlehttp/guzzle: ^7.4
Requires (Dev)
- phpunit/phpunit: ^9.5
README
Sharepoint SDK to use Sharepoint as filestorage.
For the Flysystem adapter (Symfony and Laravel) see the flysystem package: gwsn/flysystem-sharepoint-adapter
Installation
You can install the package via composer:
composer require gwsn/sharepoint-sdk
First configuration to start usage
You need to request a new clientId and clientSecret for a new application on Azure.
-
Go to
Azure portal
https://portal.azure.com -
Go to
Azure Active Directory
-
Go to
App registrations
-
Click on
new Registration
and follow the wizard.
(give it a name like mine is 'gwsn-sharepoint-connector' and make a decision on the supported accounts, single tenant should be enough but this depends on your organisation) -
When created the application is created write down the following details
-
'Application (client) id', this will be your
$clientId
-
'Directory (tenant) id', this will be your
$tenantId
-
Then we go in the menu to the
API permissions
to set the permissions that are required -
The click on
Add a permission
and add the following permissions:
Microsoft Graph:- Files.ReadWrite.All
- Sites.ReadWrite.All
- User.Read
-
Click on the
Grant admin consent for ...Company...
-
Go in the menu to
Certificates & secrets
-
Click on
new client secret
-
Give it a description and expiry date and the value will be your
$clientSecret
-
The last parameter will be the sharepoint 'slug', this is part of the url of the sharepoint site what you want to use and creation of sharepoint site is out of scope of this readme.
When you sharepoint url is likehttps://{tenant}.sharepoint.com/sites/{site-slug}/Shared%20Documents/Forms/AllItems.aspx
You need to set the$sharepointSite
as{site-slug}
Example:
- Sharepoint site url:
https://GWSN.sharepoint.com/sites/gwsn-documents-store/Shared%20Documents/Forms/AllItems.aspx
- Sharepoint site variable:
$sharepointSite = 'gwsn-documents-store'
- Sharepoint site url:
Basic usage with the flysystem adapter (preferred way!)
use GWSN\FlysystemSharepoint\FlysystemSharepointAdapter; use GWSN\FlysystemSharepoint\SharepointConnector; use League\Flysystem\Filesystem; $tenantId = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'; $clientId = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'; $clientSecret = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; $sharepointSite = 'your-path-to-your-site'; $connector = new SharepointConnector($tenantId, $clientId, $clientSecret, $sharepointSite); $prefix = '/test'; // optional $adapter = new FlysystemSharepointAdapter($connector, $prefix); $flysystem = new Filesystem($adapter);
Basic needs to be able to use the folder|drive|file service
use GWSN\Microsoft\Authentication\AuthenticationService; use GWSN\Microsoft\Drive\DriveService; use GWSN\Microsoft\Drive\FileService; use GWSN\Microsoft\Drive\FolderService; use GWSN\Microsoft\Sharepoint\SharepointService; // Not needed if you use a framework with dependency injection ! require dirname(dirname(__DIR__)) . '/vendor/autoload.php'; $tenantId = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'; $clientId = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx'; $clientSecret = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; $sharepointSite = 'your-path-to-your-site'; // Login into MS oauth and fetch new access token // In real application please save the access token and use it until it expires $authService = new AuthenticationService(); $accessToken = $authService->getAccessToken($tenantId, $clientId, $clientSecret);
Usage for managing for Sharepoint drives
include the basic usage and add the following code
// Initialize the drive $spDrive = new DriveService($accessToken); $driveId = $spDrive->requestDriveId($siteId); $spDrive->setDriveId($driveId); // Check if Resource exists try { $result = $spDrive->checkResourceExists('/test'); var_dump($result); $result = $spDrive->checkResourceExists('/testDoc.docx'); var_dump($result); } catch (\Exception $exception) { var_dump($exception->getMessage()); } // move file /test.txt to folder /test and rename it to testje.txt $result = $spFileService->moveFile('/test.txt', '/test', 'testje.txt'); // check if it still exists $result = $spDrive->checkResourceExists('/test.txt'); var_dump($result); // check if new file exists $result = $spDrive->checkResourceExists('/test/testje.txt'); var_dump($result);
Usage for managing Sharepoint folders
include the basic usage and add the following code
try { // Initialize the drive $spDrive = new DriveService($accessToken); $driveId = $spDrive->requestDriveId($siteId); $spDrive->setDriveId($driveId); // Create the folderService $spFolderService = new FolderService($accessToken, $driveId); // Get files from sharepoint folder $listRootDirResult = $spFolderService->requestFolderItems('/'); // Check if Folder exists $spFolderService->checkFolderExists('/test'); // Get files from sharepoint sub folder $listRootDirResult = $spFolderService->requestFolderItems('/test'); // Get Folder from sharepoint $spFolderService->createFolderRecursive('/dummy/test'); // Delete Folder from sharepoint we just created $spFolderService->deleteFolder('/dummy/test'); $spFolderService->deleteFolder('/dummy'); // Check if Folder exists while its a file try { $result = $spFolderService->checkFolderExists('/testDoc.docx'); var_dump($result); } catch (\Exception $exception) { var_dump($exception->getMessage()); } } catch (\Exception $exception) { var_dump($exception->getMessage()); }
Usage for files in Sharepoint drives
include the basic usage and add the following code
// FileService $spFileService = new FileService($accessToken, $driveId); // write file to directory $result = $spFileService->writeFile('/test.txt', 'testContent'); var_dump(isset($result['id'])); // read file from directory $content = $spFileService->readFile('/test.txt'); var_dump(($content === 'testContent')); // write file to directory $result = $spFileService->writeFile('/test/docje.txt', 'testContent'); var_dump(isset($result['id'])); // read file from directory $content = $spFileService->readFile('/test/docje.txt'); var_dump(($content === 'testContent')); // move file $result = $spFileService->moveFile('/test.txt', '/test', 'testje.txt'); $result = $spDrive->checkResourceExists('/test.txt'); var_dump($result); $result = $spDrive->checkResourceExists('/test/testje.txt'); var_dump($result); // copy file $result = $spFileService->copyFile('/test/testje.txt', '/', 'toBeDeleted.txt'); var_dump($result); // copy dir $result = $spFileService->copyFile('/test', '/test2'); var_dump($result); // delete file from directory $content = $spFileService->deleteFile('/test/testje.txt'); var_dump($content); $content = $spFileService->deleteFile('/test/docje.txt'); var_dump($content); $content = $spFileService->deleteFile('/toBeDeleted.txt'); var_dump($content); $content = $spFileService->deleteFile('/test.txt'); var_dump($content);
Testing
$ composer run-script test
Security
If you discover any security related issues, please email info@gwsn.nl instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.