Download the PHP package rattfieldnz/safe-urls without Composer
On this page you can find all versions of the php package rattfieldnz/safe-urls. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download rattfieldnz/safe-urls
More information about rattfieldnz/safe-urls
Files in rattfieldnz/safe-urls
Package safe-urls
Short Description A laravel package to check URLs with Google's Safe Browsing API.
License MIT
Homepage https://github.com/rattfieldnz/safe-urls
Informations about the package safe-urls
safe-urls
A Laravel package to check URLs with Google's Safe Browsing API (look up).
Inspired by another similar package @ https://github.com/snipe/Safebrowsing.
Take a look at contributing.md to see a to do list.
- Installation
- Update Config
- Publish Config
- Set Your Google Safebrowsing API Key
- Usage
- Using Blade Syntax
- Using Facades
- Example With Input and Output
- Test URLs
- Testing
- Contributing
- Security
- Credits
- License
Please Note:
This package requires that you have an active Google Safebrowsing API key. It absolutely will not work without one. It's free to create an API key .
Google also throttles API usage, so if you have a high-traffic site, you may want to build in a caching layer or something so you don't burn through your requests too quickly. You can keep an eye on your usage through the Google API console.
This project is not ready for use in production yet. When it is, there will be first major release (i.e. 1.0.0).
A Note About Google Safebrowsing API Results
During testing, there were a few times when the API showed some malware sites as 'safe', whereas in reality they weren't.
For example, running PHPUnit tests showed the Postman produced expected results. I have not found a solution yet; however, any feedback / suggestions are welcome, as are pull requests etc. Below are links which I have read about this issue further:
- https://github.com/google/safebrowsing/issues/30#issuecomment-302508958.
- https://stackoverflow.com/questions/41934692/google-url-safe-browsingv4-lookup-api-is-not-working.
- https://groups.google.com/forum/#!topic/google-safe-browsing-api/Z5FVGfBbl20
- https://stackoverflow.com/questions/54625443/google-safe-browsing-not-detecting-url-even-it-unsafe-url
Installation
Via Composer
Update Your Config
For applications using Laravel =< 5.4
Open config/app.php
and add:
to your providers
array in config/app.php
, and:
to your aliases
array in config/app.php
.
Publish the config
This will add a safe-urls.php
config file into your project's config
folder.
Set Your Google Safebrowsing API Key
In your .env
, add:
There are additional options in the config file that relate to what specific types of threats you want to check for, and what platforms you want to check on, but you only really need to worry about that if you want to check fewer things, as it's pretty inclusive already.
Usage
Using Blade Syntax
Where $urls
could be an array of URLs to check, perhaps passed through your Controller to a view.
Where true
will return the results as an associative array.
false
(or not having the second parameter) will return the results as a JSON-encoded string.
Using Facades
Example with input and output
If the value of $urls
was:
SafeUrls::check($urls, true)
Would return the following associative array:
SafeUrls::check($urls)
(or SafeUrls::check($urls, false)
) Would return the following JSON-encoded string:
Both outputs will depend on what options you have set in your config/safe-urls.php
file.
Test URLs
Here are some handy test urls you can use while you're experimenting with this Laravel package.
- http://www.yahoo.com/ (OK)
- http://www.google.com/ (OK)
- http://malware.testing.google.test/testing/malware/ (Malware)
- http://twitter.com/ (OK)
- http://ianfette.org (Malware)
- https://github.com/ (OK)
- https://testsafebrowsing.appspot.com/s/phishing.html (Malware)
- https://testsafebrowsing.appspot.com/s/malware.html (Malware)
- http://testsafebrowsing.appspot.com/apiv4/ANY_PLATFORM/MALWARE/URL/ (Malware)
- http://testsafebrowsing.appspot.com/apiv4/ANY_PLATFORM/SOCIAL_ENGINEERING/URL/ (Malware / Social Engineering)
Change log
Please see the changelog for more information on what has changed recently.
Testing
From inside the root folder of this package:
Replace YOUR_GOOGLE_API_KEY with your key. Get one by visiting https://developers.google.com/safe-browsing/v4/get-started.
Contributing
Please see contributing.md for details and a todolist.
Security
If you discover any security related issues, please email author email instead of using the issue tracker.
Credits
- Rob Attfield
- All Contributors
License
Please see the license file for more information.
All versions of safe-urls with dependencies
ext-curl Version *
ext-json Version *
illuminate/support Version ~5
curl/curl Version ^2.2