Skip to content

Documentation

Mike Fang edited this page Sep 11, 2021 · 17 revisions

Sun-Wordpress Overview

Wordpress plugin that extends the current core Wordpress functionality for the Cornell Sun iOS app

Added Post Information

Add additional information to the post object to prevent additional Wordpress API call. Please note that all extra fields are located within the post_info_dict dictionary in the response. The dictionary is added to existing post entries on the /posts endpoint as well as all of the custom post endpoints. There is no need to make a separate request to get this dictionary.

author_dict

List of author dictionaries

  • id: Integer -- author id on the website
  • name: String -- the display name of the author on the website
  • avatar_url: String -- display image of the author on the website
  • bio: String -- the description of the author on the website
  • link: String -- link to the author page on the website
  • twitter: String -- author's twitter
  • linkedin: String -- author's linked
  • email: String -- author's email

Values are null by default

Example output:

"author_dict": [
        {
          "id": 61,
          "name": "Gabrielle Leung",
          "avatar_url": "https:\/\/secure.gravatar.com\/avatar\/f3d05e2370b06e0e53933c34860829ea?s=96&d=mm&r=g",
          "bio": null,
          "link": "https:\/\/cornellsun.com\/author\/gabyleung\/",
          "twitter": null,
          "linkedin": null,
          "email": "[email protected]"
        }
      ]

featured_media_url_string

Dictionary of media dictionaries for three of the featured media sizes: medium_large, thumbnail, and full

Each media dictionary has the following information:

  • url: String -- the URL to the image at this size
  • width: int -- the width of the image at this size
  • height: int -- the height of the image at this size

Example output:

"featured_media_url_string": {
    "medium_large": {
        "url": "http://cornellsun.com/wp-content/uploads/2017/11/BINGHAMTON-14-768x511.jpg",
        "width": 768,
        "height": 511
     },
     "thumbnail": {
         "url": "http://i1.wp.com/cornellsun.com/wp-content/uploads/2017/11/BINGHAMTON-14.jpg?resize=140%2C140",
         "width": 140,
         "height": 140
     },
     "full": {
         "url": "http://i1.wp.com/cornellsun.com/wp-content/uploads/2017/11/BINGHAMTON-14.jpg?fit=1170%2C779",
         "width": 1170,
         "height": 779
     }
}

featured_media_caption

String caption for a given post's featured image. Empty string if no associated caption or no featured image.

"featured_media_caption": "Granting the popular bar and pizza joint landmark status would prevent significant exterior modifications."

featured_media_credit

String name of the photographer credited with taking a post's featured image. Note: Null if credit is stored in the caption field or no image associated with the given post.

"featured_media_credit": "Cameron Pollack / Sun Photography Editor"

category_strings

List of strings denoting the categories an article pertains to.

Example output:

"category_strings": [
    "Full Court Press",
    "Sports"
]

primary_category

String representing the lowest ID (most general) category string the post is a part of.

Example output:

"primary_category": "Sports"

tag_strings

List of strings denoting the tags this article has.

Example output:

"tag_strings": [
    "Men's Basketball"
]

post_type_enum

A string denoting which controller the iOS app should use to display this article. As of right now, it could only be:

  • "article" -- a normal article that presents a hero image and text in a detail view controller
  • "photoGallery" -- a post consisting of a series of images to be presented with captions
  • "video" -- a post consisting of a video

Example output:

"post_type_enum": "article"

post_attachments_meta

Contains all information necessary to display any associated attachments. Currently supports only posts with videos or photos. Uses the post_type_enum function in order to get the string representing the category of a post. Based on the category, calls the associated function to get the correct metadata for that article.

A post will return attachment dictionaries containing all the information necessary to display any associated attachments for a post.

Each attachment dictionary has the following attributes:

  • id: int -- the unique identifier for this media object in the Wordpress database
  • name: String -- the picture file name
  • caption: String -- the caption associated with this image on the post
  • media_type: String -- the type of this media object. Ex. "image/png", "image/jpg", etc.
  • author_name: String -- the name of the user who uploaded this image or media to the post
  • url: String -- the URL pointing to the full-sized image or media to be displayed

Example output for a post which is categorized as a photoGallery:

"post_attachments_meta": [
    {
        "id": 2347113,
        "name": "BINGHAMTON-14.jpg"
        "caption": "Facing the threat of losing a 20-point lead, Joel Davis (#23) was able to come up big in the second half for his team and stop the bleeding.",
        "media_type": "image/jpeg",
        "author_name": "Zachary Silver",
        "url": "http://cornellsun.com/wp-content/uploads/2017/11/BINGHAMTON-14.jpg"
    }
]

A post with video will return only the URL of the video. All other fields will be NULL.

Example output for a post which is categorized as a video:

"post_attachments_meta": {
            "id": null,
            "name": null,
            "caption": null,
            "media_type": null,
            "author_name": null,
            "url": "http://www.youtube.com/embed/HB_19pg-drU"
        }

post_content_no_srcset

Exactly equivalent to the rendered content in the normal API response, but with all instances of srcset='...' removed.

Example output:

"post_content_no_srcset": "<p>Content here with image however no extra src set attribute <img src='google.com' /></p>"

/trending Endpoint

Example endpoint URL

http://cornellsun.com/wp-json/sun-backend-extension/v1/trending

Default response

Returns top NUM_TRENDING_TAGS (currently 7) most popular tags as strings to be displayed in the search trending topics from the last 2 days.

Example output:

[
    "Top trending",
    "Second most trending",
    "Cornell University",
    "Martha Pollack",
    "Okenshields Playlist",
    "161 Faces",
    "Sex on Thursdays"
]

/featured Endpoint

Example endpoint URL

http://cornellsun.com/wp-json/sun-backend-extension/v1/featured
http://cornellsun.com/wp-json/sun-backend-extension/v1/featured/movies

Note that the post object returned by the featured endpoint contains the same post_info_dict as the /posts endpoint.

Default response

Returns the extended post object for the first post displayed prominently on the home page of cornellsun.com.

With Category

Returns the featured post within a given category. The category slug should be used instead of the full name.

/author Endpoint

/author/{author_name}

Returns a list of post_info_dict containing posts associated with the target author_name.

Example endpoint URL

https://cornellsun.staging.wpengine.com/wp-json/sun-backend-extension/v1/author/Mihika%20Badjate

Response author object

Most of the attributes are similar to the author_dict object outlined in the earlier section. Only a subset of the attributes are listed.

  • id: String -- The unique author identifier for the author in Wordpress
  • posts: Post Object List -- See the Added Post Information section for more details on the Post Object
  • target_name: String -- The url-decoded name passed to the endpoint. This is included in case we pass a name which can match more than 1 authors' name in the Wordpress database and thus allows us to identify the offending query

Example response

{
  "id": "957",
  "name": "Mihika Badjate",
  "avatar_url": "https://secure.gravatar.com/avatar/68ca2a0c359b143d03f86a885dfbabd6?s=96&d=mm&r=g",
  "bio": "Mihika Badjate is a member of the Class of 2023 in the College of Arts and Sciences. She is a staff writer for the news department and can be reached at [email protected].",
  "twitter": "",
  "linkedin": "https://www.linkedin.com/in/mihika-badjate-060a36178",
  "email": "[email protected]",
  "posts": [...(see **Added Post Information**)],
  "target_name": "Mihika Badjate"
}

/comments Endpoint

Note

The comments endpoint is currently unused. The Cornell Daily Sun ceased including comments on their web articles.

/comments/{post_id}

Returns a list of comment objects for the post with ID post_id. post_id must be a number corresponding to a post's unique Wordpress identifier. If there are no comments for a given post, then an empty list [] is returned. If there is an error fetching the comments from Facebook, then the error will be returned. If there is an error going through the responses from the Facebook Graph API, then the exception is returned to the requester.

Example endpoint URL

http://cornellsun.staging.wpengine.com/wp-json/sun-backend-extension/v1/comments/2754605

Response comment object

  • id: String -- the unique Facebook Graph API identifier of the comment node.
  • created_time: Object
    • date: String -- the date and time the comment was posted on the article
    • timezone_type: int -- (tbh not entirely sure what this is and documentation isn't very helpful)
    • timezone: String -- how far off of GMT the posted timezone is
  • from: Object
    • name: String -- the name of the user that posted the comment
    • id: String -- the Facebook Graph API's unique identifier for the user
    • profile_picture: Object
      • height: int -- height of the image
      • is_silhouette: boolean -- true if the icon is the default Facebook user image
      • url: String -- url to the user's profile picture image
      • width: int -- width of the image
  • message: String -- the string comment the user wrote for the given article
  • replies: Comment List -- a list of additional comment objects that directly reply to this comment

Example response

[
    {
        "id": "1558607794255395_1559620154154159",
        "created_time": {
            "date": "2018-02-09 01:45:36.000000",
            "timezone_type": 1,
            "timezone": "+00:00"
        },
        "from": {
            "name": "Vivian Li",
            "id": "10213617649489868",
            "profile_picture": {
                "height": 50,
                "is_silhouette": false,
                "url": "https://lookaside.facebook.com/platform/profilepic/?asid=10213617649489868&height=50&width=50&ext=1523574773&hash=AeTWdUvznEbXzdgO",
                "width": 50
            }
        },
        "message": "Hi Kelly,\n\nWhile I'm not in a sorority myself, some of my best friends are part of Greek life, namely Asian Greek, and they're definitely not like the \"typical\" sorority girl that you described in your article. While I (and they) do believe that there are problems with the system, it's unfair to stereotype all of the members of the Greek community into just one image - just because a couple of sisters are in the same major or participate in the same activity, it does not mean that they are the same person. \n\nYou definitely presented an interesting idea in your article in rushing as an undercover journalist, but I had two issues with the process itself. First, it's unfair for you to base your judgments of the entire Greek community off of one rush event, especially one in which you didn't have a long period of time to get to know anyone in particular. If you had five minutes to talk to someone, what would you be able to say that would distinguish yourself? Second, while you claimed that you didn't go into the event with a bias, I disagree, based on the way you already had these preconceptions of the sisters - you mention this \"sorority girl style\" and the \"perky\" attitude. How can you expect to see anything different when you are just there to reinforce this sorority girl stereotype that you see? \n\nI don't love Greek life but I love some people in the Greek community and don't think that this article gives them an accurate representation.",
        "replies": []
    },
    {
        "id": "1558607794255395_1559546730828168",
        "created_time": {
            "date": "2018-02-08 23:54:45.000000",
            "timezone_type": 1,
            "timezone": "+00:00"
        },
        "from": {
            "name": "Kayla Fitzgerald",
            "id": "10212326984629967",
            "profile_picture": {
                "height": 50,
                "is_silhouette": false,
                "url": "https://lookaside.facebook.com/platform/profilepic/?asid=10212326984629967&height=50&width=50&ext=1523574773&hash=AeS4VSUrcLeNpjq5",
                "width": 50
            }
        },
        "message": "I appreciate this different approach to sororities and rush! I certainly did not and do not consider myself the “typical” sorority girl.  At Cornell, I found situations where it was far to easy to be surrounded by the same people in your classes or major.  Instead of meeting others, I would stick to who I knew in the classroom buildings I knew. Sorority life offered a different option to meet people in other majors and programs who were just as outgoing or gregarious as myself. \n\nThrough joining a sorority I simply found a like minded group of athletes, bookworms, partiers and couch potatoes — all colors of Cornellian. Whether Friday night was spent in Olin or at a party— I never felt pressure to be anything but what I wanted to be. The sorority brought my friends together and facilitated the friendship and I am grateful for that.\n\nMy experience is certainly different from others. I heard of tales of hazing and pledging horrors.  Luckily, I was never in that situation. The system does need improvements and I hope this discussion continues so all can share a similar experience to mine.",
        "replies": []
    }
]

/urltoid Endpoint

/urltoid?url={url}

This endpoint is used to convert from a URL of a given article or post into an integer post ID. If the URL does not correspond to an article, then the endpoint will return 0. Note that the URL is taken as a normal GET parameter (?url={url}) rather than being embedded in the URL string (/urltoid/{url}).

Example Request

http://cornellsun.staging.wpengine.com/wp-json/sun-backend-extension/v1/urltoid?url=http://cornellsun.staging.wpengine.com/2018/02/14/the-nines-recommended-to-be-a-historical-landmark-owners-promise-to-fight-all-the-way-against-designation/

Example Response

2754605