diff --git a/.github/workflows/dispatch-ci.yml b/.github/workflows/dispatch-ci.yml index 9db0ff8e..cb8a373c 100644 --- a/.github/workflows/dispatch-ci.yml +++ b/.github/workflows/dispatch-ci.yml @@ -1,9 +1,11 @@ name: Dispatch CI on: - # At 12:10 PM UTC, only on Tuesday and Wednesday + # At 4:20 PM UTC, only on Wednesday and Thursday schedule: - - cron: '10 12 * * 2,3' + - cron: '20 16 * * 3,4' + +permissions: {} jobs: dispatch-ci: @@ -11,6 +13,9 @@ jobs: # Only run cron on the silverstripe account if: (github.event_name == 'schedule' && github.repository_owner == 'silverstripe') || (github.event_name != 'schedule') runs-on: ubuntu-latest + permissions: + contents: read + actions: write steps: - name: Dispatch CI uses: silverstripe/gha-dispatch-ci@v1 diff --git a/.github/workflows/keepalive.yml b/.github/workflows/keepalive.yml index 92ed0d49..afcd378e 100644 --- a/.github/workflows/keepalive.yml +++ b/.github/workflows/keepalive.yml @@ -1,17 +1,21 @@ name: Keepalive on: - # At 10:50 PM UTC, on day 7 of the month + # At 4:20 PM UTC, on day 25 of the month schedule: - - cron: '50 22 7 * *' + - cron: '20 16 25 * *' workflow_dispatch: +permissions: {} + jobs: keepalive: name: Keepalive # Only run cron on the silverstripe account if: (github.event_name == 'schedule' && github.repository_owner == 'silverstripe') || (github.event_name != 'schedule') runs-on: ubuntu-latest + permissions: + actions: write steps: - name: Keepalive uses: silverstripe/gha-keepalive@v1 diff --git a/.github/workflows/merge-up.yml b/.github/workflows/merge-up.yml index 1cc51d66..3bd741c6 100644 --- a/.github/workflows/merge-up.yml +++ b/.github/workflows/merge-up.yml @@ -1,17 +1,22 @@ name: Merge-up on: - # At 12:10 PM UTC, only on Saturday + # At 4:20 PM UTC, only on Sunday schedule: - - cron: '10 12 * * 6' + - cron: '20 16 * * 0' workflow_dispatch: +permissions: {} + jobs: merge-up: name: Merge-up # Only run cron on the silverstripe account if: (github.event_name == 'schedule' && github.repository_owner == 'silverstripe') || (github.event_name != 'schedule') runs-on: ubuntu-latest + permissions: + contents: write + actions: write steps: - name: Merge-up uses: silverstripe/gha-merge-up@v1 diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md deleted file mode 100644 index 40304bcc..00000000 --- a/CONTRIBUTING.md +++ /dev/null @@ -1,15 +0,0 @@ -# Contributing - -Any open source product is only as good as the community behind it. You can participate by sharing code, ideas, or simply helping others. No matter what your skill level is, every contribution counts. - -See our [high level overview](http://silverstripe.org/contributing-to-silverstripe) on silverstripe.org on how you can help out. - -## Copyright - -**IMPORTANT: By supplying code to the SilverStripe core team in patches, tickets and pull requests, you agree to assign copyright of that code to SilverStripe Limited, on the condition that SilverStripe Limited releases that code under the BSD license.** - -We ask for this so that the ownership in the license is clear and unambiguous, and so that community involvement doesn't stop us from being able to continue supporting these projects. By releasing this code under a permissive license, this copyright assignment won't prevent you from using the code in any way you see fit. - -## Contributing code - -See [contributing code](docs/en/05_Contributing/01_Code.md) diff --git a/src/Flysystem/PublicAssetAdapter.php b/src/Flysystem/PublicAssetAdapter.php index eef2129b..21448570 100644 --- a/src/Flysystem/PublicAssetAdapter.php +++ b/src/Flysystem/PublicAssetAdapter.php @@ -53,6 +53,7 @@ protected function findRoot($root) */ public function getPublicUrl($path) { + $path = Convert::slashes($path, '/'); return Controller::join_links(Director::baseURL(), $this->parentUrlPrefix, $path); } diff --git a/tests/php/PublicAssetAdapterTest.php b/tests/php/PublicAssetAdapterTest.php index dacfa3c7..d39cd24b 100644 --- a/tests/php/PublicAssetAdapterTest.php +++ b/tests/php/PublicAssetAdapterTest.php @@ -28,4 +28,32 @@ public function testInitBaseURL() $adapter->getPublicUrl('dir/file.jpg') ); } + + public function provideGetPublicUrl(): array + { + return [ + 'filename' => [ + 'path' => 'lorem.jpg', + 'expected' => '/baseurl/assets/lorem.jpg', + ], + 'unixPath' => [ + 'path' => 'path/to/lorem.jpg', + 'expected' => '/baseurl/assets/path/to/lorem.jpg', + ], + 'windowsPath' => [ + 'path' => 'path\\to\\lorem.jpg', + 'expected' => '/baseurl/assets/path/to/lorem.jpg', + ], + ]; + } + + /** + * @dataProvider provideGetPublicUrl + */ + public function testGetPublicUrl(string $path, string $expected) + { + $adapter = new PublicAssetAdapter('assets'); + $actual = $adapter->getPublicUrl($path); + $this->assertSame($expected, $actual); + } }