From 0c90e94864a19cdde2a7aee28b89898c2818cc54 Mon Sep 17 00:00:00 2001 From: zach Date: Sat, 12 Jul 2008 04:12:47 -0400 Subject: First volly at a Twitter-compatible API. Just working out the detials of 1) Basic Auth and 2) dispatch to the right Action class files to handle the requests. You can hit it with... http://localhost/laconica/api/public_timeline.json or to try Basic Auth you can try something like: http://nickname:password@localhost/laconica/api/statuses/friends_timeline.xml Although that actual method isn't done yet, so it should authenticate and then complain. darcs-hash:20080712081247-ca946-acd3e0e2762c7d9ff0cb3cd7a53cfdfcc5b26660.gz --- actions/api.php | 93 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 93 insertions(+) create mode 100644 actions/api.php (limited to 'actions/api.php') diff --git a/actions/api.php b/actions/api.php new file mode 100644 index 000000000..21404e331 --- /dev/null +++ b/actions/api.php @@ -0,0 +1,93 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +// XXX: Not sure of terminology yet... maybe call things "api_methods" insteads of "commands" + +class ApiAction extends Action { + + function handle($args) { + parent::handle($args); + + $command = $this->arg('command'); + + # XXX Maybe check to see if the command actually exists first + + if($this->requires_auth($command)) { + if (!isset($_SERVER['PHP_AUTH_USER'])) { + + # This header makes basic auth go + header('WWW-Authenticate: Basic realm="Laconica API'); + + # if the user hits cancel -- bam! + common_show_basic_auth_error(); + } else { + $nickname = $_SERVER['PHP_AUTH_USER']; + $password = $_SERVER['PHP_AUTH_PW']; + $user = common_check_user($nickname, $password); + + if ($user) { + $this->process_command($command, $nickname, $password); + } else { + # basic authentication failed + common_show_basic_auth_error(); + } + } + + } else { + $this->process_command($command); + } + } + + # this is where we can dispatch off to api Class files + function process_command($command, $nickname=NULL, $password=NULL) { + + $parts = explode('.', $command); + $api_action = "api_$parts[0]"; + $extension = $parts[1]; # requested content type + + $api_actionfile = INSTALLDIR."/actions/$api_action.php"; + + if (file_exists($api_actionfile)) { + require_once($api_actionfile); + $action_class = ucfirst($api_action)."Action"; + $action_obj = new $action_class(); + + # need to pass off nick and password and stuff ... put in $args? constructor? + # pull from $_REQUEST later? + call_user_func(array($action_obj, 'handle'), $_REQUEST); + } else { + + # need appropriate API error functs + print "\nerror!\n"; + } + } + + # Whitelist of API methods that don't need authentication + function requires_auth($command) { + + # The only command that doesn't in Twitter's API is public_timeline + if (ereg('^public_timeline.*$', $command)) { + return false; + } + return true; + } + +} -- cgit v1.2.3-54-g00ecf