Url highlight logo --- [![Build status](https://github.com/vstelmakh/url-highlight/workflows/build/badge.svg?branch=master)](https://github.com/vstelmakh/url-highlight/actions) [![Packagist version](https://img.shields.io/packagist/v/vstelmakh/url-highlight?color=orange)](https://packagist.org/packages/vstelmakh/url-highlight) [![PHP version](https://img.shields.io/packagist/php-v/vstelmakh/url-highlight)](https://www.php.net/) [![License](https://img.shields.io/github/license/vstelmakh/url-highlight?color=yellowgreen)](LICENSE) **Url highlight** - PHP library to parse URLs from string input. Works with complex URLs, edge cases and encoded input. Features: - Replace URLs in string by HTML tags (make clickable) - Match URLs without scheme by top-level domain - Work with HTML entities encoded input - Extract URLs from string - Check if string is URL ## Installation Install the latest version with [Composer](https://getcomposer.org/): ```bash composer require vstelmakh/url-highlight ``` Also, there are [Twig logo Twig extension](https://github.com/vstelmakh/url-highlight-twig-extension) and [Symfony logo Symfony bundle](https://github.com/vstelmakh/url-highlight-symfony-bundle) available. ## Quick start ```php highlightUrls('Hello, http://example.com.'); // Output: // Hello, http://example.com. ``` To properly handle HTML entity escaped string, see [Encoder](#encoder). ## Usage #### Check if string is URL ```php isUrl('http://example.com'); // return: true $urlHighlight->isUrl('Other string'); // return: false ``` #### Parse URLs from string ```php getUrls('Hello, http://example.com.'); // return: ['http://example.com'] ``` #### Replace URLs by HTML tags (make clickable) ```php highlightUrls('Hello, http://example.com.'); // return: 'Hello, http://example.com.' ``` ## Configuration There are 3 parts which could be configured according to your needs: - [Validator](#validator) - define if match is valid and should be recognized as URL (e.g. allow/disallow specific schemes) - [Highlighter](#highlighter) - define the way how URL should be highlighted (e.g. replaced by html `` tag) - [Encoder](#encoder) - define how to work with encoded input (e.g. html special chars) Configuration provided via constructor implementing corresponding interface instance. Use `null` to keep default: ```php http://example.com` - `MarkdownHighlighter` - converts matches to markdown format. Example: `http://example.com` → `[http://example.com](http://example.com)` By default, `HtmlHighlighter` is used, with settings listed below. Highlighter usage example: ```php 'nofollow', 'class' => 'light'] ); $urlHighlight = new UrlHighlight(null, $highlighter); ``` If you need custom behavior - create and use your own highlighter implementing [HighlighterInterface](./src/Highlighter/HighlighterInterface.php). ### Encoder Encoder should be used to handle encoded input properly. For example HTML escaped string could contain something like: `http://example.com?a=1"` or `http://example.com?a=1&b=2` which will be wrongly matched as URL. By default, there is no encoder used. There are 2 encoders bundled with library: - `HtmlEntitiesEncoder` - to work with HTML entities encoded string (any character expected to be HTML entity encoded) - `HtmlSpecialcharsEncoder` - to work with HTML escaped string (only `&` `"` `'` `<` `>` expected to be encoded) Encoder usage example: ```php highlightUrls('<a href="http://example.com">Example</a>'); // return: '<a href="http://example.com">Example</a>' ``` If you need custom behavior - create and use your own encoder implementing [EncoderInterface](./src/Encoder/EncoderInterface.php). Keep in mind - using **encoder require more regex operations and could have performance impact**. Better to not use encoder if you don't expect encoded string. ## Credits [Volodymyr Stelmakh](https://github.com/vstelmakh) Licensed under the MIT License. See [LICENSE](LICENSE) for more information.