code711 / siteconfiggitsync
Sync changes in config/site back into your git repository
Installs: 4 062
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
Type:typo3-cms-extension
Requires
- php: 8.0.*||8.1.*||8.2.*||8.3.*
- code711/siteconfigurationevents: ^1.0
- knplabs/github-api: ^3.16
- m4tthumphrey/php-gitlab-api: ^11.5
- php-http/guzzle7-adapter: ^1.1
- typo3/cms-core: ^11.5||^12.0||^13.0
Requires (Dev)
- saschaegerer/phpstan-typo3: *
- typo3/cms-backend: ^13.0
- typo3/cms-frontend: ^13.0
- typo3/cms-install: ^13.0
- typo3/cms-lowlevel: ^13.0
- typo3/cms-tstemplate: ^13.0
- typo3/coding-standards: *
README
Sometimes it is necessary for a TYPO3 project that the site-config yaml files are managed in git alongside the site-package. Those projects have the problem that site-admins can then not change settings in the site config without manually carrying those changes back over to the git repository in order for them not to be overriden with the next CI/CD run or publish.
This extension aims to alleviate this problem by pushing those changes back to your gitlab instance automatically. In doing so the extension will create a branch, check in the changes that have been made and create a merge-request which you then can manage in gitlab without manually merging the yaml files. And you will be notified about the changes because of the merge-request.
There is no git binary on the server needed, everything is done through the GitLab API. Right now only GitLab is supported, but it can be selfhosted or on gitlab.com.
Changelog
1.1.0
- added GitHUB support
1.0.3
- fixed issue #1
- fixed issue reading the user-list in the extension configuration interface when a project is not part of a group
- added LoggerAwareInterface to AfterConfigurationWriteListener
1.0.1
Fix README.md
1.0.0
Support TYPO3 12
0.10.0
Externalised the XCLASS of the SiteConfiguration Class to EXT:siteconfigurationevents. Composer installations should pull this extension automatically as a dependency. Refactored the git related actions into event listeners.
0.9.x Initial release
Setup / Installation
Gitlab token
after installing this extension with
composer req code711/siteconfiggitsyncyou will need to create an API Token in your GitLab Project Page with at least 'Developer' permissions.
This is done in your GitLab in your Project under 'Settings->Access Token'. Developer Permissions are needed because only from this level on Branches can be created and Merge-requests can be issued.
In the field 'Token name' enter something meaningfull for this task, as it will be written next to commits or merge-requests. For example 'External Site change from TYPO3'.
Set the 'Expiration Date' to your liking.
In 'Select a role' choose 'Developer'
And for the scope select 'api'. The other scopes are not enough for the tasks we want to do.
after pressing the 'Create project access token' button you will be given a series of alphanumeric character. Copy this string of character. This is your token.
GitHUB token
after installing this extension with
composer req code711/siteconfiggitsyncyou will need to create an API Token in your GitLab Project Page with at least 'Developer' permissions.
The setup for GitHUB is from TYPO3 Point of view the same as in the above Gitlab setup.
The main difference is how to access your ACCESS_TOKEN.
In Github access tokens are always personal tied to a user. The token can be created inside an organisation or team, but it has to be created as a personal token by one of its members.
To do that access your Github dashboard, and click on your profile Icon. Choose the entry "Settings". In the following page choose 'Developer Settings' on the left hand side of the screen. Finally open up the Option "Personal access tokens" and choose the option "Fine-grained tokens"
You should be here then Fine-grained personal access token
If you don't see the organisation or team where your project is located you have to enrol the organisation or team once. This is done from the Organisation Overview screen by choosing "Settings" in to top menu and then "Personal access tokens" - here you will then be able to enrol your organisation. Once you've done that, return to the "Developer Settings" screen, your organisation will then be listed there.
Create a personal access token of the type "Fine-grained token" and restrict it to the repository you want to push your changes to. The following permissions are needed:
- "Contents" - read & write
- "Pull requests" - read & write
- "Metadata" - readonly
save and store the token
TYPO3 Backend config
In your TYPO3 backend navigate to Settings->Extension Configuration and open the accordion for the siteconfiggitsync extension:
Choose 'gitlab' or 'github' in the service dropdown (v1.1)
In the field project url add the complete URL to your projects repository, without any .git. Just as it is in your browser. for example
https://gitlab.com/mycompany/customerproject(same is true for github)
In the field API Auth Token enter the token you just generated.
Now press the "Save 'siteconfiggitsync' Configuration" button, and close the window. Re-open the window and navigate again to the siteconfiggitsync accordion and open it. The fields 'main_branch' and 'Who to assign a merge request' should be filled with respectively the available branches in that project and members who are allowed to merge merge-requests.
Choose the branch which represents the production branch, i.e. from which the branch to commit the changes should be taken.
Optionaly choose a member who gets the merge-requests assigend to. If no member is chosen the merge-requests will not be assigend to anybody, and it depends on your setup if you are notified when one is created.
Now press the "Save 'siteconfiggitsync' Configuration" button again, and you should be ready to accept merge-requests when the site-config is changed through the backend interface.
Notes and limitations
- renaming is not done with a git-move but with checking in a new file and removing the old one. The move operation did not work for me when developing this extension. This might be revisited later
- this extension is marked beta because not all scenarios have been tested. This is a 'works' for me right now
- The gitlab server must be reachable via http or https from the production server. The gitlab api implementation is using guzzlehttp, so a proxy configuration should be possible, but I have not looked into this yet. Help in this regard is welcome
- it should be possible to add bitbucket support. This might be added at a later stage