From: Arthur Date: Wed, 4 Jan 2017 15:34:06 +0000 (+0100) Subject: Merge pull request #733 from ArthurHoaro/hotfix/reverse-proxy-port X-Git-Tag: v0.9.0~79 X-Git-Url: https://git.immae.eu/?a=commitdiff_plain;h=061f04fba06d2a78246de747e2bdd5625fc22400;hp=8e4be773685f7dff074f23e2df13072577091f44;p=github%2Fshaarli%2FShaarli.git Merge pull request #733 from ArthurHoaro/hotfix/reverse-proxy-port Hide default ports in local URL behind a reverse proxy --- diff --git a/application/Url.php b/application/Url.php index c5c7dd18..25a62a8a 100644 --- a/application/Url.php +++ b/application/Url.php @@ -94,7 +94,10 @@ class Url 'utm_', // ATInternet - 'xtor=' + 'xtor=', + + // Other + 'campaign_' ); private static $annoyingFragments = array( diff --git a/index.php b/index.php index 427eb239..bb1debd3 100644 --- a/index.php +++ b/index.php @@ -1949,8 +1949,8 @@ function install($conf) $conf->set( 'api.secret', generate_api_secret( - $this->conf->get('credentials.login'), - $this->conf->get('credentials.salt') + $conf->get('credentials.login'), + $conf->get('credentials.salt') ) ); try { @@ -2231,8 +2231,8 @@ $app = new \Slim\App($container); // REST API routes $app->group('/api/v1', function() { - $this->get('/info', '\Api\Controllers\Info:getInfo'); -})->add('\Api\ApiMiddleware'); + $this->get('/info', '\Shaarli\Api\Controllers\Info:getInfo'); +})->add('\Shaarli\Api\ApiMiddleware'); $response = $app->run(true); // Hack to make Slim and Shaarli router work together: diff --git a/tests/Url/CleanupUrlTest.php b/tests/Url/CleanupUrlTest.php index ba9a0437..1407d7d2 100644 --- a/tests/Url/CleanupUrlTest.php +++ b/tests/Url/CleanupUrlTest.php @@ -8,7 +8,13 @@ require_once 'application/Url.php'; class CleanupUrlTest extends PHPUnit_Framework_TestCase { /** - * Clean empty UrlThanks for building nothing + * @var string reference URL + */ + protected $ref = 'http://domain.tld:3000'; + + + /** + * Clean empty URL */ public function testCleanupUrlEmpty() { @@ -16,59 +22,87 @@ class CleanupUrlTest extends PHPUnit_Framework_TestCase } /** - * Clean an already cleaned Url + * Clean an already cleaned URL */ public function testCleanupUrlAlreadyClean() { - $ref = 'http://domain.tld:3000'; - $this->assertEquals($ref, cleanup_url($ref)); - $ref = $ref.'/path/to/dir/'; - $this->assertEquals($ref, cleanup_url($ref)); + $this->assertEquals($this->ref, cleanup_url($this->ref)); + $this->ref2 = $this->ref.'/path/to/dir/'; + $this->assertEquals($this->ref2, cleanup_url($this->ref2)); + } + + /** + * Clean URL fragments + */ + public function testCleanupUrlFragment() + { + $this->assertEquals($this->ref, cleanup_url($this->ref.'#tk.rss_all')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'#xtor=RSS-')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'#xtor=RSS-U3ht0tkc4b')); + } + + /** + * Clean URL query - single annoying parameter + */ + public function testCleanupUrlQuerySingle() + { + $this->assertEquals($this->ref, cleanup_url($this->ref.'?action_object_map=junk')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?action_ref_map=Cr4p!')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?action_type_map=g4R84g3')); + + $this->assertEquals($this->ref, cleanup_url($this->ref.'?fb_stuff=v41u3')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?fb=71m3w4573')); + + $this->assertEquals($this->ref, cleanup_url($this->ref.'?utm_campaign=zomg')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?utm_medium=numnum')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?utm_source=c0d3')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?utm_term=1n4l')); + + $this->assertEquals($this->ref, cleanup_url($this->ref.'?xtor=some-url')); + + $this->assertEquals($this->ref, cleanup_url($this->ref.'?campaign_name=junk')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?campaign_start=junk')); + $this->assertEquals($this->ref, cleanup_url($this->ref.'?campaign_item_index=junk')); } /** - * Clean Url needing cleaning + * Clean URL query - multiple annoying parameters */ - public function testCleanupUrlNeedClean() + public function testCleanupUrlQueryMultiple() { - $ref = 'http://domain.tld:3000'; - $this->assertEquals($ref, cleanup_url($ref.'#tk.rss_all')); - $this->assertEquals($ref, cleanup_url($ref.'#xtor=RSS-')); - $this->assertEquals($ref, cleanup_url($ref.'#xtor=RSS-U3ht0tkc4b')); - $this->assertEquals($ref, cleanup_url($ref.'?action_object_map=junk')); - $this->assertEquals($ref, cleanup_url($ref.'?action_ref_map=Cr4p!')); - $this->assertEquals($ref, cleanup_url($ref.'?action_type_map=g4R84g3')); - - $this->assertEquals($ref, cleanup_url($ref.'?fb_stuff=v41u3')); - $this->assertEquals($ref, cleanup_url($ref.'?fb=71m3w4573')); - - $this->assertEquals($ref, cleanup_url($ref.'?utm_campaign=zomg')); - $this->assertEquals($ref, cleanup_url($ref.'?utm_medium=numnum')); - $this->assertEquals($ref, cleanup_url($ref.'?utm_source=c0d3')); - $this->assertEquals($ref, cleanup_url($ref.'?utm_term=1n4l')); - - $this->assertEquals($ref, cleanup_url($ref.'?xtor=some-url')); - $this->assertEquals($ref, cleanup_url($ref.'?xtor=some-url&fb=som3th1ng')); - $this->assertEquals($ref, cleanup_url( - $ref.'?fb=stuff&utm_campaign=zomg&utm_medium=numnum&utm_source=c0d3' + $this->assertEquals($this->ref, cleanup_url($this->ref.'?xtor=some-url&fb=som3th1ng')); + + $this->assertEquals($this->ref, cleanup_url( + $this->ref.'?fb=stuff&utm_campaign=zomg&utm_medium=numnum&utm_source=c0d3' )); - $this->assertEquals($ref, cleanup_url( - $ref.'?xtor=some-url&fb=som3th1ng#tk.rss_all' + + $this->assertEquals($this->ref, cleanup_url( + $this->ref.'?campaign_start=zomg&campaign_name=numnum' + )); + } + + /** + * Clean URL query - multiple annoying parameters and fragment + */ + public function testCleanupUrlQueryFragment() + { + $this->assertEquals($this->ref, cleanup_url( + $this->ref.'?xtor=some-url&fb=som3th1ng#tk.rss_all' )); // ditch annoying query params and fragment, keep useful params $this->assertEquals( - $ref.'?my=stuff&is=kept', + $this->ref.'?my=stuff&is=kept', cleanup_url( - $ref.'?fb=zomg&my=stuff&utm_medium=numnum&is=kept#tk.rss_all' + $this->ref.'?fb=zomg&my=stuff&utm_medium=numnum&is=kept#tk.rss_all' ) ); // ditch annoying query params, keep useful params and fragment $this->assertEquals( - $ref.'?my=stuff&is=kept#again', + $this->ref.'?my=stuff&is=kept#again', cleanup_url( - $ref.'?fb=zomg&my=stuff&utm_medium=numnum&is=kept#again' + $this->ref.'?fb=zomg&my=stuff&utm_medium=numnum&is=kept#again' ) ); }