Drupal Planet

Syndicate content
Drupal.org - aggregated feeds in category Planet Drupal
Updated: 3 hours 8 min ago

Valuebound: Drupal 8: How to create a custom block programatically

Mon, 12/19/2016 - 2:33am
span property=schema:name data-quickedit-field-id=node/212/title/en/rss class=field field--name-title field--type-string field--label-hiddenDrupal 8: How to create a custom block programatically/span span data-quickedit-field-id=node/212/uid/en/rss rel=schema:author class=field field--name-uid field--type-entity-reference field--label-hiddena title=View user profile. href=/user/9 lang= about=/user/9 typeof=schema:Person property=schema:name datatype= class=usernameJaywant.Topno/a/span span property=schema:dateCreated content=2016-12-19T07:33:52+00:00 data-quickedit-field-id=node/212/created/en/rss class=field field--name-created field--type-created field--label-hiddenMon, 12/19/2016 - 02:33/span
Categories: Drupal Feeds

Valuebound: Drupal 8: Custom Block Creation programmatically

Mon, 12/19/2016 - 2:33am
span property=schema:name data-quickedit-field-id=node/211/title/en/rss class=field field--name-title field--type-string field--label-hiddenDrupal 8: Custom Block Creation programmatically /span span data-quickedit-field-id=node/211/uid/en/rss rel=schema:author class=field field--name-uid field--type-entity-reference field--label-hiddena title=View user profile. href=/user/9 lang= about=/user/9 typeof=schema:Person property=schema:name datatype= class=usernameJaywant.Topno/a/span span property=schema:dateCreated content=2016-12-19T07:33:52+00:00 data-quickedit-field-id=node/211/created/en/rss class=field field--name-created field--type-created field--label-hiddenMon, 12/19/2016 - 02:33/span
Categories: Drupal Feeds

Larry Garfield: Moving to a new Platform

Mon, 05/02/2016 - 9:02am
pAfter my a href=http://www.garfieldtech.com/blog/leaving-palantirlast post/a, a number of people asked if I was leaving Drupal all together. Perish the thought. :-) However, after a decade at Palantir.net and the five-year Wagnerian Saga that was the Drupal 8 development cycle (complete with a href=https://www.youtube.com/watch?v=7zvCOKzY3kAsinging/a), I have been asking myself What next?/p pWell, what do I like to do? I like to build. I like to teach. I like to make things better. I like to work with smart people, as colleagues, as community partners, and as customers. I want to be able to have an impact in making something better for other people./p pTo that end, I am pleased to announce that today is my first day as Director of Runtimes, Integrations, and Services for a href=http://platform.shPlatform.sh/a./p pa href=http://www.garfieldtech.com/blog/joining-platformsh target=_blankread more/a/p
Categories: Drupal Feeds

DrupalEasy: DrupalEasy Podcast 174 - Floss Belt (Ryan Szrama - Drupal Commerce)

Mon, 05/02/2016 - 7:02am
pa href=https://drupaleasy.podbean.com/mf/play/kectku/DrupalEasy_ep174_20160502.mp3Direct .mp3 file download./a/p pRyan Szrama (a href=https://www.drupal.org/u/rszramarszrama/a), President and CEO of a href=https://commerceguys.comCommerce Guys/a, project leader of a href=https://www.drupal.org/project/commerceDrupal Commerce/a, and proud ex-Best Buy Geek Squad member joins Ryan, Ted, and Mike for a comprehensive discussion Commerce Guys' recent relaunch as a standalone company, and the current development progress of Drupal Commerce for Drupal 8. We also discussed Drupal 8.1, a potential future for the theme layer, the absolute correct pronunciation of Szrama, and a big announcement from Ted./p h2Interview/h2 ullia href=https://commerceguys.com/blog/commerce-guys-refocusing-drupal-commerce-platformsh-becomes-independent-companyCommerce Guys Refocusing on Drupal Commerce as Platform.sh Becomes an Independent Company/a blog post. /li lia href=https://drupalcommerce.orghttps://drupalcommerce.org/a, especially the a href=https://drupalcommerce.org/blogblog/a for updates on 8.x-2.0. /li lia href=http://docs.drupalcommerce.orghttp://docs.drupalcommerce.org/a /li liMeta for checkout issues (base form to be inlcuded in alpha4): a href=https://www.drupal.org/node/2710973https://www.drupal.org/node/2710973/a /li liPayment roadmap issue (target for beta1 at DrupalCon): a href=https://www.drupal.org/node/2711013https://www.drupal.org/node/2711013/a /li /ulh2DrupalEasy News/h2 ulliDrupalEasy and SixMileTech team up for a href=https://events.drupal.org/neworleans2016/training/module-developmentIntroduction to Drupal 8 Module Development/a at DrupalCon New Orleans./li lia href=https://play.google.com/music/listen?u=0#/ps/I563aaw7k5rdnq4ofqlzlchiv5iDrupalEasy Podcast now on Google Play/a. /li lia href=http://reddit.com/r/drupaleasypodcastDrupalEasyPodcast on Reddit/a - upvote stories you'd like us to cover. /li /ulh2Three Stories/h2 ullia href=https://www.drupal.org/blog/drupal-8-1-0Drupal 8.1 is now available/a. /li lia href=https://www.drupal.org/node/2702061Unify amp; simplify render amp; theme system: component-based rendering (enables pattern library, style guides, interface previews, client-side re-rendering)/a - issue by a href=https://www.drupal.org/u/wim-leersWim Leers/a. /li lia href=https://www.mydropwizard.com/blog/why-you-shouldnt-upgrade-drupal-6Why you SHOULDN'T upgrade from Drupal 6!/a - blog post by a href=https://www.drupal.org/u/dsnopekDavid Snopek/a. /li /ulh2Sponsors/h2 ullia href=http://webenabled.comWebEnabled.com/a - a href=https://devpanel.comdevPanel/a /li /ulh2Picks of the Week/h2 ulliMike - a href=https://www.drupal.org/project/bootstrapBootstrap/a base theme. /li liTed - a href=https://events.drupal.org/neworleans2016/sessions/size-just-number-reflecting-community-growth-mentoring-and-where-we-spendIs size just a number? Reflecting on community growth, mentoring, and where we spend our efforts/a DrupalCon session by a href=https://www.drupal.org/u/davidhernandezDavid Hernandez/a and a href=https://www.drupal.org/u/kgoelKalpana Goel/a. /li liRyan P - a href=https://www.drupal.org/project/registry_rebuildRegistry Rebuild and --fire-bazooka/a for when you move between environments. /li liRyan S - a href=https://www.cloudflare.comCloudflare/a. /li /ulh2Upcoming Events/h2 ullia href=http://drupalcon.orgDrupalCon New Orleans/a - May 9-13, 2016. /li /ulh2Follow us on Twitter/h2 ullia href=http://twitter.com/drupaleasy@drupaleasy/a /li lia href=http://twitter.com/andrewmriley@andrewmriley/a /li lia href=http://twitter.com/liberatr@liberatr/a /li lia href=http://twitter.com/ultimike@ultimike/a /li lia href=http://twitter.com/tedbow@tedbow/a /li lia href=http://twitter.com/sixmiletech@sixmiletech/a /li lia href=http://twitter.com/akalata@akalata/a /li lia href=http://twitter.com/ryanszrama@ryanszrama/a /li /ulh2Five Questions (answers only)/h2 olliKayaking /li liClash Royale /li liBecome a beverage professional /li liLlamas /li liDrupalCon Barcelona 2007 /li /olh2Intro Music/h2 pa href=https://www.youtube.com/watch?v=KDwODbl3muEThe Dean Scream/a./p h2Subscribe/h2 pa href=https://itunes.apple.com/us/podcast/drupaleasy-podcast/id305745575Subscribe to our podcast on iTunes/a, a href=https://play.google.com/music/listen?u=0#/ps/I563aaw7k5rdnq4ofqlzlchiv5iGoogle Play/a or a href=http://www.getmiro.com/Miro/a. Listen to our podcast on a href=http://stitcher.com/s?fid=28701amp;refid=stprStitcher/a./p pIf you'd like to leave us a voicemail, call 321-396-2340. Please keep in mind that we might play your voicemail during one of our future podcasts. Feel free to call in with suggestions, rants, questions, or corrections. If you'd rather just send us an email, please use our a href=http://DrupalEasy.com/contactcontact page/a./pdiv class=feedflare a href=http://feeds.feedburner.com/~ff/DrupalEasy?a=w5ZlxTLzv30:kTGYrKrPIjQ:yIl2AUoC8zAimg src=http://feeds.feedburner.com/~ff/DrupalEasy?d=yIl2AUoC8zA border=0/img/a a href=http://feeds.feedburner.com/~ff/DrupalEasy?a=w5ZlxTLzv30:kTGYrKrPIjQ:qj6IDK7rITsimg src=http://feeds.feedburner.com/~ff/DrupalEasy?d=qj6IDK7rITs border=0/img/a /divimg src=http://feeds.feedburner.com/~r/DrupalEasy/~4/w5ZlxTLzv30 height=1 width=1 alt=/
Categories: Drupal Feeds

Dries Buytaert: Handling context in outside-in

Mon, 05/02/2016 - 4:28am
div class=field field-name-body field-type-text-with-summary field-label-hiddendiv class=field-itemsdiv class=field-item even property=content:encodedpIn a recent post we talked about how introducing a href=http://buytaert.net/turning-drupal-outside-inoutside-in experiences/a could improve the Drupal site-building experience by letting you immediately edit simple configuration without leaving the page. In a follow-up blog post, we provided a href=http://buytaert.net/examples-of-how-to-make-drupal-outside-inconcrete examples/a of how we can apply outside-in to Drupal./p pThe feedback was overwhelmingly positive. However, there were also some really important questions raised. The most common concern was the idea that the mockups ignored context./p pWhen we showed a href=http://buytaert.net/examples-of-how-to-make-drupal-outside-inhow to place a block outside-in/a, we placed it on a single page. However, in Drupal a block can also be made visible for specific pages, types, roles, languages, or any number of other contexts. The flexibility this provides is one place where Drupal shines./p h3Why context matters/h3 pFor the sake of simplicity and focus we intentionally did not address how to handle context in outside-in in the last post. However, incorporating context into outside-in thinking is fundamentally important for at least two reasons: /p ollistrongManaging context is essential to site building./strong Site builders commonly want to place a block or menu item that will be visible on not just one but several pages or to not all but some users. A key principle of outside-in is previewing as you edit. The challenge is that you want to preview what site visitors will see, not what you see as a site builder or site administrator./li listrongManaging context is a big usability problem on its own./strong Even without outside-in patterns, making context simple and usable is an unsolved problem. Modules like Context and Panels have added lots of useful functionality, but all of it happens away from the rendered page./li /olh3The ingredients: user groups and page groups/h3 pTo begin to incorporate context into outside-in, a href=https://www.drupal.org/u/tkolearyKevin Oleary/a, with input from a href=https://www.drupal.org/u/yoroyyoroy/a, a href=https://www.drupal.org/u/bojhanBojhan/a, a href=https://www.drupal.org/u/webchickAngie Byron/a, a href=https://drupal.org/u/gabor-hojtsyGábor Hojtsy/a and others, has iterated on the block placement examples that we presented in the last post, to incorporate some ideas for how we can make context outside-in. We're excited to share our ideas and we'd love your feedback so we can keep iterating./p pTo solve the problem, we recommend introducing 3 new concepts: /p ollistrongPage groups:/strong re-usable collections of URLs, wildcards, content types, etc./li listrongUser groups:/strong reusable collections of roles, user languages, or other user attributes./li listrongImpersonation:/strong the ability to view the page as a user group./li /olh4Page groups/h4 pMost sites have some concept of a section or type of page that may or may not equate to a content type. A commerce store for example may have a kids section with several product types that share navigation or other blocks. emPage groups/em adapts to this by creating reusable bundles of content consisting either of a certain type (e.g. all research reports), or of manually curated lists of pages (e.g. a group that includes /home, /contact us, and /about us), or a combination of the two (similar to a href=https://www.drupal.org/project/contextContext module/a but context never provided an in-place UI)./p h4User groups/h4 pemUser groups/em would combine multiple user contexts like role, language, location, etc. Example user groups could be Authenticated users logged in from the United States, or Anonymous users that signed up to our newsletter. The goal is to combine the massive number of potential contexts into understandable bundles that can be used for context and impersonation./p h4Impersonation/h4 pAs mentioned earlier, a challenge is that you want to preview what site visitors will see, not what you see as a site builder or site administrator. Impersonation allows site builders to switch between different user groups. Switching between different user groups allow a page to be previewed as that type of user./p h3Using page groups, user groups and impersonation/h3 pLet's take a look at how we use these 3 ingredients in an example. For the purpose of this blog post, we want to focus on two use cases:/p olliI'm a site builder working on a life sciences journal with a paywall and I want to place a block called Download report next to all entities of type Research summary (content type), but only to users with the role Subscriber (user role)./li liI want to place a block called Access reports on the main page, the About us page, and the Contact us page (URL based), and all research summary pages, but only to users who are anonymous users./li /olpThings can get more complex but these two use cases are a good starting point and realistic examples of what people do with Drupal./p h4Step #1: place a block for anonymous users/h4 pLet's assume the user is a content editor, and the user groups Anonymous and Subscriber as well as the page groups Subscriber pages and Public pages have already been created for her by a site builder. Her first task is to place the Access reports block and make it visible only for anonymous users./p pfigure class=figurebr /div class=img style=border: 1px solid #ccc; display: inline-blockimg src=http://buytaert.net/sites/buytaert.net/files/images/blog/outside-in-block-placement-anonymous.gif style=display: block; alt=Place a block for anonymous users //div pfigcaptionFirst the editor changes the impersonation to Anonymous then she places the block. She is informed about the impact of the change./figcaption/p/figure/p h4Step #2: place a block for subscribers/h4 pOur editor's next task is to place the Download reports block and make it visible only for subscribers. To do that she is going to want to view the page as a subscriber. Here it's important that this interactions happens smoothly, and with animation, so that changes that occur on the page are not missed./p pfigure class=figurebr /div class=img style=border: 1px solid #ccc; display: inline-blockimg src=http://buytaert.net/sites/buytaert.net/files/images/blog/outside-in-block-placement-subscriber.gif style=display: block; alt=Place a block for subscribers //div pfigcaptionThe editor changes the impersonation to Subscribers. When she does the Access reports block is hidden as it is not visible for subscribers. When she places the Download report block and chooses the Subscriber pages page group, she is notified about the impact of the change./figcaption/p/figure/p h4Step #3: see if you did it right/h4 pOnce our editor has finished step one and two she will want to go back and make sure that step two did not undo or complicate what was done in step one, for example by making the Download report block visible for Anonymous users or vice versa. This is where impersonation comes in./p pfigure class=figurebr /div class=img style=border: 1px solid #ccc; display: inline-blockimg src=http://buytaert.net/sites/buytaert.net/files/images/blog/outside-in-impersonate.gif style=display: block; alt=Confirm you did it right //div pfigcaptionThe anonymous users need to see the Access reports block and subscribers need to see the Download report block. Impersonation lets you see what that looks like for each user group./figcaption/p/figure/p h3Summary/h3 pThe idea of combining a number of contexts into a single object is not new, both context and panels do this. What is new here is that when you bring this to the front-end with impersonation, you can make a change that has broad impact while seeing it exactly as your user will./p /div/div/div
Categories: Drupal Feeds

Janez Urevc: Media entity reaches 8.x-1.0!

Mon, 05/02/2016 - 3:00am
spanMedia entity reaches 8.x-1.0!/span spanspan lang= about=/users/slashrsm typeof=schema:Person property=schema:name datatype=slashrsm/span/span spanMon, 02.05.2016 - 10:00/span div class=field field--name-body field--type-text-with-summary field--label-hidden field--itempMore than two years ago I gave a href=https://www.youtube.com/watch?v=4giCe2GNnLQa session about the future of media at DrupalCon Prague/a. The outcome of that session was a href=https://groups.drupal.org/node/327768a planning sprint/a that happened two days after it. One of the ideas that was born on that sprint was a href=https://drupal.org/project/media_entityMedia entity/a, storage layer for media-related information built with simplicity and support for remotely hosted media in mind. It's development started shortly after that and got significantly accelerated in the spring of the next year, when the core of the media initiative met at NYC Camp and a href=https://groups.drupal.org/node/418803agreed on the common battle plan for Drupal 8/a./p pMedia entity and it's plugins have been pretty stable for the last few months. It seemed to be almost ready for it's first release, but there were few tickets in the issue queue which I wanted to resolve first. In the last few days I found some time to look at those. Together with a href=https://drupal.org/u/paranojikTadej Baša (@paranojik)/a we managed to finish all of the most important patches, which allowed me to tag 8.x-1.0 yesterday. I am thrilled and extremely proud. A lot of individuals and organizations invested many hours to make this possible and I would like to thank every single one of them. Special thanks go to a href=http://nyccamp.org/NYC Camp organizers/a, who organized two sprints and have been supporting us from the beginning, a href=http://examiner.comExaminer.com/a, my ex employer who allowed me to spend significant amount of my time to work on many media-related modules and a href=http://www.md-systems.ch/MD Systems/a, who organized two media sprints and let part of their a href=http://www.md-systems.ch/en/blog/2016-02/media-management-in-drupal-8team to work on Drupal 8 media for 3 months/a./p pAlong with the main module I released some of it's plugins too: a href=https://drupal.org/project/media_entity_imageImage/a, a href=https://drupal.org/project/media_entity_slideshowSlideshow/a, a href=https://drupal.org/project/media_entity_twitterTwitter/a and a href=https://drupal.org/project/media_entity_instagramInstagram/a. There are also plugins that handle a href=https://drupal.org/project/video_embed_fieldVideo/a, a href=https://drupal.org/project/media_entity_audioAudio/a and a href=https://drupal.org/project/media_entity_documentDocuments/a, which are also quite ready to be used./p pMedia entity and it's plugins offer many interesting features:/p ullisimple and lean storage for local and remote media, /li liout of the box integration with standard Drupal's tools,/li lipluggable architecture that allows easy implementation of additional plugins, /li li100% automatic delivery of thumbnails,/li lidelivery of remote metadata and/li limapping of remote metadata with entity fields./li /ulpI encourage you to try it and let us know what you think. We are looking for co-maintainers too. If you'd like to spend some time in contrib and have ideas for new features a href=/contactlet me know/a./p pIn the next few weeks we're planning releases of the other media modules. Stay tuned!/p /div
Categories: Drupal Feeds

Amazee Labs: Amazee Labs launches Drupal Hoster amazee.io

Mon, 05/02/2016 - 2:14am
spanAmazee Labs launches Drupal Hoster amazee.io/span div class=field field-node--field-lead field-name-field-lead field-type-text-long field-label-hidden div class=field-items div class=field-itempToday’s the day to reconsider your hosting. We are launching amazee.io, a state-of-the-art hosting service with an integrated development and hosting environment. Think of a battle-proven system, automated deployments, full congruence between your development and productive environment, and a very competitive pricing./p p“Why another Drupal hosting provider?” You might ask. Read why: a href=https://stories.amazee.iostories.amazee.io/a /p/div /div /div spana href=/en/user/87 title=View user profile. lang= about=/en/user/87 typeof=schema:Person property=schema:name datatype= class=usernameJohanna Bergmann/a/span spanMon, 05/02/2016 - 09:14/span div class=field field-node--field-image field-name-field-image field-type-image field-label-hidden div class=field-items div class=field-itemimg class=image-style-blog-full src=https://www.amazeelabs.com/sites/default/files/styles/blog_full/public/amazeeio_text_right.png?itok=GtALlV73 width=580 height=271 alt= typeof=foaf:Image / /div /div /div div class=field field-node--body field-name-body field-type-text-with-summary field-label-hidden div class=field-items div class=field-itempAnd if you have not yet on seen our a href=https://www.amazee.iowebsite/a or a href=https://www.amazee.io/sites/default/files/factsheet_amazeeio.pdffactsheet/a let me introduce the team behind the system: Michael Schmid (Schnitzel), CTO; Tyler Ward and Bastian Widmer for DevOps, and myself, who after three great years at the Drupal Association accepted the opportunity to lead the new venture as CEO. We are excited!/p pHope to see you at the upcoming DrupalCon in New Orleans./p/div /div /div
Categories: Drupal Feeds

Red Route: Including SVG icons in a Drupal 8 theme

Sun, 05/01/2016 - 3:46am
div class=field field-name-body field-type-text-with-summary field-label-hiddendiv class=field-itemsdiv class=field-item even property=schema:articleBody content:encodedpI got started with task runners a while ago using Grunt, thanks to a href=https://24ways.org/2013/grunt-is-not-weird-and-hard/an excellent 24 ways article by Chris Coyier/a. Lately I've been using Gulp more, and all the cool kids seem to be going that way, so for the Drupal 8 version of The Gallery Guide, I've decided to use Gulp./p pSince hearing Chris Coyier talk about a href=https://css-tricks.com/svg-sprites-use-better-icon-fonts/SVG icon systems/a, I've been meaning to implement them in my own workflow. I've written about a href=http://capgemini.github.io/frontend/jekyll-svg-iconsa similar setup for Jekyll/a on the Capgemini engineering blog, and wanted to apply something similar to this site./p pThe Gulp setup for this project is almost identical to the one described in that post, so I won't go into too much detail here, but a href=http://www.red-route.org/articles/rebuilding-gallery-guide-openin the spirit of openness/a that's guiding this project, a href=https://github.com/GalleryGuide/gall/blob/master/gulpfile.js#L40the gulpfile is on Github/a./p pIn short, there's a directory of SVG icons within the theme, and there's a Gulp task to combine them into a single file at codeimages/icons.svg/code. Then the contents of that file is injected into the page using a preprocess function. There's a slight gotcha here - if the value is added directly, without going through the codet()/code function, then it automatically gets escaped to block cross-site scripting. It doesn't seem to make sense, according to a href=https://api.drupal.org/api/drupal/core%21lib%21Drupal%21Component%21Render%21FormattableMarkup.php/function/FormattableMarkup%3A%3AplaceholderFormat/8.2.xthe documentation/a, but I needed to pass the value in without any prefix character:/p precode class=language-php function gall_preprocess_page(amp;$variables) { $svg = file_get_contents(drupal_get_path('theme', 'gall') . '/images/icons.svg'); $variables['svg_icons'] = t('svg', array('svg' =gt; $svg)); } /code/pre pIf we were working with user-supplied content, this would be opening up a dangerous attack vector, but given that it's content that I've created myself in the theme, it's safe to trust it./p pHaving done that, in the codepage.html.twig/code template, the variable is available for output:/p precode class=language-twig {{ svg_icons }} /code/pre pThen these files can be referenced - here's a snippet from coderegion--header.html.twig/code:/p precode class=language-markup lt;a href=https://www.twitter.com/thegalleryguide title=Follow us on Twittergt; lt;svg class=icongt; lt;use xlink:href=#twittergt;lt;/usegt; lt;/svggt; lt;/agt; /code/pre pPart of me feels like there should be a more Drupal-ish way of doing this, so that the links are part of a menu. But given that this is my own project, and changing the icons would require a code change, it doesn't feel so bad to have them hard-coded in the template./p /div/div/divdiv class=field field-name-taxonomy-vocabulary-4 field-type-taxonomy-term-reference field-label-above div class=field-labelTags:nbsp;/div div class=field-items div class=field-item evena href=/category/tags/drupal typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Drupal/a/div div class=field-item odda href=/category/tags/drupal-8 typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Drupal 8/a/div div class=field-item evena href=/category/tags/gallery-guide typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=The Gallery Guide/a/div /div /div a href=/blog/terms class=taxonomy-link-allAll tags/a span rel=schema:url resource=/articles/including-svg-icons-drupal-8-theme class=rdf-meta element-hidden/spanspan property=schema:name content=Including SVG icons in a Drupal 8 theme class=rdf-meta element-hidden/span
Categories: Drupal Feeds

DrupalOnWindows: Cheap Pipe (sort of BigPipe) in Drupal 7

Sun, 05/01/2016 - 12:00am
div class=form-item form-type-item labelLanguage /label English /div div class=field field-name-body field-type-text-with-summary field-label-hiddendiv class=field-itemsdiv class=field-item even property=content:encodedpemThis post is on how we implemented a simple (yet effective) BigPipe like rendering strategy for Drupal 7./em/p pstrongWhy is big pipe so important?/strong/p p class=rtecenterstrongimg alt= src=http://ws003.universitatpolit.netdna-cdn.com/php_drupalonwindows/sites/default/files/ckfinder_files/1/images/Blogs/2015/44/Big-Pipe-Prod.jpg //strong/p/div/div/divdiv class=view view-read-more view-id-read_more view-display-id-entity_view_1 view-dom-id-0a82662c3174b14d9b1e93afc4211ff3 div class=view-header hr/ h2More articles.../h2 /div div class=view-content div class=item-list ul li class=views-row views-row-1 views-row-odd views-row-first div class=views-field views-field-title span class=field-contenta href=/en/blog/fixing-slow-queries-and-database-deadlocks-drupal-without-php-profiling-toolsFixing slow queries and database deadlocks in Drupal without PHP profiling tools/a/span /div/li li class=views-row views-row-2 views-row-even div class=views-field views-field-title span class=field-contenta href=/en/content/making-namespaced-callbacks-work-drupal-7-without-hacking-core-and-bound-parametersMaking namespaced callbacks work in Drupal 7 (without hacking core and with bound parameters)/a/span /div/li li class=views-row views-row-3 views-row-odd div class=views-field views-field-title span class=field-contenta href=/en/blog/php-com-class-consuming-net-phpPHP COM class: consuming .Net from PHP/a/span /div/li li class=views-row views-row-4 views-row-even div class=views-field views-field-title span class=field-contenta href=/en/blog/bypassing-form-validations-and-required-fields-drupal-bfv-moduleBypassing Form Validations and Required Fields in Drupal: the BFV module./a/span /div/li li class=views-row views-row-5 views-row-odd div class=views-field views-field-title span class=field-contenta href=/en/blog/deploying-drupal-pro-part-1-file-structureDeploying Drupal Like a Pro - Part 1: File Structure/a/span /div/li li class=views-row views-row-6 views-row-even div class=views-field views-field-title span class=field-contenta href=/en/blog/calling-net-framework-and-net-assemblies-phpCalling .Net Framework and .Net Assemblies from PHP/a/span /div/li li class=views-row views-row-7 views-row-odd div class=views-field views-field-title span class=field-contenta href=/en/blog/decent-pdf-generation-drupalDecent PDF generation in Drupal/a/span /div/li li class=views-row views-row-8 views-row-even div class=views-field views-field-title span class=field-contenta href=/en/blog/using-linq-language-integrated-queries-drupal-or-how-write-queries-x5-fasterUsing LINQ (Language Integrated Queries) in Drupal or how to write queries x5 faster/a/span /div/li li class=views-row views-row-9 views-row-odd div class=views-field views-field-title span class=field-contenta href=/en/blog/adding-products-attributes-cart-programmatically-using-ubercartAdding products with attributes to cart programmatically using Ubercart/a/span /div/li li class=views-row views-row-10 views-row-even views-row-last div class=views-field views-field-title span class=field-contenta href=/en/blog/drupal-add-new-operators-views-filters-such-contained-csv-or-how-override-default-viewsDrupal: Add new operators to views filters (such as contained in CSV) or how to override default view#039;s handlers/a/span /div/li /ul/div /div /div
Categories: Drupal Feeds

hussainweb.me: Drupal Meetup Bangalore – March and April 2016

Sat, 04/30/2016 - 11:25pm
Things have gotten busy after DrupalCon Asia which meant that the Drupal meetup we hold in Bangalore every month was a little difficult to organize. Srijan Technologies stepped up and offered their office space in Whitefield, Bangalore. They also took care of snacks and even lunch for all the attendees. Kudos to Srijan for organizing the meetup. Thank you!
Categories: Drupal Feeds

DrupalEasy: Drupal 6 to Drupal 8(.1.x) Custom Content Migration

Sat, 04/30/2016 - 7:45am
pemNote: This blog post is based on Drupal 8.1.x. It is an updated version of a a href=https://www.drupaleasy.com/blogs/ultimike/2016/03/drupal-6-drupal-80x-custom-content-migrationprevious tutorial based on Drupal 8.0.x/a. While the concepts are largely the same as 8.0.x, a refactoring of the core migrate modules took place in Drupal 8.1.x (a href=https://www.drupal.org/node/2625696migrations will become plugins in 8.1.x/a). This updated tutorial updates the previous example to work with Drupal 8.1.x, as well as demonstrates how to specify a migration group and run the migration with Drush. If you're familiar with the previous tutorial, you may want to skip to the Rolling up our sleeves section below./em/p pEven if you're only casually acquainted with Drupal 8, you probably know that the core upgrade path to Drupal 8 has been completely rewritten from the ground-up, using many of the concepts of the a href=https://www.drupal.org/project/migrateMigrate/a and a href=https://www.drupal.org/project/migrate_d2dDrupal-to-Drupal migration/a modules. Using the a href=https://www.drupal.org/project/migrate_upgradeMigrate upgrade/a module, it is possible to migrate much of a Drupal 6 (or Drupal 7) site to Drupal 8 with a minimum of fuss (DrupalEasy.com is a prime example of this). Migrate upgrade is similar to previous Drupal core upgrade paths - there are no options to pick-and-choose what is to be migrated - it's all-or-nothing. This blog post provides an example of how to migrate content from only a single, simple content type in a Drupal 6 site to a Drupal 8.1.x site, without writing any PHP code at all./p h2Setting the table/h2 pFirst, some background information on how the Drupal 8 Migrate module is architected. The Migrate module revolves around three main concepts:/p ulliSource plugins - these are plugins that know how to get the particular data to be migrated. Drupal's core Migrate module only contains base-level source plugins, often extended by other modules. Most Drupal core modules provide their own source plugins that know how to query Drupal 6 and Drupal 7 databases for data they're responsible for. For example, the Drupal 8 core Node module contains source plugins for Drupal 6 and Drupal 7 nodes, node revisions, node types, etc… Additionally, contributed and custom modules can provide additional source plugins for other CMSes (WordPress, Joomla, etc…), database types (Oracle, MSSQL, etc…), and data formats (CSV, XML, JSON, etc.) /li liProcess plugins - these are plugins designed to receive data from source plugins, then massage it into the proper form for the destination on a per-field basis. Multiple process plugins can be applied to a single piece of data. Drupal core provides various a href=https://www.drupal.org/node/2129651useful process plugins/a, but custom and contributed modules can easily implement their own./li liDestination plugins - these are plugins that know how to receive data from the process plugins and create the appropriate Drupal 8 thing. The Drupal 8 core Migrate module contains general-purpose destination plugins for configuration and content entities, while individual modules can extend that support where their data requires specialized processing. /li /ulpTogether, the Source -gt; Process -gt; Destination structure is often called the pipeline./p pIt is important to understand that for basic Drupal 6 to Drupal 8 migrations (like this example), all of the code is already present - all the developer needs to do it to configure the migration. It is much like preparing a meal where you already have a kitchen full of tools and food - the chef only needs to assemble what is already there./p pThe configuration of the migration for this example will take place completely in two custom .yml files that will live inside of a custom module. In the end, the custom module will be quite simple - just a .info.yml file for the module itself, and two .yml files for configuring the migration./p h2Reviewing the recipe/h2 pFor this example, the source Drupal 6 site is a large site, with more than 10 different content types, thousands of nodes, and many associated vocabularies, users, profiles, views, and everything else that goes along with an average Drupal site that has been around for 5+ years. The client has decided to rewrite the entire site in Drupal 8, rebuilding virtually the entire site from the ground-up - but they wanted to migrate a few thousand nodes from two particular content types. This example will demonstrate how to write a custom migration for the simpler of the two content types./p pThe external article content type to be migrated contains several fields, but only a few of consequence:/p ulliTitle - the node's title /li liPublication source - a single line, unformatted text field /li liLocation - a single line, unformatted text field /li liExternal link - a field of type link /li /ulpSome additional notes:/p ulliThe Body field is unused, and does not need to be migrated. /li liThe existing data in the Author field is unimportant, and can be populated with UID=1 on the Drupal 8 site. /li liThe node will be migrated from type ext_article to article. /li /ulpSeveral factors make this a particularly straight-forward migration:/p ulliThere are no reference fields at all (not even the author!) /li liAll of the field types to be migrated are included with Drupal 8 core. /li liThe Drupal 6 source plugin for nodes allows a type parameter, which is super-handy for only migrated nodes of a certain type from the source site. /li /ulh2Rolling up our sleeves/h2 pWith all of this knowledge, it's time to write our custom migration. First, create a custom module with only an .info.yml file (a href=https://drupalconsole.comDrupal Console/a's generate:module command can do this in a flash.) List the Migrate Drupal (migrate_drupal) and Migrate Plus modules as dependencies. The Migrate Drupal module dependency is necessary for some of its classes that contain functionality to query Drupal 6 databases, while the Migrate Plus module dependency is required because custom migrations are now plugins that utilize the MigrationConfigEntityPluginManager provided by Migrate Plus (a href=http://mikeryan.name/blog/mikeryan/migration-update-for-drupal-8-1full details in a blog post by Mike Ryan/a)./p pNext, create a migration group by creating a migrate_plus.migration_group.mygroup.yml file. The purpose of a migration group is to be able to group related migrations together, for the benefit of running them all at once as well as providing information common to all the group migrations (like the source database credentials) in one place./p pThe shared_configuration -gt; source -gt; key value of legacy corresponds to a database specified in the Drupal 8 site's settings.php file. For example:/p pNext, create a new migrate_plus.migration.external_articles.yml file in /config/install/. Copy/paste the contents of Drupal core's /core/modules/node/migration_templates/d6_node.yml file into it. This migration template is what all node migrations are based on when running the Drupal core upgrade path. So, it's a great place to start for our custom migration. emNote that the file name begins with migrate_plus.migration - this is what allows our custom migration to utilize the Migrate Plus module's MigrationConfigEntityPluginManager./em/p pThere's a few customizations that need to be made in order to meet our requirements:/p ulliChange the id and label of the migration to something unique for the project. /li liAdd the migration_group: mygroup to add this migration to the group we created above. This allows this migration access to the Drupal 6 source database credentials. /li liFor the source plugin, the d6_node migration is fine - this source knows how to query a Drupal 6 database for nodes. But, by itself, it will query the database for nodes, regardless of their type. Luckily, the d6_node plugin takes an (optional) node_type parameter. So, we add ext_article as the node_type. /li liWe can remove the nid and vid field mappings in the process section. The Drupal core upgrade path preserves source entity ids, but as long as we're careful with reference fields (in our case, we have none), we can remove the field mappings and let Drupal 8 assign new node and version ids for incoming nodes. Note that we're not migrating previous node revisions, only the current revision./li liChange the type field mapping from a straight mapping to a static value using the default_value process plugin. This is what allows us to change the type of the incoming nodes from ext_article to just article. /li liSimilarly, change the uid field mapping from a straight mapping to a static_value of 1, which assigns the author of all incoming nodes to the UID=1 user on the Drupal 8 site. /li liSince we don't have any body field data to migrate, we can remove all the body field mappings. /li liAdd a mapping for the Publication source. On the Drupal 6 site, this field's machine name is field_source, on the Drupal 8 site, the field's machine name is field_publication_source. Since it is a simple text field, we can use a direct mapping. /li liAdd a direct mapping for field_location. This one is even easier than the previous because the field name is the same on both the source and destination site. /li liAdd a mapping for the source External link field. On the Drupal 6 site, the machine name is field_externallinktarget, while on the Drupal 8 site, it has been changed to field_external_link. Because this is a field of type link, we must use the d6_cck_link process plugin (provided by the Drupal 8 core Link module). This process plugin knows how to take Drupal 6 link field data and massage it into the proper form for Drupal 8 link field data. /li liFinally, we can remove all the migration dependencies, as none of them are necessary for this simple migration. /li /ulpThe resulting file is:/p pNote that .yml files are super-sensitive to indentation. Each indentation must be two spaces (no tab characters)./p h2Serving the meal/h2 pTo run the migration, first enable the custom module. The act of enabling the module and Drupal core's reading in of the migration configuration could trigger an error if the configuration isn't formatted properly. For example, if you misspelled the d6_node source plugin as db_node, you'll see the following error:/p precode[Error] The db_node plugin does not exist. /code/prepIf the module installs properly, the Drush commands provided by the a href=https://www.drupal.org/project/migrate_toolsMigrate Tools/a (8.x-2.x-dev - 2016-Apr-12 or later) module can be used to manage the migration. First, use the Drush migrate-status command (alias: ms) can be run to confirm that the migration configuration exists. This is similar to functionality in Drupal 7's Migrate module./p precode~/Sites/drupal8migrate $ drush ms Group: mygroup Status Total Imported Unprocessed Last imported enternal_articles Idle 602 602 0 2016-04-29 16:35:53 /code/prepFinally, using Drush, the migration can be run using the migrate-import (alias: mi) command:/p precode~/Sites/drupal8migrate $ drush mi external_articles Processed 602 items (602 created, 0 updated, 0 failed, 0 ignored) - done with 'external_articles' /code/prepSimilarly, the migration can be rolled back using the drush migrate-rollback (alias: rm) command:/p precode~/Sites/drupal8migrate $ drush migrate-rollback external_articles Rolled back 602 items - done with 'external_articles' /code/prepOnce the migration is complete, navigate over to your Drupal 8 site, confirm that all the content has been migrated properly, then uninstall the custom module as well as the other migrate-related modules./p pNote that the Migrate module doesn't properly dispose of its tables (yet) when it is uninstalled, so you may have to manually remove the migrate_map and migrate_message tables from your destination database./p h2Odds and ends/h2 ulliOne of the trickier aspects about writing custom migrations is updating the migration configuration on an installed module. There are several options: ulliThe a href=https://www.drupal.org/project/config_develConfiguration development/a module provides a codeconfig-devel-import-one/code (cdi1) drush command that will read a configuration file directly into the active store. For example: codedrush cdi1 modules/custom/mymodule/config/install/migrate.migration.external_articles.yml/code/li liDrush core provides a codeconfig-edit/code command that allows a developer to directly edit an active configuration. /li liFinally, if you're a bit old-school, you can uninstall the module, then use the drush php command to run codeDrupal::configFactory()-gt;getEditable('migrate.migration.external_articles)-gt;delete();/code, then reinstall the module. /li /ul/li liSometimes, while developing a custom migration, if things on the destination get really dirty, I've found that starting with a fresh DB helps immensely (be sure to remove those migrate_ tables as well!) /li /ulh2Additional resources/h2 ullia href=https://www.drupal.org/node/2668742Migrations are now plugins change record/a /li lia href=http://mikeryan.name/blog/mikeryan/migration-update-for-drupal-8-1Migration Update for Drupal 8.1/a - blog post by Mike Ryan. /li lia href=http://www.jeffgeerling.com/blog/2016/migrate-custom-json-feed-drupal-8-migrate-source-jsonMigrate a custom JSON feed in Drupal 8 with Migrate Source JSON/a blog post by Jeff Geerling. /li lia href=https://drupalize.me/blog/201604/custom-drupal-drupal-migrations-migrate-toolsCustom Drupal-to-Drupal Migrations with Migrate Tools/a - blog post by William Hetherington. /li /ulpemThanks to a href=https://www.drupal.org/u/mikeryanMike Ryan/a and a href=https://www.drupal.org/u/mu5a5hiJeffrey Phillips/a for reviewing this post prior to publication./em/pdiv class=feedflare a href=http://feeds.feedburner.com/~ff/DrupalEasy?a=HXHuHo9wkbQ:osahgAYBSS8:yIl2AUoC8zAimg src=http://feeds.feedburner.com/~ff/DrupalEasy?d=yIl2AUoC8zA border=0/img/a a href=http://feeds.feedburner.com/~ff/DrupalEasy?a=HXHuHo9wkbQ:osahgAYBSS8:qj6IDK7rITsimg src=http://feeds.feedburner.com/~ff/DrupalEasy?d=qj6IDK7rITs border=0/img/a /divimg src=http://feeds.feedburner.com/~r/DrupalEasy/~4/HXHuHo9wkbQ height=1 width=1 alt=/
Categories: Drupal Feeds

hussainweb.me: Porting token module to Drupal 8

Fri, 04/29/2016 - 11:50pm
Now, token is a module everyone needs and no one knows, especially after token is mostly in core since Drupal 7. How can that still be dev two months after Drupal 8 final?!
Categories: Drupal Feeds

Aten Design Group: Introducing Entity Query API for Drupal 8

Fri, 04/29/2016 - 3:26pm
pDrupal 8 lays the foundation for building robust and flexible RESTful APIs quickly and efficiently. Combine this with Drupal’s best-in-class fieldable entity model and it becomes incredibly easy to construct systems that solve many different problems well./p pOut of the box, Drupal 8 comes with core modules for all of the standard RESTful HTTP methods, GET, POST, PATCH, and DELETE. These endpoints are entity specific. Collection endpoints - endpoints that deal with entities in aggregate - are another story. The solution offered is the Views module./p pIn a headless or API intensive site however, core Drupal 8 and Views are limited by a major shortcoming. Support for querying your entity content over an API is limited to only the custom views that you create. This means that you must first create a view for any content that you want to expose. Filtering is limited to only the filters you explicitly enable and there’s no clear solution for fine-grained control over sorting and paging your results via query strings - the common practice for RESTful APIs. This creates a lot of development overhead for headless and API intensive sites which will inevitably end up with innumerable views./p pCreating publicly available APIs would be worse yet. Typically, you would like a public API to allow your consumers to discover and access your data as they see fit. Managing each view for all your entity types becomes increasingly difficult with every new field added or new entity type. This issue makes sense, the Views module’s original intent was to provide prescribed aggregations of your content, possibly modified by a few contextual items like the current path or the current user. Views were never intended to be an all-purpose query tool for the end user./p pEnter a href=https://www.drupal.org/project/entityqueryapiEntity Query API/a. Entity Query API allows API consumers to make queries against any entity in Drupal. From users, to nodes, to configuration entities, this is an incredibly powerful tool. By creating a standardized set of parameters for crafting these queries, Entity Query API allows developers to create generalized tooling not tied to particular views or entities. Moreover, they need not worry about creating matching views for every collection of content. This ability to let API consumers craft their own result-set further reinforces the separation of concerns between the client and the server./p pEntity Query API does all this by taking advantage of the excellent a href=https://api.drupal.org/QueryInterfaceQueryInterface/a provided by Drupal Core. The module simply translates your request URI and associated query string into an entity query on the backend, executes it, and returns the results as JSON. By using this, we also get the built in access control that Drupal entity queries provide./p pEntity Query API is still in alpha (as of April 2016), but it fully supports everything that you can do with an entity query in code, i.e., conditions, condition groups, sorting, ranges, etc. Like the REST UI module, we have a similar configuration page for enabling queryable entities. We support all core authentication methods as well as a href=https://www.drupal.org/project/jwtJSON Web Token Authentication/a (another module we’ve built). In future, we’d like to dynamically collect any authentication providers available, just like the REST UI module./p pI’m going to be sprinting on Entity Query API at DrupalCon New Orleans on Monday, May 9th 2016 and during the after-DrupalCon sprints on Friday, May 13th 2016. We’d like to add support for other encodings like XML and HAL+JSON (currently the module just supports JSON). Finally, we’d like to add the option to retrieve just entity IDs instead of fully loaded entities./p pAs always, there’s plenty of work to be done in open source. If you’re interested in Entity Query API, come find me during the sprints or send me a tweet anytime during DrupalCon, my handle is @gabesullice. Of course, the easiest way to help is just to a href=https://www.drupal.org/project/entityqueryapidownload the module/a and report any bugs you find. Finally, if you're going to be at DrupalCon New Orleans, stop by the Aten booth, I'd love to hear your ideas and feedback!/p
Categories: Drupal Feeds

Chapter Three: How to Host Drupal 8 on DigitalOcean

Fri, 04/29/2016 - 3:21pm
span data-quickedit-field-id=node/2126/title/en/rss class=field field--name-title field--type-string field--label-hiddenHow to Host Drupal 8 on DigitalOcean/span div data-quickedit-field-id=node/2126/body/en/rss class=clearfix text-formatted field field--name-body field--type-text-with-summary field--label-hidden field__itempimg alt=How to Host Drupal 8 on DigitalOcean data-entity-type=file data-entity-uuid=81d1063c-5f91-46ba-b106-6fe76299c835 src=/sites/default/files/inline-images/do_0.jpg style=margin: 0 0 10px 10px; class=align-right /These are instructions on how to setup DigitalOcean droplet to host your personal website. a href=https://www.digitalocean.com/ target=_blankDigitalOcean/a is a very affordable cloud hosting for developers (starting from $5 for a very simple droplet 512MB Memory / 1 CPU and 20GB disk)./p/div span data-quickedit-field-id=node/2126/uid/en/rss class=field field--name-uid field--type-entity-reference field--label-hiddenspan title=View user profile. href=/about/minnur-yunusov lang= about=/about/minnur-yunusov typeof=schema:Person property=schema:name datatype=Minnur Yunusov/span/span span data-quickedit-field-id=node/2126/created/en/rss class=field field--name-created field--type-created field--label-hiddenApril 29, 2016/span
Categories: Drupal Feeds

DrupalCon News: PM FTW: Need-to-See Sessions BoFs to blow your minds

Fri, 04/29/2016 - 11:31am
div class=field field--name-body field--type-text-with-summary field--label-hiddendiv class=field__itemsdiv class=field__item evenp dir=ltrI’ll never forget the day that I talked to Angie at DrupalCon London and asked her who the community Project Managers were. There were none. I was floored. How could something so essential, useful amp; critical to success be overlooked? That was the state of our community as I saw it then: nonexistent. Who were the Project Managers in the Drupal Community? I didn’t know a single one in 2011./p/div/div/div
Categories: Drupal Feeds

agoradesign: Why it is a bad idea to do function calls on injected services during instantiation in Drupal 8

Fri, 04/29/2016 - 11:17am
div class=field field-name-body field-type-text-with-summary field-label-hidden div class=field-items div class=field-item evenToday I was tracking down a strange issue with a form submission and validation, which finally turned out to be the consequence of an unobvious wrong function call inside a class constructor./div /div /div
Categories: Drupal Feeds

Acquia Developer Center Blog: BigPipe in Drupal: Bigger, Better Performance for Free

Fri, 04/29/2016 - 10:05am
div class=field field-name-field-podcast-image field-type-image field-label-hiddendiv class=field-itemsdiv class=field-item evenimg typeof=foaf:Image src=https://dev.acquia.com/sites/default/files/styles/blog_node_image/public/podcast/images/file_llama_with_numbers_svg_-_wikipedia_the_free_encyclopedia_0.jpg?itok=zDlMoJcx width=340 height=260 alt=Wim lloves llamas title=Wim lloves llamas //div/div/divdiv class=field field-name-body field-type-text-with-summary field-label-hiddendiv class=field-itemsdiv class=field-item even property=content:encodedp a href=https://www.drupal.org/u/wim-leersWim Leers/a, Senior Software Engineer in the Acquia Office of the CTO (aka “OCTO”), has been busy in the last few years making Drupal 8 amazing! His contributions include working with a href=https://www.drupal.org/u/fabianxFabian Franz/a on aspects of Drupal’s new caching and rendering systems to make Drupal 8 performant. Today’s podcast is a conversation he and I had about who he is and what he’s been up to following our own collaboration preparing a href=https://dev.acquia.com/blog/drupal-8-module-of-the-week/drupal-8-module-of-the-week-bigpipe/22/01/2016/9566my own post on BigPipe/a. /p p Below is a transcript of parts of the conversation you can hear in full in the audio and video versions of this podcast. In the audio and video versions, we also touch on: /p ulliaspects of contribution and the professionalization of contribution in open source, especially in the light of Wim being paid by Acquia to be a full-time contributor to Drupal. /li lihow even small contributions, like a well-written bug report, add up to making a big difference ... and my daughter’s commit credit in Drupal 8 :-) /li liHierarchical Select module /li liMany hands making light work in open source /li liPlus everything below about caching, BigPipe, performance, and more in the transcript! /li /ulh2 Learn more about BigPipe in Drupal 8br //h2 ulliWatch Wim’s webinar with Fabien Potencier, a href=https://www.acquia.com/resources/webinars/best-practices-drupal-performance-tuningBest Practices for Drupal Performance Tuning/a. It covers BigPipe, caching, profiling, and more at a high level. /li liWim goes into a lot more detail about Drupal 8 and BigPipe in his webinar, a href=https://www.acquia.com/resources/webinars/bigpipe-architecture-behind-fastest-version-drupal-yetBigPipe: The Architecture Behind the Fastest Version of Drupal Yet/a. /li liWim and Fabian gave two sessions on caching and BigPipe at DrupalCon Barcelona: /li li a href=https://events.drupal.org/barcelona2015/sessions/caching-edge-cdns-everyoneCaching at the Edge: CDNs for everyone/a /li li a href=https://events.drupal.org/barcelona2015/sessions/making-drupal-fly-fastest-drupal-ever-hereMaking Drupal fly - The fastest Drupal ever is here!/a /li liCheck out a href=https://dev.acquia.com/blog/drupal-8-module-of-the-week/drupal-8-module-of-the-week-bigpipe/22/01/2016/9566my post about BigPipe/a in the a href=https://dev.acquia.com/blog/drupal-8-module-of-the-weekDrupal 8 Module of the Week series/a. /li /ulh2 Interview video - 41 minutesbr //h2 piframe width=640 height=360 src=https://www.youtube.com/embed/7rbUyv3hYDc frameborder=0/iframe/p blockquotep BigPipe in a nutshell: “What matters in the end is not the number of requests, but how fast it actually feels for the end-user because that's what you care about and that's where BigPipe makes a huge difference. - Wim Leers /p/blockquote h2 Guest dossierbr //h2 ulliName: Wim Leers /li liWork affiliation: Senior Software Engineer, Acquia Office of the CTO /li liDrupal.org: a href=https://www.drupal.org/u/wim-leerswim-leers/a /li liTwitter: a href=https://twitter.com/wimleers@wimleers/a /li liLinkedIn: a href=https://www.linkedin.com/in/wimleersWim Leers/a /li liGitHub: a href=https://github.com/wimleerswimleers/a /li liBlog/Website: a href=http://wimleers.com/http://wimleers.com//a - Hello! My name is Wim and I’m interested in a href=http://en.wikipedia.org/wiki/Web_Performance_OptimizationWPO/a, a href=http://drupal.org/Drupal/a and data mining. I’ve worked on a href=http://wimleers.com/tags/facebookFacebook/a’s Site Speed team. And I love llamas. /li liDrupal/FOSS role: Drupal core contributor /li li1st version of Drupal: Drupal 5 beta /li /ulp img alt=BigPipe loading principle demo gif src=/sites/default/files/podcast/images/bigpipe_page_loading.gif //p h2 Partial Transcriptbr //h2 h3 How did you discover Drupal?br //h3 p strongWim:/strong I was going to build this website – or I needed to build a website but I was looking for a way that will allow me to set up a website that was maintainable, that didn’t require too much digging around in code, and that looks like it would be a good choice for the long run. I looked at WordPress, at Joomla, at Drupal, and I think a few others maybe, but Drupal stood above the rest like it was the obvious better choice back then, I believe. It was the time of Drupal 5.0 being in active beta. 4.7 was I think the active version. I never used that. I jumped straight to the beta because it looked much better. /p p strongjam:/strong I had the joy of installing 4.6 and 4.7. The good old days. Wow. Drupal 5.0 was such a massive leap at that time. /p p Why did you stick with it now for nine years? /p p strongWim:/strong Yes. I got kind of rolled deeper into the community as I think is the story for many of us. That was 2006 - the end of 2006. It was the Christmas break at my first year of University. I was trying to actually do less work on this Open-source project that I was working on before by building a website so that others could maintain it. So it’s kind of funny that I used Drupal 4 and other Open-source projects. In doing so, I needed a few things to be built myself in order for this website to really function well. So I started working on that and then I noticed - back then it was very easy to get an account that allows you to create a project, a module on Drupal.org. Right now, we have to go through a quite tough review process or back then at least, there was not review process. It was just if they saw you on IRC quite a few times, “Yes, sure, you can get an account.” /p p strongjam:/strong The pendulum swings back and forth on that one. /p p strongWim:/strong I know. /p p strongjam:/strong We’ve been in a fairly Draconian period recently. /p h3 The path to becoming a performance expertbr //h3 blockquotep ... from doing something Open-sourcey to choosing Drupal because it seemed the best, to then getting annoyed by sites being slow and then looking at how Drupal could be faster for a Bachelor thesis, to them better understanding it through my Master thesis and at Facebook and then eventually, I ended up at Acquia. It’s a path that has definitely been big, mutually influenced by Drupal. /p/blockquote p strongWim:/strong Yes. I don't know the details. At any case, back then it was very easy. That’s all that matters. That’s why I managed to publish a module very early on and that started to get quite a few users and get more users and I found it interesting that my module that was growing in feature sets and getting more and more users on the hundreds of websites using it. That was so fascinating to me that I kept working on it and improving it more. Then, I got freelance work doing that in the summer so instead of having a crappy student job for the summer, I managed to do freelance work while further developing this module. So that led to more freelance development and that led to my bachelor thesis being about Drupal and CDNs so performance in general, but then a few years later led to my master thesis being about Drupal, not very strictly Drupal but again performance. Performance plus data mining to better understand why a site is slow in certain scenarios. That basically led to Drupal being a significant part or significant presence during my entire period of studying computer science. /p p strongjam:/strong What was that first module? /p p strongWim:/strong Hierarchical select. /p p strongjam:/strong Picking up at your Master's thesis, talk about your work in performance and where that’s led you. /p p strongWim:/strong Yes. It’s quite interesting to see how Drupal allowed me to do a bachelor’s thesis on Drupal plus CDN to make Drupal faster. Then I wanted to better understand in which scenarios a site could still be slow so for example when accessed from a certain region even while using a CDM or when using a particular browser or maybe a particular piece of JavaScript was slow in a particular browser. Those kind of things, figuring that that that is quite difficult. People complain it’s slow, but they don’t really explain why, or it’s normal, that’s regular, and users if you will – non-technical people will just complain and say it’s broken or slow but will not be able to pinpoint that’s the exact reason. /p p There can be so many reasons and it can be very difficult to simulate that, to actually see it happen in front of you as a developer. So for my Master’s thesis, I worked on data mining and collecting performance information, performance data. So applying data mining on the performance data allowed me to automatically figure out which situations, which combinations were slow. So then it will allow you to see which exact scenarios are also the things that are most commonly slow. Therefore, our most worth attention from a person fixing them to look into those problems. From that point of view ... And I published that Master thesis and a series of blog posts about that ... Somehow, a person at Facebook discovered that or stumbled upon that and he reached out to me. He was from the – what was called back then the Site Speed Team. I first, I literally didn't believe it that there was a person from Facebook contacting me. I was looking at the email headers to figure out if it was spoofed or something. /p p strongjam:/strong Somebody’s pranking you. /p p strongWim:/strong Yes, yes. Exactly. That's what I thought. So it looked like it checked out. I was saying, “Okay. Let’s send a reply, I guess.” Then, two days later, I think I had an informal Skype call with that person and it looked like they were at Facebook office or something, Silicon-Valley-like in his background. /p p strongjam:/strong Because you could tell. /p p strongWim:/strong Well, it looked like he at least wasn't in a cellar somewhere pranking me. It was somewhat legit looking. Yes, then I had phone interviews and I think I actually was asked in the beginning even to do a full-time position but I was still studying so I asked if it was possible to do an internship instead and so that’s how I ended up doing an internship there while continuing to work on that same data mining and performance data project piece of software that I started for my Master thesis. They’ve led me to an interesting place so from doing something Open-sourcey to choosing Drupal because it seemed the best, to then getting annoyed by sites being slow and then looking at how Drupal could be faster for a Bachelor thesis, to them better understanding it through my Master thesis and at Facebook and then eventually, I ended up at Acquia. It’s a path that has definitely been big, mutually influenced by Drupal. /p h3 On to making Drupal fasterbr //h3 p strongjam:/strong Your biggest contribution to Drupal 8 has also been in the performance area. Would you like to talk about caching and cache tags and BigPipe? /p p strongWim:/strong Sure. I've now been working on Drupal and working at Acquia full-time for about three and a half years, close to four. The first part of that was Spark, so authoring experience. That's a WYSIWYG editing CKEditor, the toolbar to it to some extent – those kinds of things. /p p strongjam:/strong You came in during the Spark initiative? /p h3 Cache Tags, Render Caching, Cache Invalidationbr //h3 p strongWim:/strong Yes. So that was 2012. Then, for the last one and a half to two years probably, I’ve been working pretty much entirely on performance so making Drupal faster. A big portion of what was looking to be a good candidate for making Drupal 8 significantly faster was cache tags. That was a concept that was added a long time ago, I think even in 2011 or so. But it wasn’t really being used in many places because it was only being used in a handful of places across Drupal Core. For example, entities. So nodes, terms, users did not use them at all even though they seemed like a prime candidate. At the same time we had the concept of render caching which is basically we’re rendering something. Render caching allows you to cache the fragment of the page that is being rendered so that you don’t have to do all of the work of getting the data and then turning that into HTML in the theme system, which can take some time. The point was to use render caching in more places, the most expensive places, for example rendering entities such as nodes and users. That actually made for an interesting overlap between render caching and cache tags because when you have rendered something, you want that data to be updated as soon as the data it depends upon is changed. For example, if you change a node title, you want the render cached nodes to be updated. Otherwise, we’re looking at the old thing. /p p strongjam:/strong Right. Now, I think that just about every one who is listening to this will know this already. But what you’re actually describing is one of the harder problems in computer science. How do you cache something and how do you find out in a cheap way when that cache should be cleared and you have new data and how do you avoid having stale stuff showing up as much as possible? /p p strongWim:/strong Yes. So the saying in computer science goes, “There are two hard problems in computer science, naming things and caching,” or “cache invalidation” I should say. To be clear, I did not invent cache tags. That was something that very smart people came up a long time before me. I had the ability also because I’m working on Drupal core full time to bring cache tags to many places in Drupal core and so that it’s an inherent part almost of many parts of Drupal core. So I made it sure that for example every single entity, entity type, so whether it’s config entities or nodes or terms, anything that has proper test coverage and whenever those things change, the corresponding cache tag is invalidated which then allows us to have this rendered caches and any other cache to be updated automatically, to be invalidated automatically. Indeed, it’s just a small bit of metadata that is associated with whatever is cached whether it’s rendered or computed or whatever it is. That allows us to very efficiently update those things. Cache tags everywhere makes sure that we can reliably invalidate things and reliably have things update when they should which was an impossible problem to solve in Drupal 7 and before because we didn’t have such a concept. /p p strongjam:/strong And “performantly” as well, if that’s a word. /p p strongWim:/strong Yes, that’s a word. Yes. /p p strongjam:/strong Without huge cost on my server. /p p strongWim:/strong Yes. There is always some cost because there is something additional that needs to happen. You’d have to retrieve something from the cache then check if the cache tags that are associated with it have been invalidated in the meantime. That’s the additional cost. But it’s a pretty small cost. /p p strongjam:/strong That’s a much smaller cost than re-rendering the entire page. /p p strongWim:/strong Yes. Every single time, which is what happened in Drupal 7 before. Actually, to be honest, in most other systems. So most other CMSs on Frameworks or what you quite often see as a solution which is not really a solution is to just assume it’s okay to cache something for five or for ten minutes. But that means that if you as a blogger for example and you fix a typo, your broken title, your wrong title with still that typo in there is going to be there for another 5-10 minutes. So your changes are not showing up right away which is a very annoying, disconcerting experience. /p p strongjam:/strong Sure. It’s a kludge. It’s a hack. I mean Cron versus Poor Man’s Cron comes to mind ... /p p strongWim:/strong Yes. /p h3 BigPipe, Cache Context, Max Age and the Dynamic-ness of thingsbr //h3 p strongjam:/strong Yes. So I’m going to imbed two recent webinar videos that you’ve done on this podcast page [See links above!]. If anyone who’s listening to the podcast, in real time we’re speaking in early 2016, we recently did two webinars at Acquia about a thing called BigPipe and BigPipe is essentially the next step in this conversation. I’m going to imbed those videos and when slides are also going to be available and I’m going to link to all of the stuff that we’re talking about. We’ve got this fantastic caching architecture in place and working in Drupal 8. What is BigPipe and tell us about the magic that it does with all of this stuff? /p p strongWim:/strong Yes. First off, actually the two webinars you were mentioning, the first one is actually a subset of the second one so I would recommend to only link to the second one which concludes everything. So then people have one coherent story. That’s probably going to be useful to them. [Check out all the links above in this post!] /p p strongjam:/strong All right. Okay. Now, BigPipe. /p p strongWim:/strong Yes. So far we talked about cache tags and rendered caching. But cache tags are not the only bit of cacheability metadata that we have in Drupal 8. We have two more. Those three things together actually allow us to know comprehensively and with complete certainty what things it depends on, what it varies by its own. So cache tags are for declaring dependencies on data, for example on entities so that we know when something has changed. But we also have cache context which allows us to define which context something depends on, what it varies by. For example, if jam has user role A and I have user role B and we have access to different things, then the outputs, the rendered HTML, should also be different. Or maybe it says, “Hi jam” or “Hi Wim,” then the output needs to vary by user. So those kinds of variations are what cache contexts are about. So cache tags and context and then there is a third called “max-age” to describe something that expires after a certain period of time. That’s less commonly necessary, max-age zero means that something is absolutely not cacheable so it needs to be requested or updated every single time. But it’s useful for things like maybe temperature data that is okay to cache for – that remains the same across say one minute or two minutes or 10 minutes. /p p So those three things together allow us then to know the dynamicness of every part of the page. In Drupal usually we have blocks. Most people build Drupal sites using the block system. So when blocks are appearing in different parts of the page, very often, some blocks are personalized. For example, the menu block below will only show menu links that are accessible to the current user. Maybe there is a shopping cart, maybe there is a “Hi, jam. Your friends have just sent you so many messages.” Something like that. So those kinds of things are dynamic. Then, usually there’s also parts of the page--and it’s not limited to blocks by the way but that’s just an easy way to think about it. Usually, you have blocks that are the same across users and usually even across everything. So for example, a menu of the footer or a search form like a search block. /p p strongjam:/strong Or the main content. /p p strongWim:/strong The main content, yes. So all of those are actually cacheable across users like if it’s rendered once, we can reuse it for jam, for me, for anybody else. Thanks to those cacheability metadata, so tags, context, and max-age, we know that a given block is going to vary that much. It’s going to be stale at that point when certain entities invalidate it. For example, when jam changes his user name into something like a “Llama” for example. /p p strongjam:/strong Just to pick a random word. /p h3 BigPipe and Perceived Performancebr //h3 p strongWim:/strong Yes. So the fact that we know for any given block what things it depends on, makes us able to know when something is very dynamic and when it’s not. So that allows us to pull out that part of the page, delay rendering it so that we can send the entire page minus the personalized parts first and then send the personalized parts like the “Hi, jam” blog, the shopping carts, those kinds of things, we can send those later. So the difference on this, the perceived performance. How fast a site feels, how fast a site looks and actually just how fast a site shows up. It makes it so that the sites show up instantaneously regardless of user, regardless of the complexity of those dynamic parts of the page because the parts that are the same--which is usually significant parts of a page--those show up immediately. They can be sent right away extremely fast, which means ... /p p strongjam:/strong Usually, when I'm browsing that's the stuff that I actually care about. That’s the article I want to read. That’s the photo I want to see because that's the point of the page and that’s what everybody's getting already and that’s usually pre-cached, ready to go. /p p strongWim:/strong Yes, exactly. /p p strongjam:/strong Barely or not at all dynamic. /p p strongWim:/strong Yes, exactly. Basically, the crucial parts of the page are usually not personalized and in that case we can make that available so, so much faster because Drupal and just about every other system out there, what they do currently is they render everything and only then once every single detail is rendered, then they send it to the end user. That makes it so that you have to wait even for the stupid, smaller things that are maybe not that important to you. Then you have BigPipe which, because of that metadata, it's just a module you can install; you don't have to configure anything. Thanks to that metadata, it can figure out which parts are too dynamic or are very dynamic or personalized. It can delay the rendering of that. Send the majority of the page first and then send the dynamic parts later. That makes for a much, much faster experience. We're trying to get that into Drupal 8.1 and it looks like many people are happy with that [BigPipe is an experimental core module in Drupal 8.1!]. It will not be enabled by default. It will even be marked as an experimental module at first because we want to make sure that it works in even the most extreme cases. So it's better to first have it experimental so sites can opt into it so we can get more experience and then hopefully in 8.2 we can make it a non-experimental module. That will be a great performance boost with no efforts basically for every site. /p p strongjam:/strong So cache tags rendering, cache context, all of that is in Drupal 8 and on always by default and I don’t have to think about it. I’m just benefitting from your work. /p p strongWim:/strong Yes. Yes. /p p strongjam:/strong As of the beginning of February 2016, if I want to take advantage of this delivery mechanism which builds on techniques, that’s called the BigPipe module? /p p strongWim:/strong Yes. /p p strongjam:/strong And as of Drupal 8.1 or 2 or probably you're moving that into Core as well. [In core as of Drupal 8.1!] /p p strongWim:/strong Yes. /p p strongjam:/strong Wow. Exciting. /p p strongWim:/strong Yes. It is very exciting. Actually, this is actually a technique not invented by us. I should say by the way that it was not just me who worked on this. Fabian Franz also from Germany by the way. /p p Thank you, Fabian! Thank you, Facebook! /p p strongjam:/strong Thank you, Fabian. /p p strongWim:/strong Yes, thank you, Fabian. He did a great amount of work. He did the initial pioneering, the initial proof of concept. I worked a lot with him to actually make it happen and get it to a more final state, but he did a lot of the work. Even Fabian didn’t invent this. It’s a technique pioneered by Facebook. They invented or published about this some years ago. I forget the exact ... /p p strongjam:/strong No, no, no. When you were an intern there… /p p strongWim:/strong No, no, no. /p p strongjam:/strong You used all the documentation and you snuck it on to a photocopier and smuggled it out. /p p strongWim:/strong Then, I probably would be in trouble. No. /p p strongjam:/strong Wim Leers, master software spy! /p p strongWim:/strong That’s actually a pretty cool title. I should try to get that to happen. Yes, they pioneered it. The whole point is that currently, or in the classical way of delivering webpages, what happens is first you do a request, then the server does work, you wait, you wait, you wait. You have a blank screen you’re looking at. Then the server sends a bunch of things. Then the client – the browser has to fetch all the CSS, the JavaScript, the images and can only then start rendering. So it's a sequential process and BigPipe allows us to make that a more parallel process where the browser immediately gets a response, not with everything, but with probably the majority if not all of the CSS and JavaScript and images so it can start downloading and rendering that already. Then dynamic parts show up. That’s the reason it’s called BigPipe in the sense that it becomes a bigger pipe along which to send things because things are happening in parallel instead of in sequence. /p p strongjam:/strong All right. Wim, this is so interesting. a href=https://dev.acquia.com/blog/drupal-8-module-of-the-week/drupal-8-module-of-the-week-bigpipe/22/01/2016/9566I wrote a small post about this/a and I did some research into this and every new thing I find out about it, it's just so exciting. It's such a great bit of technology. Thank you Fabian from Tag1 Consulting for all of your work. Fabian Franz. Thank you Wim for your amazing work on this. I am going to link to everything that we’ve been talking about and I’m going to embed the webinar videos where people can learn a lot more about the technical nitty-gritty of all this [see links above!]. Wim, I guess you're working on getting this into Core now, right? That’s pretty much your job right now? /p p strongWim:/strong No, I’m working on other things as well but that is one of the things that I’m going to focus on in the next few weeks. Yes. /p p strongjam:/strong Fantastic. /p p strongWim:/strong I’m very happy. I wanted to get this into Drupal ever since I read about it on Facebook’s engineering blog. It’s finally to the point where it already works. You can download it for 8.0 if you’re running Drupal 8 already. It will hopefully be in 8.1. It’s great that Open-source is then able to get this awesome technique which doesn't require any infrastructure which usually is the case for making things faster. You usually need a lot of infrastructure and money and servers. It’s just a more efficient way of delivering HTML and getting the browsers around the stuff. I'm very excited that it’s going to be available in an Open-source project like Drupal. As far as I know, nothing else has something like this so pretty cool. /p p strongjam:/strong I'm working through the title for this podcast in my mind . It's got to be something like “Bigger, Better Performance for Free,” right? Actually, the point that you only just touched on now that I hadn’t thought of this morning of course was you don’t need massive parallel server infrastructure and all this stuff to get things really, really cracking. In this case, you get like a ton more bang for your buck out of Drupal now, just with the all of this default stuff that’s… /p p strongWim:/strong Yes, because usually people measure things in terms of requests per second. That is actually going to be identical with BigPipe. The entire duration of a request is going to be the same. It's just that we send useful information much earlier and then continue to send additional things, the dynamic parts later. So if you look at those traditional things to measure which are easy to measure but don't actually give you a good idea of how fast a site is, because what matters in the end is not the number of requests but how fast it actually feels for the end-user because that's what you care about and that's where BigPipe makes a huge difference. /p p strongjam:/strong Wim, thank you for taking the time to talk with me this morning. It's been so great. It’s so interesting and thanks for everything that you've been doing. It’s great, and keep up the good work. /p p strongWim:/strong Thank you. Yes. Thanks for having me, and maybe see you next time and have a great day. /p /div/div/divdiv class=field field-name-field-podcast-audio field-type-file field-label-hiddendiv class=field-itemsdiv class=field-item evenaudio controls=controlssource src=https://dev.acquia.com/sites/default/files/podcast-audio/bigpipe-caching_d8_wim_leers.mp3 type=audio/mpeg //audio/div/div/divdiv class=field field-name-field-podcast-series field-type-taxonomy-term-reference field-label-inline clearfixdiv class=field-labelPodcast series:nbsp;/divdiv class=field-itemsdiv class=field-item evena href=/podcast-series/drupal-8 typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Drupal 8/a/div/div/divdiv class=field field-name-field-skill-level field-type-taxonomy-term-reference field-label-inline clearfixdiv class=field-labelSkill Level:nbsp;/divdiv class=field-itemsdiv class=field-item evena href=/skill-level/beginner typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Beginner/a/divdiv class=field-item odda href=/skill-level/intermediate typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Intermediate/a/divdiv class=field-item evena href=/skill-level/advanced typeof=skos:Concept property=rdfs:label skos:prefLabel datatype=Advanced/a/div/div/div
Categories: Drupal Feeds

qed42.com: Pune Drupal Group Meetup, April 2016

Fri, 04/29/2016 - 9:59am
span property=schema:name data-quickedit-field-id=node/140/title/en/rss class=field field--name-title field--type-string field--label-hiddenPune Drupal Group Meetup, April 2016/span div data-quickedit-field-id=node/140/body/en/rss class=clearfix text-formatted field field--name-body field--type-text-with-summary field--label-above div class=field__labelBody/div div property=schema:text class=field__itempThe monthly Pune Drupal Group Meetup for April was hosted by a href=http://www.qed42.com/QED42/a. The second PDG meetup to take place in the month of April, You would assume meeting this often would get tiring for other people but not us! We Drupalers love a good catchup session./p pThe first session was kicked off by a href=https://www.drupal.org/u/prashant114606Prashant/a and a href=https://www.drupal.org/u/rahul01Rahul/a, Interns at QED42 and they spoke on, Our experience with Drupal. They explained about their journey as new comers to Drupal, from the lenses of both CMS and the community. Their confusion at the beginning, the new tech and softwares they have learned, their experience at Drupalcon Asia and their love for the community. A really enjoyable session peppered with ernest observations and cute cat pictures and a brilliant first time attempt. Bravo boys!/p img alt=Rahul and Prashant data-entity-type=file data-entity-uuid=817511a1-4fb1-4e58-872f-0f79601cb5ac height=622 src=/sites/default/files/inline-images/20160429_205102.jpg width=829 class=align-center /p /p pThe second session was taken by a href=https://www.drupal.org/u/manavArjun Kumar /aof QED42 on,Introduction to CMI. With a brief on CMI and the difference from the features land, he concluded with a demo./p img alt=Arjun CMI data-entity-type=file data-entity-uuid=68ef8616-e00d-426b-85fd-ceb38799cb7f height=636 src=/sites/default/files/inline-images/AuogbkMzqC5-6dGHBcmsmfV9YKjhD8ZOgKno1YgWcZjH_1.jpg width=848 class=align-center /p /p pAfter a short discussion on the probable date and location for Pune Drupal Camp we broke off for BOF sessions,with a href=https://www.drupal.org/u/navneet0693Navneet /aleading the discussion on Acquia certifications and further discussions on CMI./p img alt=BOF data-entity-type=file data-entity-uuid=17c969ce-4731-47ca-a405-9ab42c68b5d5 height=489 src=/sites/default/files/inline-images/BOF_0.jpg width=869 class=align-center /pWith 20 people in attendence we concluded the PDG april meetup with delicious Pahadi Sandwiches in our tummy. Have a great weekend and see you soon!/p p /p /div /div span data-quickedit-field-id=node/140/uid/en/rss rel=schema:author class=field field--name-uid field--type-entity-reference field--label-hiddenspan lang= about=/user/33 typeof=schema:Person property=schema:name datatype=aurelia.bhoy/span/span span property=schema:dateCreated content=2016-04-29T14:59:27+00:00 data-quickedit-field-id=node/140/created/en/rss class=field field--name-created field--type-created field--label-hiddenFri, 04/29/2016 - 20:29/span
Categories: Drupal Feeds

InternetDevels: The Best Drupal eCommerce Websites

Fri, 04/29/2016 - 8:14am
div class=field field--name-field-preview-image field--type-image field--label-hiddendiv class=field__itemsdiv class=field__item evenimg src=http://st2.internetdevels.net/sites/default/files/public/blog_preview/ecommerce_websites.jpg width=864 height=577 alt=The Best Drupal eCommerce Websites //div/div/divdiv class=field field--name-body field--type-text-with-summary field--label-hiddendiv class=field__itemsdiv class=field__item evenpNowadays, lots of companies can benefit from having their own ecommerce sites. It allows brands to sell anything from physical products up to consultations and appointments. In one of our previous blogs, we outlined the main points as to a href=http://internetdevels.com/blog/drupal-is-the-best-solution-for-ecommerce-websiteswhy Drupal is the one stupendous solution for your ecommerce website/a. Today, we’ll take you on one of the most enthralling journeys and show you a variety of outstanding examples of ecommerce websites that incorporate Drupal. So come aboard!/p a href=http://internetdevels.com/blog/best-drupal-ecommerce-websitesRead more/a/div/div/div
Categories: Drupal Feeds

Mediacurrent: Friday 5: 5 Ways to Connect with Mediacurrent at DrupalCon

Fri, 04/29/2016 - 7:55am
img typeof=foaf:Image src=http://d1l4od7sxc8nwf.cloudfront.net/sites/default/files/styles/thumb_blog_spotlight/public/friday-5-blog-graphic.png?itok=_cbspLjG width=200 height=171 alt=Mediacurrent Friday 5 Logo title=Mediacurrent Friday 5 Logo / pWe hope you've had a great week!/p pspan style=line-height: 1.538em;Thanks for joining us for Episode 7 of the Mediacurrent Friday. Planning on attending DrupalCon next month in New Orleans? If so, you won't want to miss /spanspan style=line-height: 1.538em;Marketing Director Shellie Hutchens give you strong5 Ways to Connect with Mediacurrent at DrupalCon./strong/span/p
Categories: Drupal Feeds