Improve API Docs for Invite to Group, Iss#8087

This commit is contained in:
Julie Torres
2016-10-02 19:17:14 -04:00
parent acee4bad80
commit e271e57f63

View File

@@ -21,6 +21,11 @@ import { encrypt } from '../../libs/encryption';
import { sendNotification as sendPushNotification } from '../../libs/pushNotifications'; import { sendNotification as sendPushNotification } from '../../libs/pushNotifications';
import pusher from '../../libs/pusher'; import pusher from '../../libs/pusher';
/**
* @apiDefine GroupBodyInvalid
* @apiError (400) {BadRequest} GroupBodyInvalid A parameter in the group body was invalid.
*/
/** /**
* @apiDefine GroupNotFound * @apiDefine GroupNotFound
* @apiError (404) {NotFound} GroupNotFound The specified group could not be found. * @apiError (404) {NotFound} GroupNotFound The specified group could not be found.
@@ -669,38 +674,68 @@ async function _inviteByEmail (invite, group, inviter, req, res) {
* *
* @apiParam {String} groupId The group _id ('party' for the user party and 'habitrpg' for tavern are accepted) * @apiParam {String} groupId The group _id ('party' for the user party and 'habitrpg' for tavern are accepted)
* *
* @apiParam {Array} [emails] Body parameter - An array of emails addresses to invite * @apiParam {Object[]} [emails] Body parameter - An array of objects, each representing one email address to invite
* @apiParam {String} emails.email The email address of the user being invited.
* @apiParam {String} [emails.name] The name of the user being invited.
* @apiParam {Array} [uuids] Body parameter - An array of uuids to invite * @apiParam {Array} [uuids] Body parameter - An array of uuids to invite
* *
* @apiParamExample {json} Emails * @apiParamExample {json} Emails
* { * {
* "emails": ["user-1@example.com", "user-2@exmaple.com"] * "emails": [
* } * {"email": "user-1@example.com"},
* {"name": "User2", "email": "user-2@example.com"}
* ]
* }
* @apiParamExample {json} User Ids * @apiParamExample {json} User Ids
* { * {
* "uuids": ["user-id-of-existing-user", "user-id-of-another-existing-user"] * "uuids": ["user-id-of-existing-user", "user-id-of-another-existing-user"]
* } * }
* @apiParamExample {json} User Ids and Emails * @apiParamExample {json} User Ids and Emails
* { * {
* "emails": ["user-1@example.com", "user-2@exmaple.com"], * "emails": [
* "uuids": ["user-id-of-existing-user", "user-id-of-another-existing-user"], * {"email": "user-1@example.com"},
* } * {"email": "user-2@example.com"}
* ],
* "uuids": ["user-id-of-existing-user"]
* }
* *
* @apiSuccess {Array} data The invites * @apiSuccess {Array} data The invites
* @apiSuccess {Object} data[0] If the invitation was a user id, you'll receive back an object. You'll recieve one Object for each succesful user id invite. * @apiSuccess {Object} data[0] If the invitation was a user id, you'll receive back an object. You'll recieve one Object for each succesful user id invite.
* @apiSuccess {String} data[1] If the invitation was an email, you'll receive back the email. You'll recieve one String for each successful email invite. * @apiSuccess {String} data[1] If the invitation was an email, you'll receive back the email. You'll recieve one String for each successful email invite.
* *
* @apiSuccessExample {json} Successful Response * @apiSuccessExample {json} Successful Response with Emails
* { * {
* data: [ * "data": [
* { id: 'the-id-of-the-invited-user', name: 'The group name', inviter: 'your-user-id' }, * "user-1@example.com",
* "user@example.com" * "user-2@exmaple.com"
* ] * ]
* } * }
* *
* @apiSuccessExample {json} Successful Response with User Id
* {
* "data": [
* { id: 'the-id-of-the-invited-user', name: 'The group name', inviter: 'your-user-id' }
* ]
* }
*
* @apiUse GroupBodyInvalid
* @apiUse GroupNotFound * @apiUse GroupNotFound
* @apiError InvalidInvitationParams An error relating to the data sent in `emails` and/or `uuids` * @apiUse UserNotFound
* @apiError TooManyInvites A max of 100 invites (combined emails and user ids) can be sent out at a time * @apiError (400) {BadRequest} NoEmailProvided An email address was not provided in the `emails` body param
* @apiUse PartyNotFound
* @apiError (400) {BadRequest} UuidOrEmailOnly The `emails` and `uuids` params
* were both missing and/or a key other than `emails` or `uuids` was provided in
* the body param.
* @apiError (400) {BadRequest} CannotInviteSelf User id or email of invitee matches that
* of inviter.
* @apiError (401) {NotAuthorized} UserAlreadyInvited The user has already been
* invited to the group.
* @apiError (401) {NotAuthorized} UserAlreadyInGroup The user is already a member
* of the group.
* @apiError (400) {BadRequest} MustBeArray The `uuids` or `emails` body param is
* not an array.
* match a valid user.
* @apiError (400) {BadRequest} TooManyInvites A max of 100 invites (combined emails and user ids) can be sent out at a time
*/ */
api.inviteToGroup = { api.inviteToGroup = {
method: 'POST', method: 'POST',