Table of Contents
Users objects are the accounts on the system.
Fields
| Field | Name | Description | Type | Required | 
|---|---|---|---|---|
| uid | User ID | The internal Schoology ID of the user | string | |
| school_id | Schoology School ID | The internal Schoology ID of the school to which the user belongs | string | |
| building_id | Schoology School Building ID | The internal Schoology ID of the school building to which the user belongs | string | |
| school_uid* | Unique ID | The user’s unique ID (e.g. student ID, SIS ID) | string | yes | 
| name_title | Name Title | The user’s title, must be one of the following: Mr., Mrs., Ms., Miss, Dr., Professor | string | |
| name_title_show | Show Name Title | Whether to show the user’s title when displaying his/her full name | {0,1} | |
| name_first | First Name | The user’s first name | string | yes | 
| name_first_preferred | Preferred First Name | The name by which the user goes | string | |
| name_middle | Middle Name | The user’s middle name | string | |
| name_middle_show | Show Middle Name | Whether to show the user’s middle name when displaying his/her full name | string | |
| name_last | Last Name | The user’s last name | string | yes | 
| name_display | Display Name | A fully-constructed name based on the user’s account settings. Cannot be set - only available on GET. | string | no | 
| username* | Username | The user’s username (either a username or email address is required for each user) | string | username or email | 
| primary_email | Primary Email Address | The user’s primary email address (either a username or email address is required for each user) | string | username or email | 
| position | Job Position | The user’s position in the school/company. | string | |
| gender | Gender | The user’s gender | {M,F} | |
| grad_year* | Graduation Year | The user’s graduation year (YYYY) | 4 digit integer | |
| birthday_date | Birthday | The user’s birthday (YYYY-MM-DD) | string | |
| password* | Password | The user’s password (existing passwords will not be changed if left blank) | string | |
| role_id* | Role ID | The ID of the role to which you would like to assign the user | integer | yes | 
| email_login_info | Email Login Information | Whether to send login information by email (if an email address is set); used only during user creation | {0,1} | |
| profile_url | Profile picture URL | The full URL of the user’s profile picture | string | |
| tz_name* | Timezone Name | An IANA-defined timezone name (see http://en.wikipedia.org/wiki/List_of_tz_database_time_zones) | string | |
| parents | User Parents | The user accounts of the user’s parents; requires ‘View user parents’ permission to be enabled for the current API user. | user objects | |
| parent_uids | User Parent User Ids | When creating/updating user accounts, a comma delimited list of the user’s parents’ user ids. API users must have permission to create users in order to create/update these associations. | comma-delimited list of integers | |
| advisor_uids | User Advisor User Ids | When creating/updating user accounts, a comma delimited list of the user’s advisors’ user ids. API users must have permission to create users in order to create/update these associations. | comma-delimited list of integers | |
| child_uids | User Child User Ids | A comma-delimited list of user ids identifying the user’s children. | comma-delimited list of integers | |
| send_message | Send Message status | Whether or not the signed-in user can send a private message to the listed user | integer | |
| synced | Sync Status | Whether or not this user was synced with an external system (eg, Student Information System). The default value is 0. For synced users, the Unique ID field is not editable through Schoology. | {0,1} | |
| profile_picture_fid | Profile Picture File ID | ID pointing to temporary save of the profile picture upload (write-only). For more details on uploading files: File Uploading | integer | |
| additional_buildings | Additional Buildings | The internal building IDs to which the user belongs to as a non-main building | Comma-delimited list of integers | |
| subjects_taught | Subjects Taught* | The subjects taught by a teacher. | string | undefined | 
| grades_taught | Grades Taught* | The grades taught by a teacher | string | undefined | 
| position | Position* | A user generated description of their position | string | undefined | 
| department* | Department | A user generated description of their department. | string | undefined | 
| bio | Biography | A user generated short bio on themselves. | string | undefined | 
| phone | Phone | The phone number of the user | string | undefined | 
| website | Website | User Website | string | undefined | 
| address | Address | User Address | string | undefined | 
| interests | Interests | User Interests | string | undefined | 
| activities | Activities | User Activities | string | undefined | 
| birthday_date | Birthday | The user’s birthday | string | undefined | 
Operations
create
Create a user in your school
| Path |    | 
| Content | An object containing user fields JSONJSON XML | 
| Return | An object containing user fieldsJSON XML | 
bulk create
Create multiple users at a time. The following parameters can be added to this endpoint:
- update_existing: Set this to 1 (e.g. ?update_existing=1) in order update existing users, matched by the ‘school_uid’ field. Without this parameter, user creation will fail if a pre-existing user has the same ‘school_uid’ as a passed user object.
- ignore_email_conflicts: If set to 1 and one of the users to be created has the same email address as another account in a different school, the user will be created without an email address. If a username was not specified, one will be generated based on the school_uid parameter. If this flag is not specified or if the conflict is with another account in the same school, an error will be thrown.
- email_conflict_resolution:
- set to 1 (e.g. ?email_conflict_resolution=1) to create an account in your school with a username if an email account already exists within Schoology. (Eg - If john@schoology.com already exists, the new account will be created with only a username ‘john’). If a new username is present, the new account will be created using that username.
- set to 2 (e.g. ?email_conflict_resolution=2) to merge duplicate Schoology accounts with [email]@[verified_domain] into the new account that you’re creating. However, if an email acount differs from your claimed domain, an account will be created using only a username.
 
| Path |    | 
| Content | Multiple users can be created at a time (up to 50) by wrapping your response in ‘users’, with user fields wrapped in ‘user’.JSON XML | 
| Return | The API endpoint (location) of each user created, or an error message if there was a problem creating the user.JSON XML | 
list
View a list of users in your school (paged). If your school has multiple buildings and you are not an administrator for all buildings, only users in your same building will be returned. Administrators for all buildings (i.e. administrators that are not associated with a specific building) will have users in all buildings returned and can optionally filter results with the following query strings:
- building_id: Only return users for the given building.
- role_ids: (Comma-separated list of IDs) Only return users who belong to the given role IDs
- parent_access_codes: Add in parent access codes for each of the returned users (set to 1)
- school_uids: A comma-separated list of school_uids within the school (up to 50 at one time)
| Path |    | 
| Content | none | 
| Return | A collection of user objects, each one containing user fieldsJSON XML | 
list (inactive)
View a list of inactive users in your school
| Path |    | 
| Content | none | 
| Return | A collection of user objects, each one containing user fieldsJSON XML | 
view
View a specified user
| Path |    | 
| Content | none | 
| Return | An object containing user fieldsJSON XML | 
view (inactive)
View a specified inactive user
| Path |    | 
| Content | none | 
| Return | An object containing user fieldsJSON XML | 
update
Modify a user
| Path |    | 
| Content | An object containing user fields | 
| Return | none | 
bulk update
Modify multiple users
| Path |    | 
| Content | Up to 50 users can be updated at a time by wrapping your response in ‘users’, with user fields wrapped in ‘user’.JSON XML | 
| Return | The schoology ID of each user updated, or an error message if there was a problem creating the user.JSON XML | 
bulk update (re-activate)
Re-activate inactive users.
- Set option_reenroll to 1 in the request body to place the user back into their courses and groups.
| Path |    | 
| Content | An object containing user fields Sample Request BodyJSON XML | 
| Return | A link to the user profiles of the reactivated usersJSON XML | 
delete
Delete a user (cannot be undone). The following parameters can be added to this endpoint:
- option_comment: Reason for marking inactive
- option_keep_enrollments: Set this to 1 (e.g. ?option_keep_enrollments=1) to keep a history of the user’s grade and attendance data. Note: if this parameter is not set, this endpoint will delete all history of the user’s grades and attendance records. This process cannot be reversed
- email_notification: Whether or not the deleted user should be notified via email that their account has been made inactive. If set to 1, email will be sent. If set to 0, email will not be sent. If this parameter is not used, emails will be sent by default.
| Path |    | 
| Content | none | 
| Return | none | 
bulk delete
Delete up to 50 users. The following parameters can be added to this endpoint:
- uids: Comma-separated list of Schoology IDs
- option_comment: Reason for marking inactive
- option_keep_enrollments: Set this to 1 (e.g. ?option_keep_enrollments=1) to keep a history of the user’s grade and attendance data. Note: if this parameter is not set, this endpoint will delete all history of the user’s grades and attendance records. This process cannot be reversed
- email_notification: Whether or not the deleted user should be notified via email that their account has been made inactive. If set to 1, email will be sent. If set to 0, email will not be sent. If this parameter is not used, emails will be sent by default.
| Path |    | 
| Content | none | 
| Return | none | 
Bulk Import Associations
Create parent-child or advisor-advisee associations.
Asocciation Fields
| Field | Name | Description | Type | Required | 
|---|---|---|---|---|
| student_school_uid | Unique ID | The student’s unique ID | string | yes | 
| parent_school_uid / advisor_school_uid | Unique ID | The parent’s / advisor’s unique ID | string | yes | 
| delete | Delete | Whether or not to delete this association if it exists | (0 ,1) | 
- Two separate endpoints depending on the type of association.
| Path |    | 
| Content | An object containing association fields Sample Request BodyJSON XML | 
| Return | The students school_uid and uid and the advisors school_uid and uid OR any relevant error messages.JSON XML | 
| Path |    | 
| Content | An object containing association fields Sample Request BodyJSON XML | 
| Return | The students school_uid and uid and the parents school_uid and uid OR any relevant error messages.JSON XML | 
Other Calls
These other calls are supported, as well. Please read their description for more information.
| Path |    | 
| Description | A shortcut for  GET users/{user_id}where{user_id}is the user ID of the current API user. | 
| Content | none | 
| Return | none | 
| Path |    | 
| Description | If the user has an active Schoology web session, it returns the user id for the passed OAuth tokens and the Schoology web session timestamp. Use this information to validate the given access tokens for the logged in user and to check if the user has an active Schoology web session | 
| Content | none | 
| Return | JSON  XML | 
| Path |    | 
| Description | Returns a list of all currently available interfaces languages. Use the language code property from returned language objects when creating/updating user languages | 
| Content | none | 
| Return | JSON  XML |