The following warnings occurred: | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Warning [2] Undefined array key "allowautourl" - Line: 584 - File: inc/class_parser.php PHP 8.1.31 (Linux)
|
"Virtual" slugs? - Printable Version +- GetSimple Support Forum (http://get-simple.info/forums) +-- Forum: GetSimple (http://get-simple.info/forums/forumdisplay.php?fid=3) +--- Forum: Developer Discussions (http://get-simple.info/forums/forumdisplay.php?fid=8) +--- Thread: "Virtual" slugs? (/showthread.php?tid=1855) |
"Virtual" slugs? - RobA - 2011-06-17 I've worked with a different CMS and it has an interesting feature that I was trying to determine how to duplicate in GS. (I'm translating terms into GS speak so hopefully this ends up clear). Lets say I want to create a plugin that creates a page of content. To do this currently, as far as I know, I need to create a page, then on the page put in a plugin hook using some short code like (% whatever %). My plugin needs a add_filter hook and does a massage of $content to replace the code with the desired content. This means my plugin parse gets called every page. I'd like to instead have my plugin "register" a slug with GS, such that when the url is to that slug, a function in my plugin gets called to return the page content. Of course, the plugin configuration would also require picking a template to render the page with...or use the default template...? This would allow a page to be generated with much less overhead on all the other pages. Any suggestions/thoughts on this idea? If it worthwhile and how it could be implemented? (In the other software I used they call this feature "custom perma links".) -Rob A> "Virtual" slugs? - mvlcek - 2011-06-17 RobA Wrote:Lets say I want to create a plugin that creates a page of content. I would still create the page in order to have keywords, set the template, set the position in the menu (if needed), etc. Then check for the slug configured in your plugin either before adding the filter Code: if (@$_GET['id'] == myplugin_get_slug_from_config()) { Code: add_filter('content','myplugin_filter'); Even if there was a possibility to "register" a slug in GetSimple, the execution would not be more efficient. (Corrected code, as $id is not available at startup of the plugin) "Virtual" slugs? - ccagle8 - 2011-06-17 Just thinking aloud here: Couldn't you use a check with return_page_slug(), sort of like this: http://get-simple.info/forum/post/14808/#p14808 "Virtual" slugs? - mvlcek - 2011-06-17 ccagle8 Wrote:Just thinking aloud here: Couldn't you use a check with return_page_slug(), sort of like this: Within the filter you can do this (it's equivalent to checking the global $id variable), as it is always called from the frontend. Outside you would have to test first, if it is the frontend, e.g. if (function_exists('return_page_slug')) ... "Virtual" slugs? - Zegnåt - 2011-06-17 RobA Wrote:I need to […] put in a plugin hook using some short code like (% whatever %).No you don’t. Code: add_action('index-pretemplate','changeContent'); RobA Wrote:This means my plugin parse gets called every page.Not necessarily. When your plugin file is being loaded the current page slug is already accessible. Normally the slug is figured out with the following code (from index.php): Code: if (isset($_GET['id'])){ Code: if (isset($_GET['id'])){ ccagle8 Wrote:Couldn’t you use a check with return_page_slug()return_page_slug() is not available to plugins until inside the index-pretemplate hook. So if you are concerned about adding a filter to pages where the filter should not be executed that won’t work. (Or it will, but it will be a very roundabout kind of way.) "Virtual" slugs? - RobA - 2011-06-17 Zegnåt Wrote:RobA Wrote:I need to […] put in a plugin hook using some short code like (% whatever %).No you don’t. @Zegnåt - so that code and this: Code: add_filter('content','changeContent'); do the exact same thing? Which is preferred then? @all - Some good suggestions in general! Thanks. It still seems like a lot of steps to do one thing. Look at the simple case of a contact page. To make a contact page you need to: 1) install the contact plugin. 2) configure the plugin. 3) create new contact page, making sure you add it to the menu, and add the correct plugin code to the page. and the plugin code will be executed for every page (be default) unless the steps suggested were followed. Even with those suggestions, it seems odd to have to create a page (whose content is always overwritten) in order to work. I guess I was thinking of a something in the 404 handler to check "nope, not a real (xml) page", then check to see if any plugins have registered to have a certain slug, and call the registered function to generate content using the default page template, to avoid the need to create a page. -Rob A> "Virtual" slugs? - Zegnåt - 2011-06-17 RobA Wrote:Which is preferred then? The difference is a subtle one and has to do with compatibility. If you want your plugin to support other plugins that use filters — maybe to add certain things in the beginning or the end of the content — you cannot use a filter yourself. If you use a filter to overwrite the content variable, all previously run filters will have their effects overwritten. By overwriting the content variable before the filters are applied all will stay in effect. There are also places, such as certain plugins or GetSimple’s own get_header(), that will use $content without running a filter. Again, overwriting the content variable as soon as you can will make sure these are supported. RobA Wrote:I guess I was thinking of a something in the 404 handler to check "nope, not a real (xml) page", then check to see if any plugins have registered to have a certain slug, and call the registered function to generate content using the default page template, to avoid the need to create a page. This is probably possible right now. You can let your plugin create an XML file that fakes the one used by pages somewhere on the server. Then run something like the following (untested) code: Code: add_action('error-404','notFOF'); After this you will still need to add code into the changedata hook to make sure nobody creates a page using your virtual slug. That might even be the hardest part… maybe I’ll look into that tomorrow. You are right about this being build in to the core would make development way easier! It’s getting late and I’m tired so I hope I’m still making sense ;-) |