2013-08-26 09:49:49 +12:00
# External links
2017-11-23 15:36:00 +13:00
[![Build Status ](http://img.shields.io/travis/silverstripe/silverstripe-externallinks.svg?style=flat )](https://travis-ci.org/silverstripe/silverstripe-externallinks)
[![Scrutinizer Code Quality ](https://scrutinizer-ci.com/g/silverstripe/silverstripe-externallinks/badges/quality-score.png?b=master )](https://scrutinizer-ci.com/g/silverstripe/silverstripe-externallinks/?branch=master)
[![codecov ](https://codecov.io/gh/silverstripe/silverstripe-externallinks/branch/master/graph/badge.svg )](https://codecov.io/gh/silverstripe/silverstripe-externallinks)
2018-06-15 17:35:22 +12:00
[![SilverStripe supported module ](https://img.shields.io/badge/silverstripe-supported-0071C4.svg )](https://www.silverstripe.org/software/addons/silverstripe-commercially-supported-module-list/)
2014-08-07 16:49:20 +12:00
2013-08-26 09:49:49 +12:00
## Introduction
The external links module is a task and ModelAdmin to track and to report on broken external links.
## Maintainer Contact
2015-11-19 13:28:08 +13:00
* Damian Mooyman (@tractorcow ) < damian @silverstripe .com >
2013-08-26 09:49:49 +12:00
## Requirements
2017-11-23 15:36:00 +13:00
* SilverStripe ^4.0
**Note:** For a SilverStripe 3.x compatible version, please use [the 1.x release line ](https://github.com/silverstripe/silverstripe-externallinks/tree/1.0 ).
2013-08-26 09:49:49 +12:00
## Features
* Add external links to broken links reports
* Add a task to track external broken links
## Installation
2017-11-27 17:41:17 +13:00
1. Require the module via composer: `composer require silverstripe/externallinks`
2. Run `/dev/build` in your browser to rebuild the database.
2014-08-13 10:57:41 +12:00
3. Run the following task *http://path.to.silverstripe/dev/tasks/CheckExternalLinks* to check for
broken external links
2013-08-26 14:14:36 +12:00
2017-11-28 09:45:40 +13:00
## Report
2014-07-30 12:34:39 +12:00
2014-08-13 10:57:41 +12:00
A new report is added called 'External Broken links report'. When viewing this report, a user may press
the "Create new report" button which will trigger an ajax request to initiate a report run.
In this initial ajax request this module will do one of two things, depending on which modules are included:
* If the queuedjobs module is installed, a new queued job will be initiated. The queuedjobs module will then
manage the progress of the task.
* If the queuedjobs module is absent, then the controller will fallback to running a buildtask in the background.
This is less robust, as a failure or error during this process will abort the run.
In either case, the background task will loop over every page in the system, inspecting all external urls and
checking the status code returned by requesting each one. If a URL returns a response code that is considered
2017-05-12 11:41:14 +12:00
"broken" (defined as < 200 or > 302) then the `ss-broken` css class will be assigned to that url, and
2014-08-13 10:57:41 +12:00
a line item will be added to the report. If a previously broken link has been corrected or fixed, then
this class is removed.
In the actual report generated the user can click on any broken link item to either view the link in their browser,
or edit the containing page in the CMS.
While a report is running the current status of this report will be displayed on the report details page, along
with the status. The user may leave this page and return to it later to view the ongoing status of this report.
Any subsequent report may not be generated until a prior report has completed.
2014-07-30 12:34:39 +12:00
2017-11-28 09:45:40 +13:00
## Dev task
2013-08-26 14:14:36 +12:00
2018-03-26 11:28:02 +13:00
Run the following task *http://path.to.silverstripe/dev/tasks/CheckExternalLinksTask* to check your site for external
2013-08-26 14:14:36 +12:00
broken links.
2014-07-30 12:34:39 +12:00
2017-11-28 09:45:40 +13:00
## Queued job
2014-07-30 12:34:39 +12:00
2017-11-23 15:36:00 +13:00
If you have the queuedjobs module installed you can set the task to be run every so often.
2014-07-30 15:29:24 +12:00
2017-11-28 09:45:40 +13:00
## Whitelisting codes
2014-07-30 15:29:24 +12:00
2017-11-28 09:45:40 +13:00
If you want to ignore or whitelist certain HTTP codes this can be setup via `ignore_codes` in the config.yml
file in `mysite/_config` :
2014-07-30 15:29:24 +12:00
2017-11-23 15:36:00 +13:00
```yml
2017-11-28 09:45:40 +13:00
SilverStripe\ExternalLinks\Tasks\CheckExternalLinksTask:
ignore_codes:
- 401
- 403
- 501
2017-11-23 15:36:00 +13:00
```
2017-11-28 09:45:40 +13:00
## Upgrading from 1.x to 2.x
When upgrading from 1.x to 2.x (SilverStripe 3.x to 4.x) you will need to be aware of the following API changes:
* Configuration property `CheckExternalLinksTask.IgnoreCodes` renamed to `CheckExternalLinksTask.ignore_codes`
2018-02-22 10:51:59 +13:00
* Configuration property `CheckExternalLinksTask.FollowLocation` and `BypassCache` renamed to `follow_location` and `bypass_cache`
2016-12-15 10:34:59 +13:00
2018-02-22 10:51:59 +13:00
## Follow 301 redirects
2016-12-15 10:34:59 +13:00
You may want to follow a redirected URL a example of this would be redirecting from http to https
can give you a false poitive as the http code of 301 will be returned which will be classed
as a working link.
To allow redirects to be followed setup the following config in your config.yml
2018-02-22 10:51:59 +13:00
```yaml
# Follow 301 redirects
SilverStripe\ExternalLinks\Tasks\CurlLinkChecker:
follow_location: 1
```
2016-12-15 10:34:59 +13:00
2018-02-22 10:51:59 +13:00
## Bypass cache
2016-12-15 10:34:59 +13:00
By default the task will attempt to cache any results the cache can be bypassed with the
following config in config.yml.
2018-02-22 10:51:59 +13:00
```yaml
# Bypass SS_Cache
SilverStripe\ExternalLinks\Tasks\CurlLinkChecker::
bypass_cache: 1
```