KnpBundles
Open-source code of the knpbundles.com website, written in Symfony2.
Any ideas are welcome!
Please note that this service was previously called Symfony2Bundles but we had to change the name due to trademark issues.
Install
Get the code
git clone git://github.com/KnpLabs/KnpBundles.git
Configure
To configure your database in your development environment, copy
/app/config/parameters.yml.dist
to /app/config/parameters.yml
and
edit it according to your database settings.
If you want to use github connect locally, you'll need to create an app on github with the callback:
http://yourlocalurl/login/check-github
And update the parameters.yml with the Client ID and Secret.
If you also want to use sensio labs connect locally, you'll need to create a client on sensio labs connect with the callback:
http://yourlocalurl/login/check-sensio
And update the parameters.yml with the Client ID and Secret.
Install with docker
docker build
docker up -d
Create database and tables
docker-compose exec php php app/console doctrine:schema:create
docker-compose exec php php app/console --env=test doctrine:schema:create
Load data fixtures
docker-compose exec php php app/console doctrine:fixtures:load
docker-compose exec php php app/console --env=test doctrine:fixtures:load
Load assets and assetic
docker-compose exec php php app/console assets:install --symlink web/
docker-compose exec php php app/console assetic:dump --env=dev
docker-compose exec php php app/console assetic:dump --env=prod
Run the tests (requires PHPUnit >= 3.5)
docker-compose exec php phpunit -c app
Run the Behat tests (requires PHPUnit >= 3.5)
docker-compose exec php ./bin/behat @KnpBundlesBundle
To generate migrations from your current schema
docker-compose exec php php app/console doctrine:migrations:diff
docker-compose exec php php app/console doctrine:migrations:migrate
docker-compose exec php php app/console cache:warmup
Usage
Launch the consumer
We rely on RabbitMQ to update bundles:
- The main server produces messages saying "Hey, we should update this bundle"
- The consumers read these messages and update them
To launch a consumer, do:
docker-compose exec php php app/console rabbitmq:consumer update_bundle
Note that you will need a functional rabbitmq server โ Follow the instructions in this page to install it.
Populate document collections from GitHub
docker-compose exec php php app/console kb:populate
This can take a long time. GitHub API is limited to 60 calls per minute, so the commands needs to wait.
Update all bundles in database
docker-compose exec php php app/console kb:update:bundles
This can take a long time but should be run to trigger update on all bundles when this is needed.
Search engine
We use Solr and its PHP client Solarium to search bundles.
To install Solr, follow this steps:
- Download the version 3.6.2 (new versions are not compatibles) and extract it
- Uses the command
kb:solr:start --solr-path="/path/to/solar-3.6.2/example"
- And run
kb:solr:index --verbose
Use the default Jetty server included with SOLR. The default directory used for the installation is opt/solr/example
.
Copy the recommended configuration and schema found here
to your solr/conf directory.
You can run SOLR using:
docker-compose exec php php app/console kb:solr:start
See bin/prepare-test-solr.sh script Bundles will be automatically indexed on next update, or you can force indexing by console command.
If you have Solr up and running, simply do:
docker-compose exec php php app/console kb:solr:index --verbose
This will index all bundles.
Generate sitemap
docker-compose exec php php app/console kb:sitemap:generate --spaceless=1
Will create sitemap.xml and sitemap.xml.gz in web directory. Sitemap includes bundles and user profiles