diff --git a/config/global.ini.php b/config/global.ini.php
index 93699eb726107bf35e77f325a6bbbcec0d47cd6b..234b4c669dc58160dab0803760a5528fc4b3ef9c 100644
--- a/config/global.ini.php
+++ b/config/global.ini.php
@@ -539,7 +539,7 @@ bulk_requests_use_transaction = 1
 
 ; Comma separated list of known Referrer Spammers, ie. bot visits that set a fake Referrer field.
 ; All Visits with a Referrer URL host set to one of these will be excluded.
-; If you find new spam entries in Referrers>Websites, please report them here: http://dev.piwik.org/trac/ticket/5099
+; If you find new spam entries in Referrers>Websites, please report them here: https://github.com/piwik/piwik/issues/5099
 referrer_urls_spam = "semalt.com"
 
 ; DO NOT USE THIS SETTING ON PUBLICLY AVAILABLE PIWIK SERVER
diff --git a/core/ArchiveProcessor.php b/core/ArchiveProcessor.php
index c15ea5dd54a7a5512eacac6278b45be5a0fbde54..10374f18c47a737e4a08196b27d25ad721e70708 100644
--- a/core/ArchiveProcessor.php
+++ b/core/ArchiveProcessor.php
@@ -337,7 +337,7 @@ class ArchiveProcessor
         }
 
         if ($dataTable instanceof Map) {
-            // see http://dev.piwik.org/trac/ticket/4377
+            // see https://github.com/piwik/piwik/issues/4377
             $self = $this;
             $dataTable->filter(function ($table) use ($self, $columnsToRenameAfterAggregation) {
                 $self->renameColumnsAfterAggregation($table, $columnsToRenameAfterAggregation);
diff --git a/core/Common.php b/core/Common.php
index 64bf6926a1c3e4d004d439a43522167fcdfa0f3f..7ac908ad1e12c16e2ce13ba97501cd37d98f7a31 100644
--- a/core/Common.php
+++ b/core/Common.php
@@ -1066,7 +1066,7 @@ class Common
     /**
      * Marks an orphaned object for garbage collection.
      *
-     * For more information: {@link http://dev.piwik.org/trac/ticket/374}
+     * For more information: {@link https://github.com/piwik/piwik/issues/374}
      * @param $var The object to destroy.
      * @api
      */
diff --git a/core/DataAccess/ArchiveWriter.php b/core/DataAccess/ArchiveWriter.php
index ad51698d83c7266d286b7604976d9d96f6d87353..f4c84248554babc860ad7ed5b8b9b96701a71f81 100644
--- a/core/DataAccess/ArchiveWriter.php
+++ b/core/DataAccess/ArchiveWriter.php
@@ -266,7 +266,7 @@ class ArchiveWriter
 
         $tableName = $this->getTableNameToInsert($value);
 
-        // duplicate idarchives are Ignored, see http://dev.piwik.org/trac/ticket/987
+        // duplicate idarchives are Ignored, see https://github.com/piwik/piwik/issues/987
         $query = "INSERT IGNORE INTO " . $tableName . "
 					(" . implode(", ", $this->getInsertFields()) . ")
 					VALUES (?,?,?,?,?,?,?,?)";
diff --git a/core/Db/Schema/Mysql.php b/core/Db/Schema/Mysql.php
index cfcf02a94b75c9e6c06d0d6d91005693b9eabf68..ea5116421548db7bd6fd8aa5335f7423ce5bf9e6 100644
--- a/core/Db/Schema/Mysql.php
+++ b/core/Db/Schema/Mysql.php
@@ -454,7 +454,7 @@ class Mysql implements SchemaInterface
             Db::exec($statement);
         } catch (Exception $e) {
             // mysql code error 1050:table already exists
-            // see bug #153 http://dev.piwik.org/trac/ticket/153
+            // see bug #153 https://github.com/piwik/piwik/issues/153
             if (!Db::get()->isErrNo($e, '1050')) {
                 throw $e;
             }
diff --git a/core/Plugin/ControllerAdmin.php b/core/Plugin/ControllerAdmin.php
index 0212a3769c74db7f39d401d4f3e9fb65057c994f..a8e9b7b1dd38f6a1395a143fae56029a3ced36b7 100644
--- a/core/Plugin/ControllerAdmin.php
+++ b/core/Plugin/ControllerAdmin.php
@@ -102,7 +102,7 @@ abstract class ControllerAdmin extends Controller
     }
 
     /**
-     * See http://dev.piwik.org/trac/ticket/4439#comment:8 and https://github.com/eaccelerator/eaccelerator/issues/12
+     * See https://github.com/piwik/piwik/issues/4439#comment:8 and https://github.com/eaccelerator/eaccelerator/issues/12
      *
      * Eaccelerator does not support closures and is known to be not comptabile with Piwik. Therefore we are disabling
      * it automatically. At this point it looks like Eaccelerator is no longer under development and the bug has not
@@ -125,7 +125,7 @@ abstract class ControllerAdmin extends Controller
             $message = sprintf("You are using the PHP accelerator & optimizer eAccelerator which is known to be not compatible with Piwik.
                 We have disabled eAccelerator, which might affect the performance of Piwik.
                 Read the %srelated ticket%s for more information and how to fix this problem.",
-                '<a target="_blank" href="http://dev.piwik.org/trac/ticket/4439">', '</a>');
+                '<a target="_blank" href="https://github.com/piwik/piwik/issues/4439">', '</a>');
 
             $notification = new Notification($message);
             $notification->context = Notification::CONTEXT_WARNING;
diff --git a/core/Updates/0.6-rc1.php b/core/Updates/0.6-rc1.php
index cac08f47d69ed0a28403dfd4a5fc7591a16a52ad..5286e7371afb0415a97f20dc0e737f1f7520d4cf 100644
--- a/core/Updates/0.6-rc1.php
+++ b/core/Updates/0.6-rc1.php
@@ -42,8 +42,8 @@ class Updates_0_6_rc1 extends Updates
     {
         // first we disable the plugins and keep an array of warnings messages
         $pluginsToDisableMessage = array(
-            'SearchEnginePosition' => "SearchEnginePosition plugin was disabled, because it is not compatible with the new Piwik 0.6. \n You can download the latest version of the plugin, compatible with Piwik 0.6.\n<a target='_blank' href='?module=Proxy&action=redirect&url=http://dev.piwik.org/trac/ticket/502'>Click here.</a>",
-            'GeoIP'                => "GeoIP plugin was disabled, because it is not compatible with the new Piwik 0.6. \nYou can download the latest version of the plugin, compatible with Piwik 0.6.\n<a target='_blank' href='?module=Proxy&action=redirect&url=http://dev.piwik.org/trac/ticket/45'>Click here.</a>"
+            'SearchEnginePosition' => "SearchEnginePosition plugin was disabled, because it is not compatible with the new Piwik 0.6. \n You can download the latest version of the plugin, compatible with Piwik 0.6.\n<a target='_blank' href='?module=Proxy&action=redirect&url=https://github.com/piwik/piwik/issues/502'>Click here.</a>",
+            'GeoIP'                => "GeoIP plugin was disabled, because it is not compatible with the new Piwik 0.6. \nYou can download the latest version of the plugin, compatible with Piwik 0.6.\n<a target='_blank' href='?module=Proxy&action=redirect&url=https://github.com/piwik/piwik/issues/45'>Click here.</a>"
         );
         $disabledPlugins = array();
         foreach ($pluginsToDisableMessage as $pluginToDisable => $warningMessage) {
diff --git a/core/Updates/1.2-rc1.php b/core/Updates/1.2-rc1.php
index 7d9a200a7537cdffbd504de23833ead68f04e8fb..1e1862a432fe0550dd43c0358e34ff57d3b2eea3 100644
--- a/core/Updates/1.2-rc1.php
+++ b/core/Updates/1.2-rc1.php
@@ -123,7 +123,7 @@ class Updates_1_2_rc1 extends Updates
     {
         // first we disable the plugins and keep an array of warnings messages
         $pluginsToDisableMessage = array(
-            'GeoIP'     => "GeoIP plugin was disabled, because it is not compatible with the new Piwik 1.2. \nYou can download the latest version of the plugin, compatible with Piwik 1.2.\n<a target='_blank' href='?module=Proxy&action=redirect&url=http://dev.piwik.org/trac/ticket/45'>Click here.</a>",
+            'GeoIP'     => "GeoIP plugin was disabled, because it is not compatible with the new Piwik 1.2. \nYou can download the latest version of the plugin, compatible with Piwik 1.2.\n<a target='_blank' href='?module=Proxy&action=redirect&url=https://github.com/piwik/piwik/issues/45'>Click here.</a>",
             'EntryPage' => "EntryPage plugin is not compatible with this version of Piwik, it was disabled.",
         );
         $disabledPlugins = array();
diff --git a/misc/others/test_cookies_GenerateHundredsWebsitesAndVisits.php b/misc/others/test_cookies_GenerateHundredsWebsitesAndVisits.php
index 70040f497e08974f709ef79df9a83ca47d13396e..b8030333a2232c75adf1883d4906ae22cf9b5b12 100644
--- a/misc/others/test_cookies_GenerateHundredsWebsitesAndVisits.php
+++ b/misc/others/test_cookies_GenerateHundredsWebsitesAndVisits.php
@@ -1,6 +1,6 @@
 <?php
 // Script that creates 100 websites, then outputs a IMG that records a pageview in each website
-// Used initially to test how to handle cookies for this use case (see http://dev.piwik.org/trac/ticket/409)
+// Used initially to test how to handle cookies for this use case (see https://github.com/piwik/piwik/issues/409)
 use Piwik\Common;
 use Piwik\FrontController;
 use Piwik\Piwik;
diff --git a/misc/package/build.sh b/misc/package/build.sh
index de6ae59d99db5cce101a4064f84ccd999ec96306..35b230f47a1c3aaad2921abe67be3f4254c08e42 100755
--- a/misc/package/build.sh
+++ b/misc/package/build.sh
@@ -104,7 +104,7 @@ fi
 echo "Starting build...."
 ############################
 
-# Setting umask so it works for most users, see http://dev.piwik.org/trac/ticket/3869
+# Setting umask so it works for most users, see https://github.com/piwik/piwik/issues/3869
 UMASK=`umask`
 umask 0022
 
diff --git a/plugins/API/ProcessedReport.php b/plugins/API/ProcessedReport.php
index 4ffdb697eed2c03dbeb6abeba8d32741287626cd..bf8488c410cc54c7a69011dd4cb9faec431b3ba1 100644
--- a/plugins/API/ProcessedReport.php
+++ b/plugins/API/ProcessedReport.php
@@ -667,7 +667,7 @@ class ProcessedReport
                     // generate 'human readable' metric values
 
                     // if we handle MultiSites.getAll we do not always have the same idSite but different ones for
-                    // each site, see http://dev.piwik.org/trac/ticket/5006
+                    // each site, see https://github.com/piwik/piwik/issues/5006
                     $idSiteForRow = $idSite;
                     if ($row->getMetadata('idsite') && is_numeric($row->getMetadata('idsite'))) {
                         $idSiteForRow = (int) $row->getMetadata('idsite');
diff --git a/plugins/CoreConsole/Commands/CoreArchiver.php b/plugins/CoreConsole/Commands/CoreArchiver.php
index 570b1dc74d731c74d2ebab15f6dc70cef2d414bd..89b6bd9a9b6d6af6e7b3458cf5a6e36246495635 100644
--- a/plugins/CoreConsole/Commands/CoreArchiver.php
+++ b/plugins/CoreConsole/Commands/CoreArchiver.php
@@ -31,7 +31,7 @@ class CoreArchiver extends ConsoleCommand
         }
 
         if (is_string($url) && $url && in_array($url, array('http://', 'https://'))) {
-            // see http://dev.piwik.org/trac/ticket/5180 and http://forum.piwik.org/read.php?2,115274
+            // see https://github.com/piwik/piwik/issues/5180 and http://forum.piwik.org/read.php?2,115274
             throw new \InvalidArgumentException('No valid URL given. If you have specified a valid URL try --piwik-domain instead of --url');
         }
 
diff --git a/plugins/CoreHome/angularjs/anchorLinkFix.js b/plugins/CoreHome/angularjs/anchorLinkFix.js
index 9764d362ba210dc499243f57928a2fac4661ca1c..59d8114a568272eb401bf5044d4edc489cd190b8 100644
--- a/plugins/CoreHome/angularjs/anchorLinkFix.js
+++ b/plugins/CoreHome/angularjs/anchorLinkFix.js
@@ -6,7 +6,7 @@
  */
 
 /**
- * See http://dev.piwik.org/trac/ticket/4795 "linking to #hash tag does not work after merging AngularJS"
+ * See https://github.com/piwik/piwik/issues/4795 "linking to #hash tag does not work after merging AngularJS"
  */
 (function () {
 
diff --git a/plugins/CoreHome/stylesheets/cloud.less b/plugins/CoreHome/stylesheets/cloud.less
index fc71f9650ddfcef7a25d06a5df95e539606f31e1..a0750c6497fc7dea7ed2b5652db08543891cae33 100644
--- a/plugins/CoreHome/stylesheets/cloud.less
+++ b/plugins/CoreHome/stylesheets/cloud.less
@@ -1,6 +1,6 @@
 @-moz-document url-prefix() {
   // see bug in Firefox 30+
-  // http://dev.piwik.org/trac/ticket/5242
+  // https://github.com/piwik/piwik/issues/5242
   // https://bugzilla.mozilla.org/show_bug.cgi?id=1012640
   .tagCloud + .dataTableFeatures {
     clear: left;
diff --git a/plugins/ImageGraph/StaticGraph/GridGraph.php b/plugins/ImageGraph/StaticGraph/GridGraph.php
index b136f80ed025875f01aa36e486102e05457c283c..3eeb1393db470a920c7d2779ddabb85e8a4d3235 100644
--- a/plugins/ImageGraph/StaticGraph/GridGraph.php
+++ b/plugins/ImageGraph/StaticGraph/GridGraph.php
@@ -416,7 +416,7 @@ abstract class GridGraph extends StaticGraph
     // can not currently be used because pChart's label design is not flexible enough
     // e.g: it is not possible to remove the box border & the square icon
     // it would require modifying pChart code base which we try to avoid
-    // see http://dev.piwik.org/trac/ticket/3396
+    // see https://github.com/piwik/piwik/issues/3396
 //	protected function displayMinMaxValues()
 //	{
 //		if($displayMinMax)
diff --git a/plugins/Live/javascripts/visitorLog.js b/plugins/Live/javascripts/visitorLog.js
index 0b5f8fefbbafa24bba5a28484ac268d4639bfb84..3f30f9e9ab0eddaaa46c221fbeb96b65adc8693b 100644
--- a/plugins/Live/javascripts/visitorLog.js
+++ b/plugins/Live/javascripts/visitorLog.js
@@ -64,7 +64,7 @@
                     var tooltipIsOpened = false;
 
                     $('a', $this).on('focus', function () {
-                        // see http://dev.piwik.org/trac/ticket/4099
+                        // see https://github.com/piwik/piwik/issues/4099
                         if (tooltipIsOpened) {
                             $this.tooltip('close');
                         }
diff --git a/plugins/MultiSites/angularjs/dashboard/dashboard-model.js b/plugins/MultiSites/angularjs/dashboard/dashboard-model.js
index 802e1dfe8fd03361fccdcfcaba8fbb7c71840efd..52c66bd6873503cb21c48882654e42d145ae9ef6 100644
--- a/plugins/MultiSites/angularjs/dashboard/dashboard-model.js
+++ b/plugins/MultiSites/angularjs/dashboard/dashboard-model.js
@@ -97,7 +97,7 @@ angular.module('piwikApp').factory('multisitesDashboardModel', function (piwikAp
             site.idsite   = reportMetadata[index].idsite;
             site.group    = reportMetadata[index].group;
             site.main_url = reportMetadata[index].main_url;
-            // casting evolution to int fixes sorting, see: http://dev.piwik.org/trac/ticket/4885
+            // casting evolution to int fixes sorting, see: https://github.com/piwik/piwik/issues/4885
             site.visits_evolution    = parseInt(site.visits_evolution, 10);
             site.pageviews_evolution = parseInt(site.pageviews_evolution, 10);
             site.revenue_evolution   = parseInt(site.revenue_evolution, 10);
diff --git a/tests/PHPUnit/Core/ReleaseCheckListTest.php b/tests/PHPUnit/Core/ReleaseCheckListTest.php
index 67dc9efe289b42e6d4f263dd028bc72339693ede..97aeace84a78700227bff29574f445d137095e4b 100644
--- a/tests/PHPUnit/Core/ReleaseCheckListTest.php
+++ b/tests/PHPUnit/Core/ReleaseCheckListTest.php
@@ -306,7 +306,7 @@ class ReleaseCheckListTest extends PHPUnit_Framework_TestCase
     public function testPiwikJavaScript()
     {
         // check source against Snort rule 8443
-        // @see http://dev.piwik.org/trac/ticket/2203
+        // @see https://github.com/piwik/piwik/issues/2203
         $pattern = '/\x5b\x5c{2}.*\x5c{2}[\x22\x27]/';
         $contents = file_get_contents(PIWIK_DOCUMENT_ROOT . '/js/piwik.js');
 
diff --git a/tests/PHPUnit/Integration/Core/ArchiveProcessingTest.php b/tests/PHPUnit/Integration/Core/ArchiveProcessingTest.php
index e970ec97699ec10335e3eb1c718e18e8ee42585a..a87ee6dd8fc36236aca24d2ca285f22db553fdd1 100644
--- a/tests/PHPUnit/Integration/Core/ArchiveProcessingTest.php
+++ b/tests/PHPUnit/Integration/Core/ArchiveProcessingTest.php
@@ -335,7 +335,7 @@ class Core_ArchiveProcessingTest extends DatabaseTestCase
                     . ' The error Messages from MySQL were: '
                     . $didWeUseBulk
                     . "\n\n Learn more how to enable LOAD LOCAL DATA INFILE see the Mysql doc (http://dev.mysql.com/doc/refman/5.0/en/load-data-local.html) "
-                    . "\n   or ask in this Piwik ticket (http://dev.piwik.org/trac/ticket/3605)"
+                    . "\n   or ask in this Piwik ticket (https://github.com/piwik/piwik/issues/3605)"
             );
         }
         return $didWeUseBulk;
diff --git a/tests/PHPUnit/Integration/TwoVisitorsTwoWebsitesDifferentDaysArchivingDisabledTest.php b/tests/PHPUnit/Integration/TwoVisitorsTwoWebsitesDifferentDaysArchivingDisabledTest.php
index cc142c27be9509e282dfabafcdf968b636f32972..b5101d08a00cc1a07459b53cc9050550b4b60e70 100755
--- a/tests/PHPUnit/Integration/TwoVisitorsTwoWebsitesDifferentDaysArchivingDisabledTest.php
+++ b/tests/PHPUnit/Integration/TwoVisitorsTwoWebsitesDifferentDaysArchivingDisabledTest.php
@@ -60,7 +60,7 @@ class TwoVisitorsTwoWebsitesDifferentDaysArchivingDisabledTest extends Integrati
                                              'testSuffix'       => '_disabledAfter')),
 
 
-            // Testing this particular bug: http://dev.piwik.org/trac/ticket/4532
+            // Testing this particular bug: https://github.com/piwik/piwik/issues/4532
             // ENABLE ARCHIVING and Process this custom date range.
             array('VisitsSummary.get', array('idSite'           => 'all',
                                              'date'             => $dateRange,
diff --git a/tests/resources/extractSearchEngineInformationFromUrlTests.yml b/tests/resources/extractSearchEngineInformationFromUrlTests.yml
index 60daf9da832c936a50b40b50e6c8226c724f8299..5be88676d4187cb45b635745384c5ddaa4a7a960 100644
--- a/tests/resources/extractSearchEngineInformationFromUrlTests.yml
+++ b/tests/resources/extractSearchEngineInformationFromUrlTests.yml
@@ -32,7 +32,7 @@
   keywords: '<> &test; piwik &quot;'
   
 # testing Baidu special case (several variable names possible, and custom encoding)
-# see http://dev.piwik.org/trac/ticket/589
+# see https://github.com/piwik/piwik/issues/589
 
 # keyword is in "wd"
 - url: 'http://www.baidu.com/s?ie=gb2312&bs=%BF%D5%BC%E4+hao123+%7C+%B8%FC%B6%E0%3E%3E&sr=&z=&cl=3&f=8&tn=baidu&wd=%BF%D5%BC%E4+%BA%C3123+%7C+%B8%FC%B6%E0%3E%3E&ct=0'