Page MenuHomePhabricator

Add WordPress.com OAuth2 plugin
ClosedPublic

Authored by Abbe on May 8 2014, 1:04 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 1, 2:05 AM
Unknown Object (File)
Wed, Jan 1, 2:02 AM
Unknown Object (File)
Mon, Dec 30, 2:25 AM
Unknown Object (File)
Thu, Dec 26, 5:16 PM
Unknown Object (File)
Mon, Dec 23, 9:42 AM
Unknown Object (File)
Mon, Dec 23, 8:10 AM
Unknown Object (File)
Sat, Dec 21, 5:34 AM
Unknown Object (File)
Tue, Dec 17, 11:42 AM
Subscribers

Details

Summary

This plugin provides an OAuth authentication provider to authenticate users using WordPress.com Connect.

This diff corresponds to the github pull request: https://github.com/facebook/libphutil/pull/36

Test Plan

Configured Wordpress as an auth provider, saw it show up on the login screen, registered a new account, got proper defaults for my username/name/email/profile picture.

Diff Detail

Repository
rPHU libphutil
Branch
wpcom-oauth2-plugin
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 310
Build 310: [Placeholder Plan] Wait for 30 Seconds

Event Timeline

Abbe retitled this revision from to Add WordPress.com OAuth2 plugin.
Abbe updated this object.
Abbe edited the test plan for this revision. (Show Details)
epriestley added a reviewer: epriestley.

A few minor inlines. This generally looks great to me, everything inline is pretty minor.

(On your test plan, have you not run this code at all?)

What's your use case here in broad terms? For example: is this purely speculative ("someone might want to do this"), or do you or your company actually want to do this, or do you work for/with Automattic and want this for your own purposes and/or because WordPress users have expressed interest in it?

src/auth/PhutilAuthAdapterOAuthWordPress.php
13–15

Would making this configurable potentially be useful? Does only wordpress.com offer OAuth, or can another install of WordPress also serve as an OAuth server?

For example, if I run a WordPress consulting company and we have our master install at wp.mycompany.com, is it plausible that I might want to authenticate against that install? Or is this impossible / unrealistically obscure?

55–56

(weird indent)

src/future/wordpress/PhutilWordPressFuture.php
4–6

You can drop this @group stuff, we've moved away from it for documentation generation but haven't cleaned everything up yet.

76–77

You can simplify this slightly with phutil_json_decode().

78–79

We haven't updated all the code yet, but we're generally making exception messages translatable for consistency in newer code. You can do this with:

throw new Exception(
  pht('Expected JSON response from WordPress.com, got: %s', $body));

And likewise below.

This revision now requires changes to proceed.May 8 2014, 1:31 AM
Abbe edited edge metadata.

Code review suggestions incorporated

In D9004#5, @epriestley wrote:

A few minor inlines. This generally looks great to me, everything inline is pretty minor.

(On your test plan, have you not run this code at all?)

What's your use case here in broad terms? For example: is this purely speculative ("someone might want to do this"), or do you or your company actually want to do this, or do you work for/with Automattic and want this for your own purposes and/or because WordPress users have expressed interest in it?

Sorry, I misunderstood that I need to provide some test cases here which I didn't have.

We (at Automattic) are evaluating Phabricator, and have hacked this WordPress.com authentication provider to be able to authenticate users against WordPress.com, and it works fine.

src/auth/PhutilAuthAdapterOAuthWordPress.php
13–15

This plugin is specific to WordPress.com service and uses the API which is not present in WordPress software, so it can't be used to authenticate against a WordPress.org install.

Sorry, I misunderstood that I need to provide some test cases here which I didn't have.

"Test Plan" is just an informal description of "what I did to make sure the code works". You can read some more details in the documentation here: https://secure.phabricator.com/book/phabricator/article/differential_test_plans/

In this case it would be something like: "Configured Wordpress as an auth provider, saw it show up on the login screen, registered a new account, got proper defaults for my username/name/email/profile picture.".

This update is looks correct, but you've only included the most recent commit in the review. Do something like:

arc diff master

...to include all the changes since master. Then I can accept and pull this. Thanks!

Abbe edited edge metadata.
epriestley edited edge metadata.

Perfect, thanks!

This revision is now accepted and ready to land.May 8 2014, 7:15 PM
epriestley updated this revision to Diff 21411.

Closed by commit rPHU90aaeb01bb92 (authored by @Abbe, committed by @epriestley).

Abbe edited edge metadata.