codebar-ag / laravel-docuware
DocuWare integration with Laravel
Installs: 10 428
Dependents: 0
Suggesters: 0
Security: 0
Stars: 10
Watchers: 4
Forks: 7
Open Issues: 3
Requires
- php: >=8.2
- guzzlehttp/guzzle: ^7.8
- illuminate/contracts: ^11.0
- nesbot/carbon: ^2.72
- saloonphp/cache-plugin: ^3.0
- saloonphp/laravel-plugin: ^3.5
- saloonphp/saloon: ^3.7
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/pint: ^1.14
- orchestra/testbench: ^9.0
- pestphp/pest: ^2.34
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1
- phpstan/phpstan-phpunit: ^1.3
- phpunit/phpunit: ^10.5
- spatie/laravel-ray: ^1.35
- dev-main
- v11.09
- v11.08.1
- v11.08
- v11.07
- v11.06
- v11.05
- v11.04
- v11.03
- v11.0.2
- v11.0.1
- v11.0
- v5.2
- v5.1
- v5.0
- v4.3
- v4.2
- v4.1
- v4.0
- v3.6.4
- v3.6.3
- v3.6.2
- v3.6.1
- v3.6
- v3.5.1
- v3.5
- v3.4.1
- v3.4
- v3.3.0
- v3.2.0
- v3.1.1
- v3.1.0
- v3.0.1
- v2.1.1
- v2.1.0
- v2.0.2
- v2.0.1
- v2.0
- v1.3.0
- v1.2.2
- v1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.0
- 0.7.0
- 0.6.0
- 0.5.0
- 0.4.0
- 0.3.1
- 0.3.0
- 0.2.0
- 0.1.0
- 0.0.0
- dev-dependabot/github_actions/dependabot/fetch-metadata-2.3.0
- dev-feature-updates
- dev-feature-l11-annotations
This package is auto-updated.
Last update: 2025-01-27 22:56:30 UTC
README
This package was developed to give you a quick start to communicate with the DocuWare REST API. It is used to query the most common endpoints.
⚠️ This package is not designed as a replacement of the official DocuWare REST API. See the documentation if you need further functionality. ⚠️
Navigation
- Navigation
- 💡 What is DocuWare?
- 🛠 Requirements
- ⚙️ Installation
- 🏗 Usage
- Getting Started with OAuth
- Getting a new token via Username & Password:
- Getting a new token via Username & Password (Trusted User):
- Available Requests
- Organization
- User Management
- File Cabinets
- General
- Dialogs
- Search
- Get A Specific Document From A File Cabinet
- Get Documents From A File Cabinet
- Most basic example to search for documents.
- Search in multiple file cabinets
- Find results on the next page
- Define the number of results which should be shown per page
- Use the full-text search
- Search documents which are created from the first of march.
- Search documents which are created until the first of april.
- Order the results by field name.
- Search documents filtered to the value.
- Search documents filtered to multiple values.
- You can specify the dialog which should be used.
- You can also combine everything.
- Check In Check Out
- Select Lists
- Upload
- Documents
- Workflow
- Extending the connector (EXAMPLE)
- 🖼 Make encrypted URLs
- 🏋️ Document Index Fields DTO showcase
- 📦 Caching requests
- 💥 Exceptions explained
- ✨ Events
- 🔧 Configuration file
- 🚧 Testing
- 📝 Changelog
- ✏️ Contributing
- 🧑💻 Security Vulnerabilities
- 🙏 Credits
- 🎭 License
💡 What is DocuWare?
DocuWare provides cloud document management and workflow automation software that enables you to digitize, secure and work with business documents, then optimize the processes that power the core of your business.
🛠 Requirements
Version Support
Current Support
⚙️ Installation
You can install the package via composer:
composer require codebar-ag/laravel-docuware
Add the following environment variables to your .env
file:
DOCUWARE_URL=https://domain.docuware.cloud
DOCUWARE_USERNAME=user@domain.test
DOCUWARE_PASSWORD=password
DOCUWARE_PASSPHRASE="passphrase"
With the passphrase we are able to encrypt the URLs.
⚠️ You need to escape backslashes in your passphrase with another backslash:
# ❌ Passphrase contains a backslash and is not escaped: DOCUWARE_PASSPHRASE="a#bcd>2~C1'abc\#" # ✅ We need to escape the backslash with another backslash: DOCUWARE_PASSPHRASE="a#bcd>2~C1'abc\\#"
🏗 Usage
Getting Started with OAuth
This package automatically handles the generation of OAuth token for you and stores them in cache.
Getting a new token via Username & Password:
use CodebarAg\DocuWare\Connectors\DocuWareConnector; use CodebarAg\DocuWare\DTO\Config\ConfigWithCredentials; $connector = new DocuWareConnector( configuration: new ConfigWithCredentials( username: 'username', password: 'password', ) );
Getting a new token via Username & Password (Trusted User):
use CodebarAg\DocuWare\Connectors\DocuWareConnector; use CodebarAg\DocuWare\DTO\Config\ConfigWithCredentialsTrustedUser; $connector = new DocuWareConnector( configuration: new ConfigWithCredentialsTrustedUser( username: 'username', password: 'password', impersonatedUsername: 'impersonatedUsername', ) );
Available Requests
Organization
Get Organization
use CodebarAg\DocuWare\Requests\General\Organization\GetOrganization; $organizations = $this->connector->send(new GetOrganization())->dto();
Get All File Cabinets And Document Trays
use CodebarAg\DocuWare\Requests\General\Organization\GetAllFileCabinetsAndDocumentTrays; $cabinetsAndTrays = $this->connector->send(new GetAllFileCabinetsAndDocumentTrays())->dto();
User Management
Get Users
Get Users
use CodebarAg\DocuWare\Requests\General\UserManagement\GetUsers\GetUsers; $users = $this->connector->send(new GetUsers())->dto();
Get User By Id
use CodebarAg\DocuWare\Requests\General\UserManagement\GetUsers\GetUserById; $user = $this->connector->send(new GetUserById($userId))->dto();
Get Users Of A Role
use CodebarAg\DocuWare\Requests\General\UserManagement\GetUsers\GetUsersOfARole; $users = $this->connector->send(new GetUsersOfARole($roleId))->dto();
Get Users Of A Group
use CodebarAg\DocuWare\Requests\General\UserManagement\GetUsers\GetUsersOfAGroup; $users = $this->connector->send(new GetUsersOfAGroup($groupId))->dto();
Create/Update Users
Create User
use CodebarAg\DocuWare\Requests\General\UserManagement\CreateUpdateUsers\CreateUser; $user = $connector->send(new CreateUser(new User( name: $timestamp.' - Test User', dbName: $timestamp, email: $timestamp.'-test@example.test', password: 'TESTPASSWORD', )))->dto();
Update User
use CodebarAg\DocuWare\Requests\General\UserManagement\CreateUpdateUsers\UpdateUser; $user->name .= ' - Updated'; $user->active = false; $user = $connector->send(new UpdateUser($user))->dto();
Get/Modify Groups
Get Groups
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyGroups\GetGroups; $groups = $connector->send(new GetGroups())->dto();
Get All Groups For A Specific User
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyGroups\GetAllGroupsForASpecificUser; $groups = $connector->send(new GetAllGroupsForASpecificUser($userId))->dto();
Add User To A Group
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyGroups\AddUserToAGroup; $response = $connector->send(new AddUserToAGroup( userId: $userId, ids: [$groupId], ))->dto();
Remove User From A Group
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyGroups\RemoveUserFromAGroup; $response = $connector->send(new RemoveUserFromAGroup( userId: $userId, ids: [$groupId], ))->dto();
Get/Modify Roles
Get Roles
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyRoles\GetRoles; $roles = $this->connector->send(new GetRoles())->dto();
Get All Roles For A Specific User
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyRoles\GetAllRolesForASpecificUser; $roles = $connector->send(new GetAllRolesForASpecificUser($userId))->dto();
Add User To A Role
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyRoles\AddUserToARole; $response = $connector->send(new AddUserToARole( userId: $userId, ids: [$roleId], ))->dto();
Remove User From A Role
use CodebarAg\DocuWare\Requests\General\UserManagement\GetModifyRoles\RemoveUserFromARole; $response = $connector->send(new RemoveUserFromARole( userId: $userId, ids: [$roleId], ))->dto();
File Cabinets
General
Get File Cabinet Information
use CodebarAg\DocuWare\Requests\FileCabinets\General\GetFileCabinetInformation; $fileCabinet = $connector->send(new GetFileCabinetInformation($fileCabinetId))->dto();
Get Total Number Of Documents
use CodebarAg\DocuWare\Requests\FileCabinets\General\GetTotalNumberOfDocuments; $count = $connector->send(new GetTotalNumberOfDocuments( $fileCabinetId, $dialogId ))->dto();
Dialogs
Get All Dialogs
use CodebarAg\DocuWare\Requests\FileCabinets\Dialogs\GetAllDialogs; $dialogs = $connector->send(new GetAllDialogs($fileCabinetId))->dto();
Get Dialogs of a Specific Type
use CodebarAg\DocuWare\Requests\FileCabinets\Dialogs\GetASpecificDialog; $dialog = $connector->send(new GetASpecificDialog($fileCabinetId, $dialogId))->dto();
Get Dialogs Of A Specific Type
use CodebarAg\DocuWare\Enums\DialogType; use CodebarAg\DocuWare\Requests\FileCabinets\Dialogs\GetDialogsOfASpecificType; $dialogs = $connector->send(new GetDialogsOfASpecificType($fileCabinetId, DialogType::SEARCH))->dto();
Search
Get A Specific Document From A File Cabinet
use CodebarAg\DocuWare\Requests\FileCabinets\Search\GetASpecificDocumentFromAFileCabinet; $document = $connector->send(new GetASpecificDocumentFromAFileCabinet( $fileCabinetId, $documentId ))->dto();
Get Documents From A File Cabinet
use CodebarAg\DocuWare\Requests\FileCabinets\Search\GetDocumentsFromAFileCabinet; $documents = $connector->send(new GetDocumentsFromAFileCabinet( $fileCabinetId ))->dto();
Most basic example to search for documents.
You only need to provide a valid file cabinet id.
$fileCabinetId = '87356f8d-e50c-450b-909c-4eaccd318fbf'; $paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($fileCabinetId) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Search in multiple file cabinets
Provide an array of file cabinet ids.
$fileCabinetIds = [ '0ee72de3-4258-4353-8020-6a3ff6dd650f', '3f9cb4ff-82f2-44dc-b439-dd648269064f', ]; $paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinets($fileCabinetIds) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Find results on the next page
Default: 1
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->page(2) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Define the number of results which should be shown per page
Default: 50
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->perPage(30) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Use the full-text search
You have to activate full-text search in your file cabinet before you can use this feature.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->fulltext('My secret document') ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Search documents which are created from the first of march.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->filterDate('DWSTOREDATETIME', '>=', Carbon::create(2021, 3, 1)) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Search documents which are created until the first of april.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->filterDate('DWSTOREDATETIME', '<', Carbon::create(2021, 4, 1)) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Order the results by field name.
Supported values: 'asc', 'desc'
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->orderBy('DWSTOREDATETIME', 'desc') ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Search documents filtered to the value.
You can specify multiple filters.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->filter('TYPE', 'Order') ->filter('OTHER_FIELD', 'other') ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Search documents filtered to multiple values.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->filterIn('TYPE', ['Order', 'Invoice']) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
You can specify the dialog which should be used.
$dialogId = 'bb42c30a-89fc-4b81-9091-d7e326caba62'; $paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->dialog($dialogId) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
You can also combine everything.
$paginatorRequest = DocuWare::searchRequestBuilder() ->fileCabinet($id) ->page(2) ->perPage(30) ->fulltext('My secret document') ->filterDate('DWSTOREDATETIME', '>=', Carbon::create(2021, 3, 1)) ->filterDate('DWSTOREDATETIME','<',Carbon::create(2021, 4, 1)) ->filter('TYPE', 'Order') ->filter('OTHER_FIELD', 'other') ->orderBy('DWSTOREDATETIME', 'desc') ->dialog($dialogId) ->get(); $paginator = $connector->send($paginatorRequest)->dto();
Check In Check Out
Not Currently Supported
Select Lists
Get Select Lists
use CodebarAg\DocuWare\Requests\FileCabinets\SelectLists\GetSelectLists; $types = $this->connector->send(new GetSelectLists( $fileCabinetId, $dialogId, $fieldName, ))->dto();
Upload
Create Data Record
use CodebarAg\DocuWare\Requests\FileCabinets\Upload\CreateDataRecord; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTextDTO; $document = $connector->send(new CreateDataRecord( $fileCabinetId, null, null, collect([ IndexTextDTO::make('DOCUMENT_LABEL', '::data-entry::'), ]), ))->dto();
Create Table Data Record
use CodebarAg\DocuWare\Requests\FileCabinets\Upload\CreateDataRecord; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateTimeDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDecimalDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexNumericDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTableDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTextDTO; $tableRows = collect([ collect([ IndexTextDTO::make('TEXT', 'project_1'), IndexNumericDTO::make('INT', 1), IndexDecimalDTO::make('DECIMAL', 1.1), IndexDateDTO::make('DATE', $now), IndexDateTimeDTO::make('DATETIME', $now), ]), collect([ IndexTextDTO::make('TEXT', 'project_2'), IndexNumericDTO::make('INT', 2), IndexDecimalDTO::make('DECIMAL', 2.2), IndexDateDTO::make('DATE', $now), IndexDateTimeDTO::make('DATETIME', $now), ]), ]); $document = $connector->send(new CreateDataRecord( $fileCabinetId, null, null, collect([ IndexTableDTO::make('TABLE_NAME', $tableRows) ]), ))->dto();
Append File(s) To A Data Record
use CodebarAg\DocuWare\Requests\FileCabinets\Upload\AppendFilesToADataRecord; use Saloon\Data\MultipartValue; $response = $connector->send( new AppendFilesToADataRecord( fileCabinetId: $fileCabinetId, dataRecordId: $document->id, files: collect([ new MultipartValue( name: 'File[]', value: file_get_contents(__DIR__.'/../../../../Fixtures/files/test-2.pdf'), filename: 'test-2.pdf', ), new MultipartValue( name: 'File[]', value: file_get_contents(__DIR__.'/../../../../Fixtures/files/test-3.pdf'), filename: 'test-3.pdf', ), ]) ) )->dto();
Append A Single PDF To A Document
use CodebarAg\DocuWare\Requests\FileCabinets\Upload\AppendASinglePDFToADocument; $response = $this->connector->send(new AppendASinglePDFToADocument( fileCabinetId: $fileCabinetId, documentId: $document->id, fileContent: file_get_contents(__DIR__.'/../../../../Fixtures/files/test-2.pdf'), fileName: 'test-2.pdf', ))->dto();
Replace A PDF Document Section
use CodebarAg\DocuWare\Requests\FileCabinets\Upload\ReplaceAPDFDocumentSection; $response = $this->connector->send(new ReplaceAPDFDocumentSection( fileCabinetId: $fileCabinetId, sectionId: $documentWithSections->sections->first()->id, fileContent: file_get_contents(__DIR__.'/../../../../Fixtures/files/test-3.pdf'), fileName: 'test-3.pdf', ))->dto();
Batch Index Fields Update
Not Currently Supported
Get Fields
use CodebarAg\DocuWare\Requests\Fields\GetFieldsRequest; $fields = $connector->send(new GetFieldsRequest($fileCabinetId))->dto();
Documents
Update Index Values
use CodebarAg\DocuWare\Requests\Documents\UpdateIndexValues\UpdateIndexValues; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateDTO; $response = $connector->send(new UpdateIndexValues( $fileCabinetId, $documentId, collect([ IndexTextDTO::make('DOCUMENT_LABEL', '::new-data-entry::'), ]) ))->dto();
Update Table Data Record
use CodebarAg\DocuWare\Requests\Documents\UpdateIndexValues\UpdateIndexValues; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateTimeDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDecimalDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexNumericDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTableDTO; use CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTextDTO; $tableRows = collect([ collect([ IndexTextDTO::make('TEXT', 'project_1'), IndexNumericDTO::make('INT', 1), IndexDecimalDTO::make('DECIMAL', 1.1), IndexDateDTO::make('DATE', $now), IndexDateTimeDTO::make('DATETIME', $now), ]), collect([ IndexTextDTO::make('TEXT', 'project_2'), IndexNumericDTO::make('INT', 2), IndexDecimalDTO::make('DECIMAL', 2.2), IndexDateDTO::make('DATE', $now), IndexDateTimeDTO::make('DATETIME', $now), ]), ]); $document = $connector->send(new UpdateIndexValues( $fileCabinetId, null, null, collect([ IndexTableDTO::make('TABLE_NAME', $tableRows) ]), ))->dto();
Modify Documents
Transfer Document
use CodebarAg\DocuWare\Requests\Documents\ModifyDocuments\TransferDocument; $response = $connector->send(new TransferDocument( $fileCabinetId, $destinationFileCabinetId, $storeDialogId, $documentId, $fields, ))->dto();
Delete Documents
use CodebarAg\DocuWare\Requests\Documents\ModifyDocuments\DeleteDocument; $connector->send(new DeleteDocument( $fileCabinetId $documentId, ))->dto();
Clip/Unclip & Staple/Unstaple
Clip
use CodebarAg\DocuWare\Requests\Documents\ClipUnclipStapleUnstaple\Clip; $clip = $connector->send(new Clip( $fileCabinetId, [ $documentId, $document2Id, ] ))->dto();
Unclip
use CodebarAg\DocuWare\Requests\Documents\ClipUnclipStapleUnstaple\Unclip; $unclip = $connector->send(new Unclip( $fileCabinetId, $clipId ))->dto();
Staple
use CodebarAg\DocuWare\Requests\Documents\ClipUnclipStapleUnstaple\Staple; $staple = $connector->send(new Staple( $fileCabinetId, [ $documentId, $document2Id, ] ))->dto();
Unstaple
use CodebarAg\DocuWare\Requests\Documents\ClipUnclipStapleUnstaple\Unstaple; $unclip = $connector->send(new Unstaple( $fileCabinetId, $stapleId ))->dto();
Annotations/Stamps
Not Currently Supported
Documents Trash Bin
Get Documents
You can use the same methods as in the search usage. The only difference is that you have to use the
trashBin
method after thesearchRequestBuilder
method.
```php use CodebarAg\DocuWare\DocuWare; $paginatorRequest = (new DocuWare()) ->searchRequestBuilder() ->trashBin()
Delete Documents
use CodebarAg\DocuWare\Requests\Documents\DocumentsTrashBin\DeleteDocuments; $delete = $connector->send(new DeleteDocuments([$documentID, $document2ID]))->dto();
Restore Documents
use CodebarAg\DocuWare\Requests\Documents\DocumentsTrashBin\RestoreDocuments; $delete = $connector->send(new RestoreDocuments([$documentID, $document2ID]))->dto();
Application Properties
Add Application Properties
use CodebarAg\DocuWare\Requests\Documents\ApplicationProperties\AddApplicationProperties; $addProperties = $connector->send(new AddApplicationProperties( $fileCabinetId, $documentId, [ [ 'Name' => 'Key1', 'Value' => 'Key1 Value', ], [ 'Name' => 'Key2', 'Value' => 'Key2 Value', ], ], ))->dto();
Update Application Properties
use CodebarAg\DocuWare\Requests\Documents\ApplicationProperties\UpdateApplicationProperties; $updateProperties = $connector->send(new UpdateApplicationProperties( $fileCabinetId, $documentId, [ [ 'Name' => 'Key1', 'Value' => 'Key1 Value Updated', ], ], ))->dto()->sortBy('Name');
Delete Application Properties
use CodebarAg\DocuWare\Requests\Documents\ApplicationProperties\DeleteApplicationProperties; $deleteProperties = $connector->send(new DeleteApplicationProperties( $fileCabinetId, $document->id, [ 'Key1', ], ))->dto();
Get Application Properties
use CodebarAg\DocuWare\Requests\Documents\ApplicationProperties\GetApplicationProperties; $properties = $connector->send(new GetApplicationProperties( $fileCabinetId, $document->id, ))->dto();
Sections
Get All Sections
use CodebarAg\DocuWare\Requests\Documents\Sections\GetAllSectionsFromADocument; $sections = $connector->send(new GetAllSectionsFromADocument( $fileCabinetId, $documentId ))->dto();
Get Specific Section
use CodebarAg\DocuWare\Requests\Documents\Sections\GetASpecificSection; $section = $connector->send(new GetASpecificSection( $fileCabinetId, $sectionsId ))->dto();
Delete Section
use CodebarAg\DocuWare\Requests\Documents\Sections\DeleteSection; $deleted = $connector->send(new DeleteSection( $fileCabinetId, $sectionId ))->dto();
Get Textshot
use CodebarAg\DocuWare\Requests\Documents\Sections\GetTextshot; $deleted = $connector->send(new GetTextshot( $fileCabinetId, $sectionId ))->dto();
Download
Download Document
use CodebarAg\DocuWare\Requests\Documents\Download\DownloadDocument; $contents = $connector->send(new DownloadDocument( $fileCabinetId, $documentId ))->dto();
Download Section
use CodebarAg\DocuWare\Requests\Documents\Download\DownloadSection; $contents = $connector->send(new DownloadSection( $fileCabinetId, $sectionId ))->dto();
Download Thumbnail
use CodebarAg\DocuWare\Requests\Documents\Download\DownloadThumbnail; $contents = $connector->send(new DownloadThumbnail( $fileCabinetId, $sectionId ))->dto();
Workflow
Workflow History
Get Document Workflow History
use CodebarAg\DocuWare\Requests\Workflow\GetDocumentWorkflowHistory; $history = $this->connector->send(new GetDocumentWorkflowHistory( $fileCabinetId, $documentId ))->dto();
Get Document Workflow History Steps
use CodebarAg\DocuWare\Requests\Workflow\GetDocumentWorkflowHistorySteps; $historySteps = $this->connector->send(new GetDocumentWorkflowHistorySteps( $workflowId, $historyId, ))->dto();
Extending the connector (EXAMPLE)
We understand it may be repetitive to pass the configuration every time you create a new connector.
You can extend the connector and set the configuration once.
Create a new connector
<?php namespace App\Connectors; use CodebarAg\DocuWare\Connectors\DocuWareConnector; use CodebarAg\DocuWare\DTO\Config\ConfigWithCredentials; class YourOwnDocuWareConnector extends DocuWareConnector { public function __construct() { $configuration = new ConfigWithCredentials( username: 'username', password: 'password', ); parent::__construct($configuration); } }
Use the new connector
use App\Connectors\YourOwnDocuWareConnector; use CodebarAg\DocuWare\DTO\Config\ConfigWithCredentials; $connector = new YourOwnDocuWareConnector();
🖼 Make encrypted URLs
use CodebarAg\DocuWare\Facades\DocuWare;
Make encrypted URL for a document in a file cabinet.
$fileCabinetId = '87356f8d-e50c-450b-909c-4eaccd318fbf'; $documentId = 42; $url = DocuWare::url() ->fileCabinet($fileCabinetId) ->document($documentId) ->make();
Make encrypted URL for a document in a basket.
$basketId = 'b_87356f8d-e50c-450b-909c-4eaccd318fbf'; $url = DocuWare::url() ->basket($basketId) ->document($documentId) ->make();
Make encrypted URL valid for a specific amount of time.
In the example below the URL is valid for one week, afterward the URL is no longer working.
$url = DocuWare::url() ->fileCabinet($fileCabinetId) ->document($documentId) ->validUntil(now()->addWeek()) ->make();
🏋️ Document Index Fields DTO showcase
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexTextDTO { +name: "FIELD_TEXT" // string +value: "Value" // null|string }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexNumericDTO { +name: "FIELD_NUMERIC" // string +value: 1 // null|int }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDecimalDTO { +name: "FIELD_DECIMAL" // string +value: 1.00 // null|int|float }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateDTO { +name: "FIELD_DATE" // string +value: now(), // null|Carbon }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexDateTimeDTO { +name: "FIELD_DATETIME" // string +value: now(), // null|Carbon }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexKeywordDTO { +name: "FIELD_KEYWORD" // string +value: "Value" // null|string }
CodebarAg\DocuWare\DTO\Documents\DocumentIndex\IndexMemoDTO { +name: "FIELD_MEMO" // string +value: "Value" // null|string }
CodebarAg\DocuWare\DTO\OrganizationIndex { +id: "2f071481-095d-4363-abd9-29ef845a8b05" // string +name: "Fake File Cabinet" // string +guid: "1334c006-f095-4ae7-892b-fe59282c8bed" // string|null }
CodebarAg\DocuWare\DTO\Organization { +id: "2f071481-095d-4363-abd9-29ef845a8b05" // string +name: "Fake File Cabinet" // string +guid: "1334c006-f095-4ae7-892b-fe59282c8bed" // string|null +additionalInfo: [] // array +configurationRights: [] // array }
CodebarAg\DocuWare\DTO\FileCabinet { +id: "2f071481-095d-4363-abd9-29ef845a8b05" // string +name: "Fake File Cabinet" // string +color: "Yellow" // string +isBasket: true // bool +assignedCabinet: "889c13cc-c636-4759-a704-1e6500d2d70f" // string }
CodebarAg\DocuWare\DTO\Dialog { +id: "fae3b667-53e9-48dd-9004-34647a26112e" // string +type: "ResultList" // string +label: "Fake Dialog" // string +isDefault: true // boolean +fileCabinetId: "1334c006-f095-4ae7-892b-fe59282c8bed" // string }
CodebarAg\DocuWare\DTO\Field { +name: "FAKE_FIELD" // string +label: "Fake Field" // string +type: "Memo" // string +scope: "User" // string
CodebarAg\DocuWare\DTO\Field { +name: "FAKE_FIELD" // string +label: "Fake Field" // string +type: "Memo" // string +scope: "User" // string
CodebarAg\DocuWare\DTO\Document { +id: 659732 // integer +file_size: 765336 // integer +total_pages: 100 // integer +title: "Fake Title" // string +extension: ".pdf" // string +content_type: "application/pdf" // string +file_cabinet_id: "a233b03d-dc63-42dd-b774-25b3ff77548f" // string +created_at: Illuminate\Support\Carbon // Carbon +updated_at: Illuminate\Support\Carbon // Carbon +fields: Illuminate\Support\Collection { // Collection|DocumentField[] #items: array:2 [ 0 => CodebarAg\DocuWare\DTO\DocumentField // DocumentField 1 => CodebarAg\DocuWare\DTO\DocumentField // DocumentField ] } }
CodebarAg\DocuWare\DTO\Section {#23784▶ +id: "5589-5525" +contentType: "text/plain" +haveMorePages: true +pageCount: 1 +fileSize: 32 +originalFileName: "example.txt" +contentModified: "/Date(1702395557000)/" +annotationsPreview: false +hasTextAnnotations: null }
CodebarAg\DocuWare\DTO\DocumentThumbnail { +mime: "image/png" // string +data: "somedata" // string +base64: "" // string }
CodebarAg\DocuWare\DTO\TableRow { +fields: Illuminate\Support\Collection { // Collection|DocumentField[] #items: array:2 [ 0 => CodebarAg\DocuWare\DTO\DocumentField // DocumentField 1 => CodebarAg\DocuWare\DTO\DocumentField // DocumentField ] }
CodebarAg\DocuWare\DTO\DocumentPaginator +total: 39 // integer +per_page: 10 // integer +current_page: 9 // integer +last_page: 15 // integer +from: 1 // integer +to: 10 // integer +documents: Illuminate\Support\Collection { // Collection|Document[] #items: array:2 [ 0 => CodebarAg\DocuWare\DTO\Document // Document 1 => CodebarAg\DocuWare\DTO\Document // Document ] } +error: CodebarAg\DocuWare\DTO\ErrorBag { // ErrorBag|null +code: 422 // int +message: "'000' is not valid cabinet id" // string } }
📦 Caching requests
All Get Requests are cachable and will be cached by default. To determine if the response is cached you can use the following method:
Is Cached
$connector = new DocuWareConnector(); $response = $connector->send(new GetDocumentRequest($fileCabinetId, $documentId)); $response->isCached(); // false // Next time the request is sent $response = $connector->send(new GetDocumentRequest($fileCabinetId, $documentId)); $response->isCached(); // true
Invalidate Cache
To invalidate the cache for a specific request you can use the following method:
$connector = new DocuWareConnector(); $request = new GetDocumentRequest($fileCabinetId, $documentId); $request->invalidateCache(); $response = $connector->send($request);
Disable Caching
To temporarily disable caching for a specific request you can use the following method:
$connector = new DocuWareConnector(); $request = new GetDocumentRequest($fileCabinetId, $documentId); $request->disableCaching(); $response = $connector->send($request);
💥 Exceptions explained
CodebarAg\DocuWare\Exceptions\UnableToMakeRequest
This is thrown if you are not authorized to make the request.
CodebarAg\DocuWare\Exceptions\UnableToProcessRequest
This is thrown if you passed wrong attributes. For example a file cabinet ID which does not exist.
CodebarAg\DocuWare\Exceptions\UnableToLogin
This exception can only be thrown during the login if the credentials did not match.
CodebarAg\DocuWare\Exceptions\UnableToLoginNoCookies
This exception can only be thrown during the login if there was no cookies in the response from the api.
CodebarAg\DocuWare\Exceptions\UnableToFindPassphrase
This exception can only be thrown during the url making if the passphrase could not be found.
CodebarAg\DocuWare\Exceptions\UnableToMakeUrl
Something is wrong during the URL making.
CodebarAg\DocuWare\Exceptions\UnableToUpdateFields
No fields were supplied.
CodebarAg\DocuWare\Exceptions\UnableToGetDocumentCount
Something is wrong with the response from getting the document count.
Illuminate\Http\Client\RequestException
All other cases if the response is not successfully.
✨ Events
The Following events will be fired:
use CodebarAg\DocuWare\Events\DocuWareResponseLog; // Log each response from the DocuWare REST API. DocuWareResponseLog::class => [ // ],
🔧 Configuration file
You can publish the config file with:
php artisan vendor:publish --provider="CodebarAg\DocuWare\DocuWareServiceProvider" --tag="docuware-config"
This is the contents of the published config file:
<?php return [ /* |-------------------------------------------------------------------------- | Cache driver |-------------------------------------------------------------------------- | You may like to define a different cache driver than the default Laravel cache driver. | */ 'cache_driver' => env('DOCUWARE_CACHE_DRIVER', env('CACHE_DRIVER', 'file')), /* |-------------------------------------------------------------------------- | Requests timeout |-------------------------------------------------------------------------- | This variable is optional and only used if you want to set the request timeout manually. | */ 'timeout' => env('DOCUWARE_TIMEOUT', 15), /* |-------------------------------------------------------------------------- | DocuWare Credentials |-------------------------------------------------------------------------- | | Before you can communicate with the DocuWare REST-API it is necessary | to enter your credentials. You should specify a url containing the | scheme and hostname. In addition add your username and password. | */ 'credentials' => [ 'url' => env('DOCUWARE_URL'), 'username' => env('DOCUWARE_USERNAME'), 'password' => env('DOCUWARE_PASSWORD'), ], /* |-------------------------------------------------------------------------- | Passphrase |-------------------------------------------------------------------------- | | In order to create encrypted URLs we need a passphrase. This enables a | secure exchange of DocuWare URLs without anyone being able to modify | your query strings. You can find it in the organization settings. | */ 'passphrase' => env('DOCUWARE_PASSPHRASE'), /* |-------------------------------------------------------------------------- | Configurations |-------------------------------------------------------------------------- | */ 'configurations' => [ 'search' => [ 'operation' => 'And', /* * Force Refresh * Determine if result list is retrieved from the cache when ForceRefresh is set * to false (default) or always a new one is executed when ForceRefresh is set to true. */ 'force_refresh' => true, 'include_suggestions' => false, 'additional_result_fields' => [], ], 'cache' => [ 'driver' => env('DOCUWARE_CACHE_DRIVER', env('CACHE_DRIVER', 'file')), 'lifetime_in_seconds' => env('DOCUWARE_CACHE_LIFETIME_IN_SECONDS', 60), ], ], ];
🚧 Testing
Copy your own phpunit.xml-file.
cp phpunit.xml.dist phpunit.xml
Modify environment variables in the phpunit.xml-file:
<env name="DOCUWARE_TOKEN" value=""/> <env name="DOCUWARE_URL" value="https://domain.docuware.cloud"/> <env name="DOCUWARE_USERNAME" value="user@domain.test"/> <env name="DOCUWARE_PASSWORD" value="password"/> <env name="DOCUWARE_PASSPHRASE" value="passphrase"/> <env name="DOCUWARE_TIMEOUT" value="30"/> <env name="DOCUWARE_CACHE_LIFETIME_IN_SECONDS" value="0"/> <env name="DOCUWARE_TESTS_FILE_CABINET_ID" value=""/> <env name="DOCUWARE_TESTS_DIALOG_ID" value=""/> <env name="DOCUWARE_TESTS_BASKET_ID" value=""/> <env name="DOCUWARE_TESTS_ORGANIZATION_ID" value=""/>
Run the tests:
composer test
📝 Changelog
Please see CHANGELOG for more information on what has changed recently.
✏️ Contributing
Please see CONTRIBUTING for details.
🧑💻 Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
🙏 Credits
- Sebastian Fix
- Rhys Lees
- All Contributors
- Skeleton Repository from Spatie
- Laravel Package Training from Spatie
🎭 License
The MIT License (MIT). Please see License File for more information.