snippetify / laravel-sniptbot
Sniptbot for laravel
Requires
- php: ^7.2
- illuminate/support: ^5|^6|^7
- snippetify/snippet-sniffer: dev-master
Requires (Dev)
- orchestra/testbench: ^3.8|^4.0|^5.0
This package is auto-updated.
Last update: 2025-03-29 01:11:00 UTC
README
This repository implements a simple ServiceProvider that makes the instances of the Snippet Crawler and Sniffer easily accessible via a Facade in Laravel. See @Snippetify/Snippet-sniffer for more information about the PHP Snippet sniffing and its interfaces.
What it does
This library allows you
- To get code snippets using search engine api (Google)
- To get code snippets from any web page by crawling url seeds.
How to use it
$ composer require snippetify/laravel-sniptbot
php artisan vendor:publish --provider="Snippetify\Sniptbot\SniptbotServiceProvider"
Configuration
Open the created file in the config/sniptbot.php
and customize the configuration options to your liking.
return [ // Search engine api configuration keys 'provider' => [ // Your google Search engine ID // https://developers.google.com/custom-search/v1/introduction 'cx' => env('SNIPTBOT_PROVIDER_CX', ''), // Your google API key // https://developers.google.com/custom-search/v1/overview#api_key 'key' => env('SNIPTBOT_PROVIDER_KEY', ''), 'name' => env('SNIPTBOT_PROVIDER_NAME', 'google'), // provider name (google) ], // Optional // Useful for adding meta information to each snippet 'app' => [ 'name' => env('SNIPTBOT_NAME', 'Sniptbot'), // your sniptbot name 'version' => env('SNIPTBOT_VERSION', '1.0.0'), // your sniptbot version ], // Optional // Useful for logging 'logger' => [ 'name' => env('SNIPTBOT_NAME', 'Sniptbot'), // logger name 'file' => storage_path('logs/sniptbot.log'), // logger file path ], // Optional // Useful for scraping 'html_tags' => [ 'index' => 'h1, h2, h3, h4, h5, h6, p, li', // Tags to index 'snippet' => 'pre[class] code, div[class] code, .highlight pre, code[class]', // Tags to fetch snippets ], // Optional // Useful for adding new scrapers // The name must be the website host without the scheme i.e. not https://foo.com but foo.com 'scrapers' => [ // 'scraper_name' => ScraperClass::class, // You can add as many as you want ], // Optional // Useful for adding new providers 'providers' => [ // 'provider_name' => ProviderClass::class, // You can add as many as you want ], // Optional // Useful for web crawling // Please follow the link below for more information as we use Spatie crawler // https://github.com/spatie/crawler 'crawler' => [ // 'langs' => ['en'], // 'profile' => Snippetify\SnippetSniffer\Profiles\CrawlSubdomainsAndUniqueUri::class, // 'user_agent' => Snippetify\SnippetSniffer\Core::CRAWLER_USER_AGENT, // 'concurrency' => 10, // 'ignore_robots' => false, // 'maximum_depth' => null, // 'execute_javascript' => false, // 'maximum_crawl_count' => null, // 'parseable_mime_types' => ['text/html'], // 'maximum_response_size' => 1024 * 1024 * 3, // 'delay_between_requests' => 250, ] ];
Sniffing from search engine api
use Snippetify\Sniptbot\Facades\Sniffer; // Important: You must set your search engine keys before using it // @return Snippetify\SnippetSniffer\Common\Snippet[] $snippets = Sniffer::fetch('js array contains value');
Crawl url seeds
use Snippetify\Sniptbot\Facades\Crawler; // @return Snippetify\SnippetSniffer\Common\MetaSnippetCollection[] $snippets = Crawler::fetch(['your urls']);
Changelog
Please see CHANGELOG for more information what has changed recently.
Testing
You must set the PROVIDER_NAME, PROVIDER_CX, PROVIDER_KEY, CRAWLER_URI, keys in phpunit.xml file before running tests.
Important: Those links must contains at least one snippet otherwise the tests will failed.
composer test
Contributing
Please see CONTRIBUTING for details.
Credits
License
The MIT License (MIT). Please see License File for more information.