PHP Classes

File: README.md

Recommend this page to a friend!
  Classes of Stefano Azzolini   mu   README.md   Download  
File: README.md
Role: Documentation
Content type: text/markdown
Description: Documentation
Class: mu
Handle HTTP requests using callback functions
Author: By
Last change:
Date: 21 days ago
Size: 3,110 bytes
 

Contents

Class file image Download

µ

a PHP micro URL router in only 140 bytes. (99 bytes in hardcore branch)

Scrutinizer Quality Score

Warning: This is a pure proof of concept of a tweet-sized URL router

DO NOT USE IT IN PRODUCTION!

class µ{static function __callStatic($n,$a){static$r;$n==@_?($_=@$r[getenv(REQUEST_METHOD).getenv(REQUEST_URI)])&&$_():$r[$n.$a[0]]=$a[1];}}

How to use

Step 1: Define routes callbacks

µ::GET('/',function(){
    echo 'What is your name?';
    echo '<form method=post><input type=text name=username><input type=submit></form>';
});

µ::POST('/',function(){
    echo 'Hello ',$_POST['username'],', how are you?';
});

Step 2: Run the app


µ::_();

Step 3: Breath.

Thanks

celtric

David Pennington (Xeoncross)

Tyler Romeo (Parent5446)

Commented source


class µ {
    public static function __callStatic($functionName,$functionParameters){
        static $callbackMap;
        
        // Check if we must resolve the request
        if($functionName == '_'){
        
            // Compose the method+uri key and
            // invoke the callback (silence failures)
        
            ($callback = @$callbackMap[getenv(REQUEST_METHOD).getenv(REQUEST_URI)]) && $callback();
        
        } else {
        
            // Add the route handler to the callbackMap
            // $functionName is the Request HTTP Method
            // $functionParameters[0] is the route
            // $functionParameters[1] is the callback
        
            $callbackMap[$functionName.$functionParameters[0]] = $functionParameters[1];
        }
    }
}

License (MIT)

Copyright (c) 2012 Stefano Azzolini

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Bitdeli Badge