| Classe365 Developer Hub

API Documentation

| Classe365 Developer Hub
https://tenant_name.classe365.com
Authentication

For authentication, we use basic HTTP authentication. So you need to pass base64 encoded string of “<tenant_name>:<api_key>” in credentials.

You can generate the API key from our Web App’s Admin Panel > Settings > APIs page.

CURL Command Example

curl … “Authorization: Basic <base64 encoded string of tenant_name:api_key” …

PHP CURL Example

$auth_token = base64_encode("<tenant_name>:<api_key>");

$headers = array(“Content-type:application/json”, "Authorization: Basic ".$auth_token );

$ch = curl_init();

curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

Academics

The set of APIs in this section allow you to create and update departments, classes, subjects and so on…

POST /rest/academic
POST /rest/academic
POST /rest/academic
POST /rest/academic
Insert/Update Department
POST /rest/academic

Authentication

Basic Authenticaion

This API allows you to insert or update a department.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encoded string of required parameters.

id: Id of the department to be updated (If id is not specified then it will perform insert operation. If id is specified then it will perform update opearation. Thus id is required for update operation.)

name: Name of the department to be added

type: Fixed string “department”

Examples:
{"name": "Computer Science", "type": "department"}{"id":1, "name": "Computer Science", "type": "department"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is 0).

Examples

This example shows the success value when a department is inserted or updated successfully.

{
    "success": 1
}

This example shows the error when the parameters passed are not valid.

{
    "success": 0,
    "error": "invalid_parameters"
}

This example shows the error status when a department with same name exists.

{
    "success": 0,
    "error": "already_exists"
}

This example shows the error status if there is any error while saving the data.

{
    "success": 0,
    "error": "record_save_error"
}
401 Unauthorized

Authorization failed.

Example 1

This is an example to create a department named “Engineering”.

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"name": "Engineering", "type": "department"}'
Insert/Update Class
POST /rest/academic

Authentication

Basic Authenticaion

This API allows you to insert or update a class.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encoded string of required parameters.

id: Id of the class to be updated. Update operation: ID is required Insert operation: ID is not required.

department_id: ID of the department. This is required only if Department is enabled. Update operation: department_id is not required.

name: Name of the class to be added.

code: Class code for the class.

student_limit: (Optional) Numeric positive integer value. Indicates the maximum student limit for a section.

type: Static string “class”.

Examples:
{"department_id":"1","name":"Class","code":"C1","student_limit":10,"type":"class"}{"id":1,"name":"Class 1234","code":"C1234","student_limit":10,"type":"class"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Class is added successfully.

{
    "success": 1,
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: Record exists with same name.

{
    "success": 0,
    "error": "already_exists"
}

Case 4: Error while saving a record.

{
    "success": 0,
    "error": "record_save_error"
}
401 Unauthorized

Authorization failed

Example 1
Example 2

For inserting a class

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"department_id":"114","name":"Class Name","code":"C1","student_limit":10,"type":"class"}'

For updating a class

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"id":296,"name":"Class 1234","code":"C1234","student_limit":10,"type":"class"}'
Insert/Update Section
POST /rest/academic

Authentication

Basic Authenticaion

This API allows you to insert or update a section.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encdoed string of required parameters.

id: ID of the section to be updated for an update operation.

For Update Operation: Required for update operation.

For Insert operation: ID must not be specified.

class_id: ID of class For Update operation: Not required For Insert operation: Required

name: Name of section

code: Code assigned to the section

student_limit: Numeric positive integer value (Optional). Indicates the maximum student limit for a section.

type: Static string “section”

Examples:
{"class_id":1,"name":"Section 1","code":"S1","student_limit":10,"type":"section"}{"id":"1","name":"Section 1","code":"S1","student_limit":10,"type":"section"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Section added successfully.

{
    "success": 1
}

Case 2: Invalid parameters.

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: Record exists with same name.

{
    "success": 0,
    "error": "already_exists"
}

Case 4: Error while saving a record.

{
    "success": 0,
    "error": "record_save_error"
}
401 Unauthorized

Authorization failed

Example 1
Example 2

For insert section

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"class_id":296,"name":"Section 1","code":"S1","student_limit":10,"type":"section"}'

For update section

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"id":"1","name":"Section 1","code":"S1","student_limit":10,"type":"section"}'
Insert or Update a Subject
POST /rest/academic

Authentication

Basic Authenticaion

This API allows you to insert or update a subject.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encoded string of required parameters.

id: ID of the subject to be updated.

For Insert operation: ID is not required. If you specify an ID for an insert operation, an update operation is performed.

For Update operation: ID is required.

section_id: Id of section for which this subject is being created.

For Insert operation: ID is required.

For Update operation: ID is not required.

name: Name of subject to be created or updated.

code: Code assigned to the subject

credit: Credits assigned to the subject

is_elective: Indicates whether the subject is elective or a core subject. For Insert operation. This is required with the values: c for Core Subject and e for Elective Subject.

For Update operation: Not Applicable.

student_limit: Numeric positive integer value (Optional).

type: Static string “subject”

Examples:
{"section_id":1,"name":"Subject 1","code":"Sub1","credit":"5","is_elective":"e","student_limit":10,"type":"subject"}{"id":"1","name":"Subject 1","code":"Sub1","credit":"5","student_limit":10,"type":"subject"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is 0).

Examples

Case 1: Subject added successfully.

{
    "success": 1,
}

Case 2: Invalid parameters.

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: Record exists with the same name.

{
    "success": 0,
    "error": "already_exists"
}

strong textCase 4: Error while saving record.

{
    "success": 0,
    "error": "record_save_error"
}
401 Unauthorized

Authorization failed

Example 1
Example 2

For insert subject

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"section_id":1,"name":"Subject 1","code":"Sub1","credit":"5","is_elective":"e","student_limit":10,"type":"subject"}'

For update subject

curl -X POST "https://demo.classe365.com/rest/academic"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"id":"1","name":"Subject 1","code":"Sub1","credit":"5","student_limit":10,"type":"subject"}'
Get Data For A Particular Department, Class, Section or Subject
GET /rest/getAcademicDataForParticular

Authentication

Basic Authenticaion

This API allows you to get data for a particular department, class, section, or subject.

Request parameters

id
string required

ID of class/section or subject.

type
string required

Possible values for type is “class”, “section”, or “subject”.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is zero).

Examples

Case 1: Data retrieved successfully. (for class)

{
    "success": 1,
    "data": [
        {
            "class_id": 1,
            "class_name": class 1,
            "class_code": class code,
            "department_name": department 1,
            "total": 20
        }   
    ]
}

Case 1: Data retrieved successfully. (for section)

{
    "success": 1,
    "data": [
        {
            "section_id": 1,
            "section_name": section 1,
            "section_code": section code,
            "department_name": department 1,
            "class_name": class 1,
            "total": null
        }   
    ]
}

Case 1: Data retrieved successfully. (for elective subject)

{
    "success": 1,
    "data": [
        {
            "subject_id": 1,
            "subject_name": subject 1,
            "department_name": department 1,
            "class_name": class 1,
            "section_name": section 1,
            "subject_code": subject code,
            "subject_credit": credit,
            "type": Elective,
            "total": 20
        }   
    ]
}

Case 1: Data retrieved succesfully. (for core subject)

{
    "success": 1,
    "data": [
        {
            "subject_id": 2,
            "subject_name": subject 2,
            "department_name": department 1,
            "class_name": class 1,
            "section_name": section 1,
            "subject_code": subject code,
            "subject_credit": credit,
            "type": Core,
        }   
    ]
}

Case 2: Invalid parameters.

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: Data not found.

{
    "success": 0,
    "error": "no_record_found",
}
401 Unauthorized

Authorization failed

Example 1
Example 2
Example 3

For class

$ curl -X GET "https://demo.classe365.com/rest/getAcademicDataForParticular?id=8&type=class" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

For section

$ curl -X GET "https://demo.classe365.com/rest/getAcademicDataForParticular?id=8&type=section" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

For subject

$ curl -X GET "https://demo.classe365.com/rest/getAcademicDataForParticular?id=8&type=subject" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Academic Structure Data For All Classes, Sections And Subjects Together
GET /rest/getAcademicDataForAll

Authentication

Basic Authenticaion

This API allows you to get academic structure data for all classes, sections, and subjects together.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and zero for error or failure.

error
string

A small string representing the error type (only when success is zero).

Examples

Case 1: Data retrieved successfully.

{
    "success": 1,
    "data": [
        {
            "class_id": 1,
            "class_name": class 1,
            "class_code": class code,
            "department_name": department 1,
            "total": 20,
            "section": [
                {
                    "section_id": 1,
                    "section_name": section 1,
                    "section_code": section code,
                    "total": 10,
                    "subject": [
                        {
                            "subject_id": 1,
                            "subject_name": subject 1,
                            "subject_code": subject code,
                            "subject_credit": credit,
                            "type": Core,
                        },
                        {
                            "subject_id": 2,
                            "subject_name": subject 2,
                            "subject_code": subject code,
                            "subject_credit": credit,
                            "type": Elective,
                            "total": 10
                        }
                    ]    
                },
                {
                    "section_id": 2,
                    "section_name": section 2,
                    "section_code": section code,
                    "total": null,
                    "subject": []    
                }
            ]
        },
        {
            "class_id": 2,
            "class_name": class 2,
            "class_code": class code,
            "total": null,
            "section": []
        }  
    ]
}

Case 2: Data not found.

{
    "success": 0,
    "error": "no_record_found",
}
401 Unauthorized

Authorization failed

Example 1
curl -X GET "https://demo.classe365.com/rest/getAcademicDataForAll" H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Academic Sessions
GET /rest/academicSessions
Get Academic Sessions
GET /rest/academicSessions

Authentication

Basic Authenticaion

This API allows you to get the data of all unlocked academic sessions.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is 0).

Examples

Case 1: Data retrieved successfully.

{
    "success": 1,
    "data": [
        {
            "id": 1,
            "name": Year 2020,
            "start_date": 2020-01-01,
            "end_date": 2020-12-31,
            "status": Completed,
            "created": 2019-12-28 06:01:25
        },
        {
            "id": 2,
            "name": Year 2021,
            "start_date": 2021-01-01,
            "end_date": 2021-12-31,
            "status": In Progress,
            "created": 2020-12-25 09:10:15
        },
    ]
}

Case 2: Data not found.

{
    "success": 0,
    "error": "error_message",
}
401 Unauthorized

Authorization failed

Example 1
curl -X GET "https://demo.classe365.com/rest/academicSessions" H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Teachers and Admin Staff

This group contains the API documentation related to teachers and admin staff information.

POST /rest/teacher
GET /rest/teachersData
POST /rest/admin
GET /rest/adminsData
Insert or Update Staff Member
POST /rest/teacher

Authentication

Basic Authenticaion

emphasized textThis API allows you to insert new staff member or update existing staff information. Staff members can be teachers or administration staff. This depends on the is_academic parameter. If this is one, then the staff is created as a teacher and if it is zero, the staff is an admin member.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encoded string of teacher attributes and their related data

id: ID of the teacher to be updated. This is required for an update operation. If id is not specified, then the API performs an insert operation.

teacher_id: Teacher identification number, which an institute may use for unique referencing of each teacher in the institute.

first_name: Teacher’s first name

last_name: Teacher’s last name

teacher_dob: Teacher’s date of birth

teacher_email: Teacher’s email id

teacher_contact: Teacher’s contact number

image: Progfile image (base64 encoded string). Profile image.

Examples:
{"teacher_id":"2016_1_api","is_academic":1,"first_name":"Cary","last_name":"Baxter","teacher_dob":"2000-05-08","teacher_email":"support@classe365.com","teacher_contact":"1234567890"}{"id":9, "is_academic":1,"teacher_id":"2016_1_api","first_name":"Classe","last_name":"Developer","teacher_dob":"1992-05-08","teacher_email":"support@classe365.com","teacher_contact":"1234567890"}
is_academic
string

Set this value to one to specific academic staff like teacher, and set to zero to specify administration on non-academic staff

Example:
0

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Staff added or updated successfully.

{
    "success": 1
}

Case 2: Invalid teacher id.

{
    "success": 0,
    "error": "invalid_id",
}

Case 3: Data validation error.

{
    "success": 0,
    "error": "field_validations",
    "field_validations":  {
        "field_id": required,
        "field_id": email,
        "field_id": date,
        "field_id": unique,
    }
}

Case 4: Invalid value for profile image.

{
    "success": 0,
    "error": "binary_to_image_convert",
}
401 Unauthorized

Authorization failed

Example 1
Example 2

For insert teacher

 curl -X POST "https://demo.classe365.com/rest/teacher"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"teacher_id":"2016_1_apinew","first_name":"Cary","last_name":"Baxter","teacher_dob":"1991-05-11","teacher_email":"support@classe365.com","teacher_contact":"12972565652","is_academic":1,"image": ""}'

For update teacher

curl -X POST "https://demo.classe365.com/rest/teacher"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"id":8,"teacher_id":"2019","first_name":"Cary","last_name":"Baxter","teacher_dob":"1992-05-11","teacher_email":"support@classe365.com","teacher_contact":"12972565652","is_academic":1,"image": ""}'
Get Teacher Data
GET /rest/teachersData

Authentication

Basic Authenticaion

emphasized textThis API allows you to rerieve teacher information.

Request parameters

acds_id
string required
Example:
ID of the Academic Session for which we want to retrieve teacher's allocated **subjects** data
filter
string optional

JSON encoded string of Teacher fields/attributes and related values, for the fields we want to filter by

Example:
{"id":6,"first_name":"Classe","last_name":"Developer","teacher_dob":"1992-06-07","teacher_email":"","gender":"","teacher_contact":""}
order
string optional

Pass field name and order type> The order type is the sorting order. It can be:

ASC: Ascending order

DESC: Descending order

Example:
{"sortField":"first_name","sortType":"DESC"},{"sortField":"last_name","sortType":"DESC"}
page
string optional

Specify number of records to display per page and display the page number.

Example:
{"recordsPerPage":"3","pageNo":"1"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is zero).

Examples

Case 1: Data retrieved successfully.

{
    "success": 1
    "data": [{"id":"6","first_name":"Classe","last_name":"Teacher","teacher_id":"2016_2_api","address":null,"zipcode":null,"state":null,"aadhar_uid":null,"teacher_contact":"1234567890","teacher_email":"support@classe365.com","image":"http:\/\/classe365-assets.s3-us-west-1.amazonaws.com\/customer_assets\/local\/teacher\/profile_pictures\/1543034963.jpg","designation":null,"qualification":null,"teacher_dob":"1992-06-07","age":null,"gender":"Male","father_name":null,"mother_name":null,"blood_group":null,"health_date":null,"height":null,"weight":null,"body_mass_index":null,"profile_summary":null,"fb_profile_link":null,"linkedin_profile_link":null,"is_academic":"1","text_20":"Test","teacher_name":"Classe Teacher","country":"","subjects":[{"id":"1","subject_name":"Account","type":"Core","class_name":"Standared 12","section_name":"Commerce"},{"id":"2","subject_name":"State","type":"Elective","class_name":"Standared 12","section_name":"Commerce"}]}]
}

Case 2: Invalid parameters.

{
    "success": 0,
    "error": "invalid_parameters",
}
401 Unauthorized

Authorization failed

Example 1
curl -X GET "https://demo.classe365.com/rest/teachersData?filter={"id":6,"first_name":"Classe","last_name":"Developer","teacher_dob":"1992-06-07","teacher_email":"","gender":"","teacher_contact":""}&order={"sortField":"first_name","sortType":"DESC"},{"sortField":"last_name","sortType":"DESC"}&page={"recordsPerPage":"3","pageNo":"1"}"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Insert/Update Admin
POST /rest/admin

Authentication

Basic Authenticaion

This API allows you to insert an administrator or update administrator information.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string

JSON encoded string of required parameters.

id: ID of the admin to be updated. If ID is not specified then the API performs an insert operation. If id is specified then it will perform update opearation. Thus id is required for update operation.

name: Name of the Administrator

email_address: email of the administrator.

contact: contact number of the administrator.

address: Address of the administrator.

image: Profile image(base64 encoded string). Profile image to upload or update for the administrator.

Examples:
{"name":"Classe Admin","email_address":"support@classe365.com","contact":"1234567890","address":"ad"}{"id":2,"name":"Classe Admin","email_address":"support@classe365.com","contact":"1234567890","address":"ad"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Administrator added or updated successfully.

{
    "success": 1
}

Case 2: Data validation error.

{
        "success": 0,
        "error": "field_validations",
        "field_validations":  {
        "field_id": invalid_id,
        "field_id": required,
        "field_id": email,
        "field_id": unique,
    }
}

Case 3: Invalid value for Profile image.

{
    "success": 0,
    "error": "binary_to_image_convert",
}
401 Unauthorized

Authorization failed

Example 1
Example 2

For insert admin

curl -X POST "https://demo.classe365.com/rest/admin"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"name":"Hitesh","email_address":"mail@mail.com","contact":"3862","address":"ad","image": ""}'

For update admin

curl -X POST "https://demo.classe365.com/rest/admin"   -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"   -d 'data={"id":2,"name":"Hitesh","email_address":"mail@mail.com","contact":"3862","address":"ad","image": ""}'
Get Admin Data
GET /rest/adminsData

Authentication

Basic Authenticaion

This API allows you to Get Administrator Data.

Request parameters

filter
string optional

JSON encoded string of admin fields and related values, for the fields we want to filter by

name: Name of the Administrator.

email_address: Email of the Administrator.

contact: Contact number of the Administrator.

main_admin: Value assigned to represent type of administrator. Values are: 1: for super administrator 0: for sub administrator

address: Address of the administrator

Example:
{"name":"Classe","email_address":"","contact":"","main_admin":"0","address":"address"}
order
string optional

Pass field name and sorting order. The sorting order can be: ASC : For sorting in an ascending order DESC: For sorting in a descending order

Example:
{"sortField":"first_name","sortType":"DESC"},{"sortField":"last_name","sortType":"DESC"}
page
string optional

Pass number of records per page value and display page number

Example:
{"recordsPerPage":"3","pageNo":"1"}

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully

{
        "success": 1
        "data": [{"id":"2","name":"Classe Admin(Sub)","email_address":"support@classe365.com","contact":"1234567890","image":"http:\/\/classe365-assets.s3-us-west-1.amazonaws.com\/customer_assets\/local\/admin\/profile_pictures\/1506668090.png","main_admin":"0","address":"HMT"}]
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}
401 Unauthorized

Authorization failed

Example 1
curl -X GET "https://demo.classe365.com/rest/adminsData?filter='{"name":"Hitz","email_address":"","contact":"","main_admin":"0","address":"address"}'&order='{"sortField":"first_name","sortType":"DESC"},{"sortField":"last_name","sortType":"DESC"}'&page='{"recordsPerPage":"3","pageNo":"1"}'" -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Students
POST /rest/student
POST /rest/studentCourseEnroll
POST /rest/electiveSubjectsAllocation
GET /rest/getTotalStudentCount
GET /rest/studentsData
Add or Update Student
POST /rest/student

Authentication

Basic Authenticaion

This API allows you to add a student or update existing student information.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
data
string required

JSON encoded string of Student fields/attributes and related values

id: ID of the student to be updated. If the ID is not specified, then the API performs an insert operation. If ID is specified, then the API performs an update operation. ID is required for an update operation only.

profile_image: A base64 encoded string of profile image.

All date values should be passed in Y-m-d format. For example, format for 1st Dec 2019 is “2019-12-01”.

Example:
{"admission_number":"2016_1_api","first_name":"Classe","last_name":"Developer","student_dob":"2000-05-08","student_email":"support@classe365.com","student_contact":"123123123","gender":"Male","father_name":"Johnson","mother_name":"Scarlett","parents_contact":"11111111","parents_email":"support@classe365.com"}
attachments
string

JSON encoded string of attachment files. Each attachment should have the following attributes:

title: Attachment Name/Title

description (optional): Short description of the attachment

file_type: Extension of attachment file

file: base64 encodeded string of attachment file

Example:
[{"title":"Attachment 1","description":"Test Attachment Upload using API","file_type":"pdf","file":base64_encoded_string}]
Examples

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Student added/updated successfully

{
    "success": 1
}

Case 2: Invalid student ID

{
    "success": 0,
    "error": "invalid_id",
}

Case 3: Data validation error

{
    "success": 0,
    "error": "field_validations",
        -"field_validations": {
            "student_contact": "required",
            "father_name": "required",
            "mother_name": "required",
            "parents_contact": "required",
            "parents_email": "required"
        }
}

Case 4: Student limit crossed for class/section/system

{
    "success": 0,
    "error": "students_max_limit_crossed",
}

Case 5: Invalid value for Attachments

{
    "success": 0,
    "error": "invalid_attachments",
}

Case 6: Attachments not supported in update operation

{
    "success": 0,
    "error": "attachments_not_supported_in_update",
}
401 Unauthorized

Authorization failed

Example 1
Example 2

Add Student

curl -X POST "https://demo.classe365.com/rest/student"  \
 -H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2" \
 -d 'data={"admission_number":"2016_1_api","first_name":"Classe","last_name":"Developer","student_dob":"2000-05-08","student_email":"support@classe365.com","student_contact":"123123123","gender":"Male","father_name":"Johnson","mother_name":"Scarlett","parents_contact":"11111111","parents_email":"support@classe365.com"}'

Edit Student

curl -X POST "https://demo.classe365.com/rest/student"  \
 -H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2" \
 -d 'data={"id":"19","admission_number":"2016_1_api","first_name":"Stephen","last_name":"hawking","student_dob":"2000-05-08","student_email":"support@classe365.com","student_contact":"123123123","gender":"Male","father_name":"Johnson","mother_name":"Scarlett","parents_contact":"11111111","parents_email":"support@classe365.com"}'
Student Course Enrollment
POST /rest/studentCourseEnroll

Authentication

Basic Authenticaion

This API allows you to enroll student into class. So you need to use this API to add any student into class - section.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
acds_id
number required

ID of the acedemic session under which we want to enroll the student into any class - section.

student_id
number required

ID of the student whom we want to enroll.

class_id
number required

ID of the class in which we want to enroll the student.

section_id
number required

ID of the section in which we want to enoll the student.

status
string

Status of the enrollment. Supported statutes are Upcoming, In Progress, Completed, Incomplete and Withdrawan. So we need to pass U for Upcoming, I for In Progress, C for Completed, IC for Incomplete and W for Withdrawn. And if we do not pass any value for status than it will take default value “In Progress”.

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Student successfully enrolled

{
    "success": 1
}

Case 2: Invalid Parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: Invalid Class id

{
    "success": 0,
    "error": "invalid_class_id"
}

Case 4: Invalid Section id

{
    "success": 0,
    "error": "invalid_section_id"
}

Case 5: Invalid academic session id

{
    "success": 0,
    "error": "invalid_academic_session_id"
}

Case 6: Student already enrolled

{
    "success": 0,
    "error": "student_already_enrolled"
}

Case 7: Students max limit crossed

{
    "success": 0,
    "error": "students_max_limit_crossed"
}

Case 8: Students max limit crossed for class

{
    "success": 0,
    "error": "students_max_limit_crossed_class"
}

Case 9: Students max limit crossed for section

{
    "success": 0,
    "error": "students_max_limit_crossed_section"
}

Case 10: Invalid enrollment status

{
    "success": 0,
    "error": "invalid_enrollment_status"
}
401 Unauthorized

Authorization failed

Example 1

Student enrolled successfully

curl -X POST "https://demo.classe365.com/rest/studentCourseEnroll"  \
 -H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2" \
 -d 'student_id=679&acds_id=null&class_id=263&section_id=424&status="I"'
Student Elective Subject Enrollment
POST /rest/electiveSubjectsAllocation

Authentication

Basic Authenticaion

This API allows you to enroll students into elective subjects.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
acds_id
string required

ID of the acedemic session under which we want to enroll the student into elective subject.

student_id
number required

ID of the student for whom we want to update the elective subjects allocation

Example:
1
class_id
number

ID of the class for which we want to assign or unassign the elective subjects

section_id
number

ID of the section for which we want to assign or unassign the elective subjects

to_be_assigned
string

String of comma separated subject ids of elective subjects which should be allocated to a student. This parameter will be optional if we are passing the “to_be_unassigned” parameter.

Example:
2,4,5
to_be_unassigned
string

String of comma separated subject ids of the elective subjects which should be unassigned to the student. This parameter will be optional if we are passing the “to_be_assigned” parameter.

Example:
1,6

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Record updated successfully

{
    "success": 1
}

Case 2: Subject is not an elective subject or does not exist

{
    "success": 0,
    "error": "invalid_elective_subject_ids",
}

Case 3: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 4: Student is alumni or does not exist

{
    "success": 0,
    "error": "invalid_student_id",
}

Case 5: Student limit is reached for the subject

{
    "success": 0,
    "error": "students_max_limit_crossed",
}

Case 6: Save error.

{
    "success": 0,
    "error": "save_error",
}

Case 7: Subject already enrolled.

{
    "success": 0,
    "error": "subject_already_enrolled"
}

Case 8: invalid class id.

{
    "success": 0,
    "error": "invalid_class_id"
}

Case 9: invalid section id.

{
    "success": 0,
    "error": "invalid_section_id"
}
401 Unauthorized

Authorization failed

Example 1

Save elective subject for student

curl -X POST "https://prominentdemo.classe365.com/rest/electiveSubjectsAllocation"  \
 -H "Content-Type: application/x-www-form-urlencoded"  \
 -d 'student_id=1
&to_be_assigned=2,4,5
&to_be_unassigned=1,6
&class_id=1
&section_id=1'
Get Total Student Count
GET /rest/getTotalStudentCount

Using this API you retrieve count of total student in system.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Responses

200 OK
Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully

{   "success":1,
    "data":{
        "studentcount":50
    }
}

Case 2: Error occurred while retrieving data

{
    "success": 0,
    "error": "read_error",
}
Example 1
curl -X GET "https://demo.classe365.com/rest/getTotalStudentCount"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Student Data
GET /rest/studentsData

Authentication

Basic Authenticaion

This API allows you to get student information.

Request parameters

acds_id
string required

ID of the academic session to which the student belongs to

filter
string optional

JSON encoded string of student fields and values that we want to filter by. For example:

id: ID of the student to get particular student data (If ID is not specified, then the API returns the complete student data.)

class_id: ID of the class to which the student belongs to

section_id: ID of section to which the student belongs to

student_type Pass this parameter to filter the student records based on their active/alumni status. Supported values are active,alumni and all. If we pass all then API will return all active and alumni student. If we pass alumni then it will return only alumni students. By default, it will consider active and will return only active students.

Note: All date values should be passed in Y-m-d format and with range structure. For example, the value for 1st Dec 2018 is “2018-12-01 to 2014-12-01” and value for 1st Dec 2018 to 10th Dec 2018 is “2018-12-01 to 2018-12-10”.

Example:
{"id":"4","class_id":"1","section_id":"1","subject_id":"","first_name":"Cary","last_name":"Baxter","student_dob":"2014-09-21","student_email":"carybaxter@classe365.com","gender":"Male","student_contact":"1234567890","parents_contact":"1234567890"}
order
string optional

Field name and sort order type. The sort order can be: asc: Ascending order desc: Descending order

Example:
[{"sortField":"first_name","sortType":"desc"},{"sortField":"last_name","sortType":"desc"}]
page
string optional

Specify records per page and display page number. Page number starts from 1.

Example:
{"recordsPerPage":"3","pageNo":"1"}

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully

{
    "success": 1
    "data": [{"id":"54","first_name":"Cary","last_name":"Baxter","gender":"Male","student_dob":"2014-09-21","image":"Image URL","admission_number":"33","student_email":"carybaxter@gmail.com","student_contact":"1234567890","blood_group":"","father_name":"","mother_name":"","parents_contact":"1234567890","parents_email":"","country":"Country Name","enrollments":[{"enrollment_id":"59","enrollment_date":"2020-06-07 14:55:00","enrollment_status":"Incomplete","academic_term":"Default Academic Session","class_id":"2","class_name":"Grade 2","class_code":"G2","section_id":"6","section_name":"Section B","section_code":"G2SB","subjects":[{"id":"12","subject_name":"Maths","credits":null,"subject_code":"2_6_33351","type":"Core", "enrollment_status":"In Progress"},{"id":"13","subject_name":"English","credits":null,"subject_code":"2_6_68678","type":"Core","enrollment_status":""},{"id":"14","subject_name":"Hindi","credits":null,"subject_code":"2_6_1287","type":"Core","enrollment_status":"Withdrawn"}]}]}]
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}
401 Unauthorized

Authorization failed

Example 1
Example 2

Get Student Data

curl -X GET "https://demo.classe365.com/rest/studentsData?acds_id=1&page={"recordsPerPage":"10","pageNo":"1"}" \
-H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

Get Particular Student

curl -X GET "https://demo.classe365.com/rest/studentsData?filter={"id":"4"}" \
-H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Attendance

This group lists the API documentation for attendance.

POST /rest/manageAttendance
GET /rest/attendanceData
Add or Update Attendance
POST /rest/manageAttendance

Authentication

Basic Authenticaion

This API allows you to manage (add or update) the attendance data for a particular class, section, subject (if attendance is subject-wise) and session (if session-wise option is enabled).

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
acds_id
string required

ID of the acedemic session under which we want to manage this attendance data.

class_id
string required

ID of the Class for which attendance is added or updated.

section_id
string required

ID of the Section for which attendance is added or updated.

subject_id
string

ID of the Subject. Only when attendance management is Subject wise.

session_id
string

Session ID. Only when attendance management is Session wise.

date
string required

Attendance date. Format must be in YYYY-mm-dd format.

working
string required

Day is working day or holiday. For Holiday pass Zero, otherwise pass 1.

attendance_data
string required

JSON encoded string of attendance data. With key as student id and value as json encoded sring of status and commment. If Holiday, then pass “[]” in attendance_data.

Example:
{"2":{"status":"p","comment":""},"4":{"status":"a","comment":""},"5":{"status":"a","comment":""},"6":{"status":"a","comment":""},"9":{"status":"p","comment":""},"10":{"status":"p","comment":""},"12":{"status":"p","comment":""}}

Responses

201 Created
Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is zero).

message
string

API message.

Examples

Case 1: Data saved successfully.

{
    "success": 1,
    "message": "Data saved successfully."
}

Case 2: Invalid parameters.

{
    "success": 0,
    "error": "invalid_parameters"
}

Case 3: Invalid attendance data.

{
    "success": 0,
    "error": "invalid_attendance_data"
}

Case 4: Error while saving attendance data.

{
    "success": 0,
    "error": "save_error",
}
Example 1

Save Attendance

curl -X POST "https://demo.classe365.com/rest/manageAttendance"  \
 -H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2" \
 -d 'class_id=1&section_id=1&subject_id=1&session_id=6&date=2019-11-27&working=1&attendance_data={"2":{"status":"p","comment":""},"4":{"status":"a","comment":""},"5":{"status":"a","comment":""},"6":{"status":"a","comment":""},"9":{"status":"p","comment":""},"10":{"status":"p","comment":""},"12":{"status":"p","comment":""}}'
Get Attendance Data
GET /rest/attendanceData

Authentication

Basic Authenticaion

This API allows you to get attendance data.

Request parameters

acds_id
string required

ID of the acedemic session for which we want to get the attendance data.

class_id
string required

ID of the class for which you want the attendance data.

section_id
string required

ID of the section for which you want the attendance data.

subject_id
string optional

ID of the Subject. If attendance is managed subject-wise, then subject_id is mandatory.

session_id
string optional

ID of the Session. If attendance is managed session-wise, then session_id is mandatory.

date
string required

Date for which we need attendance data. Date must be in the YYYY-MM-DD format.

Responses

200 OK
Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully.

{
    "success": 1,
    "data": {
        "filter":{
            "class_id":"1",
            "section_id":"1",
            "subject_id":"1",
            "date":"2019-11-09"
        },
        "submittedYet":0,
        "isWorking":1,
        "students":{
            "57":{
                "id":"57",
                "first_name":"Student 1",
                "last_name":"Classe",
                "admission_number":"classe_29",
                "student_contact":"",
                "student_email":"",
                "is_alumni":"0",
                "class_name":"Grade 1",
                "section_name":"Section A",
                "attendance_status":"p",
                "attendance_comment":""
            },
            "1":{
                "id":"1",
                "first_name":"Student 2",
                "last_name":"Classe",
                "admission_number":"7692",
                "student_contact":"11111",
                "student_email":"test@gmail.com",
                "is_alumni":"0",
                "class_name":"Grade 1",
                "section_name":"Section A",
                "attendance_status":"a",
                "attendance_comment":""
            }
        },
        "statusList":{
            "p":{
                "key":"status",
                "value":"p",
                "extra":{
                    "label":"Present",
                    "shortcode":"P",
                    "color":"#dd066c",
                    "wight":{
                        "relatedWithPresent":"0"
                    }
                }
            },
            "a":{
                "key":"status",
                "value":"a",
                "extra":{
                    "label":"Absent",
                    "shortcode":"A",
                    "color":"#e5412d",
                    "wight":{
                        "relatedWithPresent":"0"
                    }
                }
            },
            "n":{
                "key":"status",
                "value":"n",
                "extra":{
                    "label":"Null",
                    "shortcode":"N",
                    "color":"#999999",
                    "wight":{
                        "relatedWithPresent":"0"
                    }
                }
            },
            "T":{
                "key":"status",
                "value":"T",
                "extra":{
                    "label":"Tardy",
                    "shortcode":"T",
                    "color":"#3a87ad",
                    "wight":{
                        "relatedWithPresent":"1",
                        "present":"50",
                        "absent":"50"
                    }
                }
            },
            "holidayKeyC365":{
                "key":"status",
                "value":"holidayKeyC365",
                "extra":{
                    "label":"Holiday",
                    "shortcode":"H",
                    "color":"#7ea7f1"
                }
            }
        }
    }
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: No Student found for class, section, and subject

{
    "success": 0,
    "error": "no_student_found"
}

Case 4: If any inconsistency is noticed in attendance data

{
    "success": 0,
    "error": "inconsistent_attendance_data"
}
Example 1

Get attendance data

curl -X GET "https://demo.classe365.com/rest/attendanceData?class_id=1&section_id=1&date=2019-11-08&subject_id=1&session_id=6"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Attendance Data for All Students and a Particular Date
GET /rest/allAttendanceByDate

Authentication

Basic Authenticaion

Request parameters

acds_id
string required

ID of the acedemic session under which we want to get attendance data.

date
string required

Date for which we need attendance data. Date must be in the YYYY-MM-DD format.

Responses

200 OK
Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully.

{
    "success": 1,
    "data": {
        "filter": {
            "date": "2019-11-07"
        },
        "attendance": {
            "1": {
                "1": {
                    "1": {
                        "6": {
                            "isWorking": 1,
                            "students": {
                               "57":{
                                    "id":"57",
                                    "first_name":"Student 1",
                                    "last_name":"Classe",
                                    "admission_number":"classe_29",
                                    "student_contact":"",
                                    "student_email":"",
                                    "is_alumni":"0",
                                    "class_name":"Grade 1",
                                    "section_name":"Section A",
                                    "attendance_status":"p",
                                    "attendance_comment":""
                                },
                                "1":{
                                    "id":"1",
                                    "first_name":"Student 2",
                                    "last_name":"Classe",
                                    "admission_number":"7692",
                                    "student_contact":"11111",
                                    "student_email":"test@gmail.com",
                                    "is_alumni":"0",
                                    "class_name":"Grade 1",
                                    "section_name":"Section A",
                                    "attendance_status":"a",
                                    "attendance_comment":""
                                }
                                ....
                            }
                        },
                    "7": {
                            "isWorking": 1,
                            "students": {
                               "57":{
                                    "id":"57",
                                    "first_name":"Student 1",
                                    "last_name":"Classe",
                                    "admission_number":"classe_29",
                                    "student_contact":"",
                                    "student_email":"",
                                    "is_alumni":"0",
                                    "class_name":"Grade 1",
                                    "section_name":"Section A",
                                    "attendance_status":"t",
                                    "attendance_comment":""
                                },
                                "1":{
                                    "id":"1",
                                    "first_name":"Student 2",
                                    "last_name":"Classe",
                                    "admission_number":"7692",
                                    "student_contact":"11111",
                                    "student_email":"test@gmail.com",
                                    "is_alumni":"0",
                                    "class_name":"Grade 1",
                                    "section_name":"Section A",
                                    "attendance_status":"p",
                                    "attendance_comment":""
                                }
                                ....
                            }
                        }    
                    }
                }
            }
        }
    }
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: No Record found for date

{
    "success": 0,
    "error": "no_record_found"
}
Example 1
curl -X GET "https://demo.classe365.com/rest/allAttendanceByDate?date=2019-11-07"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Attendance Date for All Students and Particular Date in Linear View
GET /rest/attendanceByDateInLV

Authentication

Basic Authenticaion

Request parameters

acds_id
string required

ID of the acedemic session for which we want to get the attendance data.

date
string required

Date for which we need attendance data. Date must be in the YYYY-MM-DD format.

Responses

200 OK
Body
Object
success
string

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully.

{
  "success": 1,
  "data": {
    "filter": {
      "date": "2019-11-07"
    },
    "attendance": [
      {
        "class_id": "1",
        "section_id": "1",
        "subject_id": "1",
        "session_id": "6",
        "isWorking": 1,
        "students": [
          {
            "id": "57",
            "first_name": "Student 1",
            "last_name": "Classe",
            "admission_number": "classe_29",
            "student_contact": "",
            "student_email": "",
            "is_alumni": "0",
            "class_name": "Grade 1",
            "section_name": "Section A",
            "attendance_status": "p",
            "attendance_comment": ""
          },
          {
            "id": "1",
            "first_name": "Student 2",
            "last_name": "Classe",
            "admission_number": "7692",
            "student_contact": "11111",
            "student_email": "test@gmail.com",
            "is_alumni": "0",
            "class_name": "Grade 1",
            "section_name": "Section A",
            "attendance_status": "a",
            "attendance_comment": ""
          }
        ]
      },
      {
        "class_id": "1",
        "section_id": "12",
        "subject_id": "123",
        "session_id": "7",
        "isWorking": 1,
        "students": [
          {
            "id": "57",
            "first_name": "Student 1",
            "last_name": "Classe",
            "admission_number": "classe_29",
            "student_contact": "",
            "student_email": "",
            "is_alumni": "0",
            "class_name": "Grade 1",
            "section_name": "Section A",
            "attendance_status": "t",
            "attendance_comment": ""
          },
          {
            "id": "1",
            "first_name": "Student 2",
            "last_name": "Classe",
            "admission_number": "7692",
            "student_contact": "11111",
            "student_email": "test@gmail.com",
            "is_alumni": "0",
            "class_name": "Grade 1",
            "section_name": "Section A",
            "attendance_status": "p",
            "attendance_comment": ""
          }
        ]
      },
      {
        "class_id": "1",
        "section_id": "11",
        "subject_id": "123",
        "session_id": "8",
        "isWorking": "0"
      }    
    ]
  }
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 3: No Record found for date

{
    "success": 0,
    "error": "no_record_found"
}
Example 1
curl -X GET "https://demo.classe365.com/rest/attendanceByDateInLV?date=2020-01-13"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Grading and Assessments

This section lists the API documentation for the APIs related to grading and assessments.

GET /rest/studentScore
GET /rest/subjectScore
POST /rest/saveAssessmentScore
Get Assessments Score for a Student
GET /rest/studentScore

Authentication

Basic Authenticaion

This API allows you to get assessments score for a student.

Request parameters

acds_id
string required

ID of the acedemic session for which we want to get the scores data.

id
string required

ID of the student whose assessment score you want to get using this API.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is zero).

Examples

Case 1: Data retrieved successfully (Grading Periods enabled).

{
    "success": 1,
    "data": [
        {
            "subject": {
                "subject_id": "1",
                "subject_name": "Subject 1",
                "type": "Core",
                "credits": "5",
                "unpublished_score_value": "81.65",
                "published_score_value": "81.65",
                "dis_unpublished_score_value": "81.65%",
                "dis_published_score_value": "81.65%",
                "color": ""
            },
            "grading_periods": [
                {
                    "grading_period_id": "1",
                    "name": "Jul 2019 - Oct 2019",
                    "weight": "50",
                    "weighted": 50,
                    "unpublished_score_value": "",
                    "published_score_value": "",
                    "dis_unpublished_score_value": "",
                    "dis_published_score_value": "",
                    "comment": "Not set",
                    "color": ""
                },
                {
                    "grading_period_id": "2",
                    "name": "Nov 2019 - Feb 2020",
                    "weight": "50",
                    "weighted": 50,
                    "unpublished_score_value": "81.65",
                    "published_score_value": "81.65",
                    "dis_unpublished_score_value": "81.65%",
                    "dis_published_score_value": "81.65%",
                    "comment": "Not set",
                    "color": ""
                }
            ],
            "assessments": [
              
                {
                    "assessment_id": "2",
                    "name": "Assignment 2",
                    "description": "Not set",
                    "ass_cat_id": "1",
                    "ass_cat_name": "Assignment",
                    "points": "30",
                    "pass_points": "15",
                    "start_date": null,
                    "end_date": null,
                    "grading_period_id": "1",
                    "counts_in_overall": "Yes",
                    "cce": "No",
                    "weight": "10.00",
                    "enable_submission": "No",
                    "is_published": "Yes",
                    "scale_type": "Percentage",
                    "score": null,
                    "dis_score": null,
                    "comment": "Not set",
                    "view_more": 0,
                    "color": ""
                },
                {
                    "assessment_id": "5",
                    "name": "Final Project",
                    "description": "It is a long established fact that a reader will be distracted by the readable content of a page when looking at its layout",
                    "ass_cat_id": "2",
                    "ass_cat_name": "Projects",
                    "points": "50",
                    "pass_points": "20",
                    "start_date": "2019-08-04",
                    "end_date": "2019-12-31",
                    "grading_period_id": "1",
                    "counts_in_overall": "Yes",
                    "cce": "No",
                    "weight": "10.00",
                    "enable_submission": "Yes",
                    "is_published": "Yes",
                    "scale_type": "Percentage",
                    "score": null,
                    "dis_score": null,
                    "comment": "Not set",
                    "view_more": 0,
                    "color": ""
                }
            ]
        },
        {
            "subject": {
                "subject_id": "2",
                "subject_name": "Subject 2",
                "type": "Core",
                "credits": "5",
                "unpublished_score_value": "",
                "published_score_value": "",
                "dis_unpublished_score_value": "",
                "dis_published_score_value": "",
                "color": ""
            },
            "grading_periods": [
                {
                    "grading_period_id": "1",
                    "name": "Jul 2019 - Oct 2019",
                    "weight": "50",
                    "weighted": 50,
                    "unpublished_score_value": "",
                    "published_score_value": "",
                    "dis_unpublished_score_value": "",
                    "dis_published_score_value": "",
                    "comment": "Not set",
                    "color": ""
                },
                {
                    "grading_period_id": "2",
                    "name": "Nov 2019 - Feb 2020",
                    "weight": "50",
                    "weighted": 50,
                    "unpublished_score_value": "",
                    "published_score_value": "",
                    "dis_unpublished_score_value": "",
                    "dis_published_score_value": "",
                    "comment": "Not set",
                    "color": ""
                }
            ],
            "assessments": [
                {
                    "assessment_id": "1",
                    "name": "Assignment 1",
                    "description": "Not set",
                    "ass_cat_id": "1",
                    "ass_cat_name": "Assignment",
                    "points": "30",
                    "pass_points": "15",
                    "start_date": null,
                    "end_date": null,
                    "grading_period_id": "1",
                    "counts_in_overall": "Yes",
                    "cce": "No",
                    "weight": "10.00",
                    "enable_submission": "Yes",
                    "is_published": "Yes",
                    "scale_type": "Percentage",
                    "score": "",
                    "dis_score": "",
                    "comment": "Not set",
                    "view_more": 0,
                    "color": ""
                },
                {
                    "assessment_id": "5",
                    "name": "Final Project",
                    "description": "It is a long established fact that a reader will be distracted by the readable content of a page when looking at its layout. ",
                    "ass_cat_id": "2",
                    "ass_cat_name": "Projects",
                    "points": "50",
                    "pass_points": "20",
                    "start_date": "2019-08-04",
                    "end_date": "2019-12-31",
                    "grading_period_id": "1",
                    "counts_in_overall": "Yes",
                    "cce": "No",
                    "weight": "10.00",
                    "enable_submission": "Yes",
                    "is_published": "Yes",
                    "scale_type": "Percentage",
                    "score": null,
                    "dis_score": null,
                    "comment": "Not set",
                    "view_more": 0,
                    "color": ""
                }
            ]
        },
    ]
}

Case 2: Data retrieved successfully (Without Grading Periods)

{
        "success": 1,
        "data": {
                    {
                        "subject": {
                            "subject_id": 1,
                            "subject_name": Math,
                            "credits": 6, 
                            "type": Core,
                            "unpublished_score_value": 75.55,
                            "published_score_value": 73.2,
                            "dis_unpublished_score_value": 75.55%,
                            "dis_published_score_value": 73.2%,
                            "comment": ,
                        }, 
                        "assessments": {
                            {
                                 "assessment_id": 10,
                                 "name": Mid Exam,
                                 "ass_cat_id": 1, 
                                 "ass_cat_name": Exam,
                                 "points": 30,
                                 "pass_points": 15,
                                 "start_date": null,
                                 "end_date": null,
                                 "counts_in_overall": Yes,
                                 "weight": 10,
                                 "is_published": Yes,
                                 "scale_type": Percentage,
                                 "score": 22,
                                 "dis_score": 73.33%,
                                 "comment": ,
                            }, 
                            {
                                 "assessment_id": 4,
                                 "name": Project 1,
                                 "ass_cat_id": 2, 
                                 "ass_cat_name": Assignment Project,
                                 "points": 30,
                                 "pass_points": 15,
                                 "start_date": null,
                                 "end_date": null,
                                 "counts_in_overall": Yes,
                                 "weight": 10,
                                 "is_published": No,
                                 "scale_type": Percentage,
                                 "score": 25,
                                 "dis_score": 83.33%,
                                 "comment": ,
                            },  
                        }
                    },
                    {
                        "subject": {
                            "subject_id": 2,
                            "subject_name": English,
                            "credits": 6, 
                            "type": Core,
                            "unpublished_score_value": 60.55,
                            "published_score_value": 60.2,
                            "dis_unpublished_score_value": 60.55%,
                            "dis_published_score_value": 60.2%,
                            "comment": ,
                        }, 
                        "assessments": {
                            {
                                 "assessment_id": 10,
                                 "name": Mid Exam,
                                 "ass_cat_id": 1, 
                                 "ass_cat_name": Exam,
                                 "points": 30,
                                 "pass_points": 15,
                                 "start_date": null,
                                 "end_date": null,
                                 "counts_in_overall": Yes,
                                 "weight": 10,
                                 "is_published": Yes,
                                 "scale_type": Percentage,
                                 "score": 22,
                                 "dis_score": 63.33%,
                                 "comment": ,
                            }, 
                            {
                                 "assessment_id": 4,
                                 "name": Project 1,
                                 "ass_cat_id": 2, 
                                 "ass_cat_name": Assignment Project,
                                 "points": 30,
                                 "pass_points": 15,
                                 "start_date": null,
                                 "end_date": null,
                                 "counts_in_overall": Yes,
                                 "weight": 10,
                                 "is_published": No,
                                 "scale_type": Percentage,
                                 "score": 25,
                                 "dis_score": 73.33%,
                                 "comment": ,
                            },  
                        }
                    }, 
            }
}

Case 3: Data not found

{
        "success": 0,
        "error": "no_record_found",
}

Case 4: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 5: Error occurred while retrieving data

{
    "success": 0,
    "error": "read_error",
}
Example 1
curl -X GET "https://demo.classe365.com/rest/studentScore?id=2"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Assessments Score for Multiple Students
GET /rest/studentsScore

Authentication

Basic Authenticaion

This API allows you to get assessments score for multiple students.

Request parameters

acds_id
string required

ID of the acedemic session for which we want to get the scores data.

recordsPerPage
string optional

Specify records per page.

Default:
20
pageNo
string optional

Page number starts from 1.

Default:
1

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is zero).

Examples

Case 1: Data retrieved successfully (Grading Periods enabled).

{
    "success": 1,
    "data": [
        {
            "learner":{
                "id":"54",
                "admission_number": "classe_29",
                "student_email": "test@gmail.com",
                "courses":[
                    {
                        "subject": {
                            "subject_id": "1",
                        },
                        "grading_periods": [
                            {
                                "grading_period_id": "1",
                                "name": "Jul 2019 - Oct 2019",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            },
                            {
                                "grading_period_id": "2",
                                "name": "Nov 2019 - Feb 2020",
                                "unpublished_score_value": "81.65",
                                "published_score_value": "81.65",
                                "dis_unpublished_score_value": "81.65%",
                                "dis_published_score_value": "81.65%",
                            }
                        ],
                        "assessments": [
                            {
                                "assessment_id": "2",
                                "name": "Assignment 2",
                                "points": "30",
                                "pass_points": "15",
                                "scale_type": "Percentage",
                                "score": null,
                            },
                            {
                                "assessment_id": "5",
                                "name": "Final Project",
                                "points": "50",
                                "pass_points": "20",
                                "scale_type": "Percentage",
                                "score": null,
                            }
                        ]
                    },
                    {
                        "subject": {
                            "subject_id": "2",
                        },
                        "grading_periods": [
                            {
                                "grading_period_id": "1",
                                "name": "Jul 2019 - Oct 2019",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            },
                            {
                                "grading_period_id": "2",
                                "name": "Nov 2019 - Feb 2020",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            }
                        ],
                        "assessments": [
                            {
                                "assessment_id": "1",
                                "name": "Assignment 1",
                                "points": "30",
                                "pass_points": "15",
                                "scale_type": "Percentage",
                                "score": "",
                            },
                            {
                                "assessment_id": "5",
                                "name": "Final Project",
                                "points": "50",
                                "pass_points": "20",
                                "scale_type": "Percentage",
                                "score": null,
                            }
                        ]
                    },
                ]    
            }
        },
        {
           "learner":{
                "id":"58",
                "admission_number": "classe_30",
                "student_email": "classetest@gmail.com",
                "courses":[
                    {
                        "subject": {
                            "subject_id": "1",
                        },
                        "grading_periods": [
                            {
                                "grading_period_id": "1",
                                "name": "Jul 2019 - Oct 2019",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            },
                            {
                                "grading_period_id": "2",
                                "name": "Nov 2019 - Feb 2020",
                                "unpublished_score_value": "81.65",
                                "published_score_value": "81.65",
                                "dis_unpublished_score_value": "81.65%",
                                "dis_published_score_value": "81.65%",
                            }
                        ],
                        "assessments": [
                            {
                                "assessment_id": "2",
                                "name": "Assignment 2",
                                "points": "30",
                                "pass_points": "15",
                                "scale_type": "Percentage",
                                "score": null,
                            },
                            {
                                "assessment_id": "5",
                                "name": "Final Project",
                                "points": "50",
                                "pass_points": "20",
                                "scale_type": "Percentage",
                                "score": null,
                            }
                        ]
                    },
                    {
                        "subject": {
                            "subject_id": "2",
                        },
                        "grading_periods": [
                            {
                                "grading_period_id": "1",
                                "name": "Jul 2019 - Oct 2019",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            },
                            {
                                "grading_period_id": "2",
                                "name": "Nov 2019 - Feb 2020",
                                "unpublished_score_value": "",
                                "published_score_value": "",
                                "dis_unpublished_score_value": "",
                                "dis_published_score_value": "",
                            }
                        ],
                        "assessments": [
                            {
                                "assessment_id": "1",
                                "name": "Assignment 1",
                                "points": "30",
                                "pass_points": "15",
                                "scale_type": "Percentage",
                                "score": "",
                            },
                            {
                                "assessment_id": "5",
                                "name": "Final Project",
                                "points": "50",
                                "pass_points": "20",
                                "scale_type": "Percentage",
                                "score": null,
                            }
                        ]
                    },
                ]    
            }
        },
    ]
}

Case 2: Data retrieved successfully (Without Grading Periods)

{
    "success": 1,
    "data": [
		 {
		 "learner":{
                "id":"54",
                "admission_number": "classe_29",
                "student_email": "test@gmail.com",
                "courses":[
                    {
						"subject": {
							"subject_id": "1",
						}, 
						"assessments": [
								{
									 "assessment_id": "10",
									 "name": "Mid Exam",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "22",
								}, 
								{
									 "assessment_id": "4",
									 "name": "Project 1",
									 "points": "30",
									 "pass_points": "15",
								     "scale_type": "Percentage",
									 "score": "25",
								},  
						]
					},
					{
						"subject": {
							"subject_id": "2",
						}, 
						"assessments": [
								{
									 "assessment_id": "10",
									 "name": "Mid Exam",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "22",
								}, 
								{
									 "assessment_id": "4",
									 "name": "Project 1",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "25",
								},  
						]
					}, 
				]
			}
		},
		{
		 "learner":{
                "id":"58",
                "admission_number": "classe_30",
                "student_email": "classetest@gmail.com",
                "courses":[
                    {
						"subject": {
							"subject_id": "1",
						}, 
						"assessments": [
								{
									 "assessment_id": "10",
									 "name": "Mid Exam",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "22",
								}, 
								{
									 "assessment_id": "4",
									 "name": "Project 1",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "25",
								},  
						]
					},
					{
						"subject": {
							"subject_id": "2",
						}, 
						"assessments": [
								{
									 "assessment_id": "10",
									 "name": "Mid Exam",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "22",
								}, 
								{
									 "assessment_id": "4",
									 "name": "Project 1",
									 "points": "30",
									 "pass_points": "15",
									 "scale_type": "Percentage",
									 "score": "25",
								},  
						]
					}, 
				]
			}
		},	
     ] 			
}

Case 3: Data not found

{
        "success": 0,
        "error": "no_record_found",
}

Case 4: Error occurred while retrieving data

{
    "success": 0,
    "error": "read_error",
}
Example 1
curl -X GET "https://demo.classe365.com/rest/studentsScore?recordsPerPage=10&pageNo=2"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Get Assessments Score for a Subject
GET /rest/subjectScore

Authentication

Basic Authenticaion

This API allows you to get assessments score for a subject.

Request parameters

acds_id
string required

ID of the acedemic session for which we want to get the scores data.

id
string required

ID of the subject for which you want to retrieve the assessments score.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully (Grading Periods enabled)

{
    "success": 1,
    "data": {
        "subject": {
            "subject_id": "1",
            "name": "Subject 1",
            "credits": "5",
            "type": "Core"
        },
        "grading_periods": [
            {
                "grading_period_id": "1",
                "name": "Jul 2019 - Oct 2019",
                "weight": "50",
                "weighted": 50
            },
            {
                "grading_period_id": "2",
                "name": "Nov 2019 - Feb 2020",
                "weight": "50",
                "weighted": 50
            }
        ],
        "overall_score": {
            "1": [
                {
                    "student_id": "4",
                    "student_first_name": "Alpesh",
                    "student_last_name": "Patel",
                    "student_admission_no": "123654014",
                    "is_alumni": "No",
                    "unpublished_score_value": "",
                    "published_score_value": "",
                    "dis_unpublished_score_value": "",
                    "dis_published_score_value": "",
                    "comment": ""
                },
            ],
            "2": [
                {
                    "student_id": "4",
                    "student_first_name": "Alpesh",
                    "student_last_name": "Patel",
                    "student_admission_no": "123654014",
                    "is_alumni": "No",
                    "unpublished_score_value": "88.30",
                    "published_score_value": "88.30",
                    "dis_unpublished_score_value": "88.30%",
                    "dis_published_score_value": "88.30%",
                    "comment": ""
                },
                {
                    "student_id": "2",
                    "student_first_name": "Gaurav",
                    "student_last_name": "Patel",
                    "student_admission_no": "76921602",
                    "is_alumni": "No",
                    "unpublished_score_value": "81.65",
                    "published_score_value": "81.65",
                    "dis_unpublished_score_value": "81.65%",
                    "dis_published_score_value": "81.65%",
                    "comment": ""
                },
                {
                    "student_id": "9",
                    "student_first_name": "Hitesh",
                    "student_last_name": "Patel",
                    "student_admission_no": "2017_9_18",
                    "is_alumni": "No",
                    "unpublished_score_value": "73.35",
                    "published_score_value": "73.35",
                    "dis_unpublished_score_value": "73.35%",
                    "dis_published_score_value": "73.35%",
                    "comment": ""
                },
                {
                    "student_id": "6",
                    "student_first_name": "Hitz",
                    "student_last_name": "Patel",
                    "student_admission_no": "123654016",
                    "is_alumni": "No",
                    "unpublished_score_value": "66.65",
                    "published_score_value": "66.65",
                    "dis_unpublished_score_value": "66.65%",
                    "dis_published_score_value": "66.65%",
                    "comment": ""
                },
                {
                    "student_id": "12",
                    "student_first_name": "Jaimin",
                    "student_last_name": "Patel",
                    "student_admission_no": "2017_10_22",
                    "is_alumni": "No",
                    "unpublished_score_value": "73.35",
                    "published_score_value": "73.35",
                    "dis_unpublished_score_value": "73.35%",
                    "dis_published_score_value": "73.35%",
                    "comment": ""
                },
                {
                    "student_id": "5",
                    "student_first_name": "Naren",
                    "student_last_name": "Patel",
                    "student_admission_no": "123654015",
                    "is_alumni": "No",
                    "unpublished_score_value": "100.00",
                    "published_score_value": "100.00",
                    "dis_unpublished_score_value": "100.00%",
                    "dis_published_score_value": "100.00%",
                    "comment": ""
                },
                {
                    "student_id": "10",
                    "student_first_name": "Samaya",
                    "student_last_name": "Venkata",
                    "student_admission_no": "20171901",
                    "is_alumni": "No",
                    "unpublished_score_value": "88.30",
                    "published_score_value": "88.30",
                    "dis_unpublished_score_value": "88.30%",
                    "dis_published_score_value": "88.30%",
                    "comment": ""
                }
            ]
        },
        "assessments": [
            {
                "assessment_id": "2",
                "name": "Assignment 2",
                "ass_cat_id": "1",
                "ass_cat_name": "Assignment",
                "points": "30",
                "pass_points": "15",
                "start_date": null,
                "end_date": null,
                "grading_period_id": "1",
                "counts_in_overall": "Yes",
                "weight": "10.00",
                "is_published": "Yes",
                "scale_type": "Percentage",
                "score": [
                    {
                        "student_id": "4",
                        "student_first_name": "Alpesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654014",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "2",
                        "student_first_name": "Gaurav",
                        "student_last_name": "Patel",
                        "student_admission_no": "76921602",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "9",
                        "student_first_name": "Hitesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_9_18",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "6",
                        "student_first_name": "Hitz",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654016",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "12",
                        "student_first_name": "Jaimin",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_10_22",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "5",
                        "student_first_name": "Naren",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654015",
                        "is_alumni": "No",
                        "actual_score_value": "",
                        "display_score_value": "",
                        "comment": ""
                    },
                    {
                        "student_id": "10",
                        "student_first_name": "Samaya",
                        "student_last_name": "Venkata",
                        "student_admission_no": "20171901",
                        "is_alumni": "No",
                        "actual_score_value": "30",
                        "display_score_value": "100.00%",
                        "comment": ""
                    }
                ]
            },
            {
                "assessment_id": "3",
                "name": "Project 1",
                "ass_cat_id": "2",
                "ass_cat_name": "Projects",
                "points": "30",
                "pass_points": "15",
                "start_date": null,
                "end_date": null,
                "grading_period_id": "2",
                "counts_in_overall": "Yes",
                "weight": "10.00",
                "is_published": "Yes",
                "scale_type": "Percentage",
                "score": [
                    {
                        "student_id": "4",
                        "student_first_name": "Alpesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654014",
                        "is_alumni": "No",
                        "actual_score_value": "25",
                        "display_score_value": "83.33%",
                        "comment": ""
                    },
                    {
                        "student_id": "2",
                        "student_first_name": "Gaurav",
                        "student_last_name": "Patel",
                        "student_admission_no": "76921602",
                        "is_alumni": "No",
                        "actual_score_value": "27",
                        "display_score_value": "90.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "9",
                        "student_first_name": "Hitesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_9_18",
                        "is_alumni": "No",
                        "actual_score_value": "24",
                        "display_score_value": "80.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "6",
                        "student_first_name": "Hitz",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654016",
                        "is_alumni": "No",
                        "actual_score_value": "18",
                        "display_score_value": "60.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "12",
                        "student_first_name": "Jaimin",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_10_22",
                        "is_alumni": "No",
                        "actual_score_value": "24",
                        "display_score_value": "80.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "5",
                        "student_first_name": "Naren",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654015",
                        "is_alumni": "No",
                        "actual_score_value": "30",
                        "display_score_value": "100.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "10",
                        "student_first_name": "Samaya",
                        "student_last_name": "Venkata",
                        "student_admission_no": "20171901",
                        "is_alumni": "No",
                        "actual_score_value": "25",
                        "display_score_value": "83.33%",
                        "comment": ""
                    }
                ]
            },
            {
                "assessment_id": "4",
                "name": "Project 2",
                "ass_cat_id": "2",
                "ass_cat_name": "Projects",
                "points": "30",
                "pass_points": "15",
                "start_date": null,
                "end_date": "2019-08-11",
                "grading_period_id": "2",
                "counts_in_overall": "Yes",
                "weight": "10.00",
                "is_published": "Yes",
                "scale_type": "Percentage",
                "score": [
                    {
                        "student_id": "4",
                        "student_first_name": "Alpesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654014",
                        "is_alumni": "No",
                        "actual_score_value": "28",
                        "display_score_value": "93.33%",
                        "comment": ""
                    },
                    {
                        "student_id": "2",
                        "student_first_name": "Gaurav",
                        "student_last_name": "Patel",
                        "student_admission_no": "76921602",
                        "is_alumni": "No",
                        "actual_score_value": "22",
                        "display_score_value": "73.33%",
                        "comment": ""
                    },
                    {
                        "student_id": "9",
                        "student_first_name": "Hitesh",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_9_18",
                        "is_alumni": "No",
                        "actual_score_value": "20",
                        "display_score_value": "66.67%",
                        "comment": ""
                    },
                    {
                        "student_id": "6",
                        "student_first_name": "Hitz",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654016",
                        "is_alumni": "No",
                        "actual_score_value": "22",
                        "display_score_value": "73.33%",
                        "comment": ""
                    },
                    {
                        "student_id": "12",
                        "student_first_name": "Jaimin",
                        "student_last_name": "Patel",
                        "student_admission_no": "2017_10_22",
                        "is_alumni": "No",
                        "actual_score_value": "20",
                        "display_score_value": "66.67%",
                        "comment": ""
                    },
                    {
                        "student_id": "5",
                        "student_first_name": "Naren",
                        "student_last_name": "Patel",
                        "student_admission_no": "123654015",
                        "is_alumni": "No",
                        "actual_score_value": "30",
                        "display_score_value": "100.00%",
                        "comment": ""
                    },
                    {
                        "student_id": "10",
                        "student_first_name": "Samaya",
                        "student_last_name": "Venkata",
                        "student_admission_no": "20171901",
                        "is_alumni": "No",
                        "actual_score_value": "28",
                        "display_score_value": "93.33%",
                        "comment": ""
                    }
                ]
            },
            {
                "assessment_id": "5",
                "name": "Final Project",
                "ass_cat_id": "2",
                "ass_cat_name": "Projects",
                "points": "50",
                "pass_points": "20",
                "start_date": "2019-08-04",
                "end_date": "2019-12-31",
                "grading_period_id": "1",
                "counts_in_overall": "Yes",
                "weight": "10.00",
                "is_published": "Yes",
                "scale_type": "Percentage",
                "score": []
            }
        ]
    }
}

Case 2: Data retrieved successfully (Without Grading Periods)

{
        "success": 1,
        "data": {
                "subject": {
                    "subject_id": 1,
                    "subject_name": Math,
                    "credits": 6, 
                    "type": Core,
                }, 
                "overall_score": { // If grading periods are disabled just one element in this array with key value 0 
                    "0": {
                        {
                           "student_id": 45,
                           "student_first_name": Cindy,
                           "student_last_name": Hanson, 
                           "student_admission_no": 2019001,
                           "is_alumni": No,
                           "unpublished_score_value": 85.33,
                           "published_score_value": 70.20,
                           "dis_unpublished_score_value": 85.33%,
                           "dis_published_score_value": 70.20,
                           "comment": ,
                        },
                        {
                           "student_id": 40,
                           "student_first_name": Ben,
                           "student_last_name": Gerber, 
                           "student_admission_no": 2019002,
                           "is_alumni": No,
                           "unpublished_score_value": 75.25,
                           "published_score_value": 70.00,
                           "dis_unpublished_score_value": 75.25%,
                           "dis_published_score_value": 70.00%,
                           "comment": ,
                        },
                    }
                }, 
                "assessments": {
                    {
                        "assessment_id": 10,
                        "name": Mid Exam,
                        "ass_cat_id": 1, 
                        "ass_cat_name": Exam,
                        "points": 30,
                        "pass_points": 15,
                        "start_date": null,
                        "end_date": null,
                        "counts_in_overall": Yes,
                        "weight": 10,
                        "is_published": Yes,
                        "scale_type": Percentage,
                        "score": {
                            {
                               "student_id": 45,
                               "student_first_name": Cindy,
                               "student_last_name": Hanson, 
                               "student_admission_no": 2019001,
                               "is_alumni": No,
                               "actual_score_value": 15,
                               "display_score_value": 50%,
                               "comment": ,
                            },
                            {
                               "student_id": 40,
                               "student_first_name": Ben,
                               "student_last_name": Gerber, 
                               "student_admission_no": 2019002,
                               "is_alumni": No,
                               "actual_score_value": 15,
                               "display_score_value": 50%,
                               "comment": ,
                            },
                        }
                    }, 
                    {
                        "assessment_id": 4,
                        "name": Project 1,
                        "ass_cat_id": 2, 
                        "ass_cat_name": Assignment Project,
                        "points": 30,
                        "pass_points": 15,
                        "start_date": null,
                        "end_date": null,
                        "counts_in_overall": Yes,
                        "weight": 10,
                        "is_published": No,
                        "scale_type": Percentage,
                        "score": {
                            {
                               "student_id": 45,
                               "student_first_name": Cindy,
                               "student_last_name": Hanson, 
                               "student_admission_no": 2019001,
                               "is_alumni": No,
                               "actual_score_value": 15,
                               "display_score_value": 50%,
                               "comment": ,
                            },
                            {
                               "student_id": 40,
                               "student_first_name": Ben,
                               "student_last_name": Gerber, 
                               "student_admission_no": 2019002,
                               "is_alumni": No,
                               "actual_score_value": 15,
                               "display_score_value": 50%,
                               "comment": ,
                            },
                        }
                    },  
                }, 
            }
        }

Case 3: Data not found

{
    "success": 0,
    "error": "no_record_found",
}

Case 4: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters",
}

Case 5: Error occurred while retrieving data

{
    "success": 0,
    "error": "read_error",
}
Example 1
curl -X GET "https://demo.classe365.com/rest/subjectScore?id=1"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
Add or Update Assessment Score
POST /rest/saveAssessmentScore

Authentication

Basic Authenticaion

This API allows you to add or update an assessment score.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
acds_id
string required

ID of the acedemic session under which we want to manage the scores data.

assessment_id
string

ID of assessment

Example:
1
subject_id
string

ID of subjects

Example:
1
score_data
string

JSON encoded string of obtained scores

Example:
{"4":{"score":"20","comment":"Good","status":""},"2":{"score":"10","comment":"Poor Performance","status":""},"6":{"score":"","comment":"","status":"EXE"}}

Responses

201 Created

This section shows the different responses from the API.

Body
Object
success
string

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

message
string

API message.

Examples

Case 1: Data saved successfully

{
    "success": 1,
    "message": "Data saved successfully."
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_parameters"
}

Case 3: Invalid assessment id

{
    "success": 0,
    "error": "invalid_assessment_id"
}

Case 4: Assessment not applicable on subjects

{
    "success": 0,
    "error": "invalid_assessment_id_and_subject_id",
}

Case 5: Invalid assessment score data

{
    "success": 0,
    "error": "invalid_score_data",
}

Case 6: Error while saving assessment score data

{
    "success": 0,
    "error": "save_error",
}
401 Unauthorized

Authorization failed

Example 1

Save Assessment Score

curl -X POST "https://demo.classe365.com/rest/saveAssessmentScore" -H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2" -d 'assessment_id=1&subject_id=1&score_data={"4":{"score":"20","comment":"Good","status":""},"2":{"score":"10","comment":"Poor Performance","status":""},"6":{"score":"","comment":"","status":"EXE"}}'
Invoicing and Payments

This section lists the API documentation for the APIs related to invoicing and payments.

Get Fees Data for all Fees, Invoices, and Payments together or for a particular Fees/Invoice/Payment
GET /rest/feesInfo

Authentication

Basic Authenticaion

This API allows you to get fees data for all fess, particular fees, particular invoice and particular payment.

Request parameters

If we do not specify fees_id, invoice_id or payment_id then all fees, invoices and payments data is returned in a nested JSON format.

fee_id
number optional

If data is needed for particular fees then pass fees_id.

invoice_id
number optional

If data is needed for particular invoice then pass invoice_id.

payment_id
number optional

If data is needed for particular payment then pass payment_id.

format
string optional

Format of the returned data. The type can be: “json” or “xml” value. If we do not pass a format parameter, then data is returned in xml format.

invoice_date_from
string optional

Pass this parameter to filter the invoices by Invoice date. All invoices greater or equal to date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

invoice_date_to
string optional

Pass this parameter to filter the invoices by Invoice date. All invoices less or equal to date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

invoice_created_date_from
string optional

Pass this parameter to filter the invoices by Invoice Created date. All invoices with created date greater or equal to the date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

invoice_created_date_to
string optional

Pass this parameter to filter the invoices by Invoice Created date. All invoices with created date less or equal to the date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

invoice_due_date_from
string optional

Pass this parameter to filter the invoices by Invoice Due date. All invoices with due date greater or equal to the date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

invoice_due_date_to
string optional

Pass this parameter to filter the invoices by Invoice Due date. All invoices with due date less or equal to the date passed in this parameter will be considered in response data.
Date value should be in YYYY-mm-dd format. Note: This parameter is not applicable when we pass invoice_id or payment_id parameter.

Responses

200 OK

This section shows the different responses from the API.

Body
Object
Examples

Case 1: Data retrieved successfully.

[
    {
        "id": "1",
        "name": "Education Term Fee 1",
        "description": "1st Term fee includes all Education.",
        "type": "Academic",
        "partial_payments": "Allowed",
        "recuring": "No",
        "amount": "4998.00 CAD",
        "discount": "100.00 CAD",
        "due_date": "",
        "invoices": [
            {
                "invoice_id": "1",
                "user": "Student",
                "user_id": "17",
                "user_name": "Classe Student",
                "sub_total  ":"5000 CAD",
                "discount_in_percentage":"2.00",
                "discount":"100.00 CAD",
                "tax_amount ":"98.00 CAD",
                "amount":"4998.00 CAD"
                "status": "Partially Paid",
                "date": "12-08-2019",
                "due_date": "",
                "line_items":[
                    {
                        "name":"Tution Fee",
                        "description":"",
                        "rate":"5000.00",
                        "qty":"1.00",
                        "tax_in_percentage":"2.00"
                    }
                ]
                "payments": [
                    {
                        "payment_id": "1",
                        "paid_amount": "2000.00 CAD",
                        "paid_through": "GoCardLess",
                        "paid_by": "parents",
                        "paid_on": "12-08-2019",
                        "status": "Paid",
                        "transaction_id": "*****v2r5"
                    }
                ]
            },
            .....
            {
                "invoice_id": "38",
                "user": "Form Submission",
                "user_id": "3",
                "user_name": "Developer Prominentapps",
                "sub_total  ":"5000 CAD",
                "discount_in_percentage":"2.00",
                "discount":"100.00 CAD",
                "tax_amount ":"98.00 CAD",
                "amount":"4998.00 CAD"
                "status": "Paid",
                "date": "13-09-2019",
                "due_date": "",
                "line_items":[
                    {
                        "name":"Tution Fee",
                        "description":"",
                        "rate":"5000.00",
                        "qty":"1.00",
                        "tax_in_percentage":"2.00"
                    }
                ]
                "payments": [
                    {
                        "payment_id": "7",
                        "paid_amount": "4998.00 CAD",
                        "paid_through": "Stripe",
                        "paid_by": "form_submission",
                        "paid_on": "13-09-2019",
                        "status": "Paid",
                        "transaction_id": "*****zbBw"
                    }
                ]
            }
        ]
    },
    {
        "id": "2",
        "name": "Education Term Fee 2",
        "description": "1st Term fee includes all Education.",
        "type": "Academic",
        "partial_payments": "Not allowed",
        "recuring": "No",
        "amount": "10237.50 CAD",
        "discount": "250.00 CAD",
        "due_date": "",
        "invoices": [
            {
                "invoice_id": "10",
                "user": "Student",
                "user_id": "17",
                "user_name": "Classe Student",
                "sub_total  ":"10000 CAD",
                "discount_in_percentage":"2.50",
                "discount":"250.00 CAD",
                "tax_amount ":"487.50 CAD",
                "amount": "10237.50 CAD",
                "status": "Un-paid",
                "date": "12-08-2019",
                "due_date": "",
                "line_items":[
                    {
                        "name":"Tution Fee",
                        "description":"",
                        "rate":"10000.00",
                        "qty":"1.00",
                        "tax_in_percentage":"5.00"
                    }
                ]
                "payments": []
            },
            ....
        ]
    },
    
    {
        "id": "4",
        "name": "Library Fees",
        "description": "Library Fees",
        "type": "Library Fees",
        "partial_payments": "Not allowed",
        "recuring": "No",
        "amount": "2000.00 CAD",
        "discount": "0.00 CAD",
        "due_date": "15-09-2019",
        "invoices": []
    },
    ....
]

Case 2: No Record found.

{}
401 Unauthorized

Authorization failed

Example 1
Example 2
Example 3
Example 4

Get data for particular fees category using fee_id.

curl -X POST "https://demo.classe365.com/rest/feesInfo?fee_id=1&format=json"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

Get data for particular invoice using invoice_id.

curl -X POST "https://demo.classe365.com/rest/feesInfo?invoice_id=1&format=json"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

Get data for particular payment using payment_id.

curl -X POST "https://demo.classe365.com/rest/feesInfo?payment_id=1&format=json"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

Get data for all fees category.

curl -X POST "https://demo.classe365.com/rest/feesInfo?format=json"  -H -H "Content-Type: application/json" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"
CRM-Enroll & Forms
GET /rest/getSubmission
GET /rest/getSubmissionsData
Add or Update Form Submission Details
POST /rest/formSubmit

Authentication

Basic Authenticaion

This API allows you to add a submission or update existing submission details.

Request headers

Content-Type
string required
Example:
application/x-www-form-urlencoded

Request body

application/x-www-form-urlencoded
Object
id
number

ID of the submission to be updated. If the ID is not specified, then the API performs an insert operation. If ID is specified, then the API performs an update operation. ID is required for an update operation only.

form_id
number

ID of the Form for which submission is added or updated.

{form_field_id}
string

The value of form field/attribute. Form field/attribute like First Name, Last Name, Email, Contact and any other custom fields created on the form. The param name (form_field_id) should be the exact field id displayed for Field Id (non editable setting) under related field setting.

For date type field, pass the date value in Y-m-d format.

For image and file type fields, pass file name (with extension) and base64 encoded file data in json encoded format.

For class and section fields in student pre-admission form, we need to pass class id and section id.

For elective subject field in student pre-admission form, we need to pass the ids of elective subjects in comma separated string format.

For subject field in teacher registration form, we need to pass the ids of subjects in comma separated string format.

Examples

Generic Forms

{
    "id": 1,
    "form_id": 1,
    "firstname_76": "Clase",
    "lastname_76": "Developer",
    "contact_76": "Clase",
    "date_77": "2020-06-07",
    "file_78": '[{"name":"File_Name_With_Extension","file":"base64_encoded_string_of_file_data"}]',
    "image_79": '[{"name":"File_Name_With_Extension","file":"base64_encoded_string_of_file_data"}]'
}

Students Pre-admission

{
    "id": 1,
    "form_id": 1,
    "firstname_76": "Clase",
    "lastname_76": "Developer",
    "contact_76": "123456789",
    "class_76": 1,
    "section_76": 1,
    "electivesubject_76": "10,12,17"
}

Teachers Registration

{
    "id": 1,
    "form_id": 1,
    "firstname_76": "Clase",
    "lastname_76": "Developer",
    "contact_76": "Clase",
    "date_77": "2020-06-07",
    "file_78": '[{"name":"File_Name_With_Extension","file":"base64_encoded_string_of_file_data"}]',
    "image_79": '[{"name":"File_Name_With_Extension","file":"base64_encoded_string_of_file_data"}]',
    "subjectSelection_76": "10,12,15"
}

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is 0).

Examples

Case 1: Submission added/updated successfully.

{
    "success": 1
}

Case 2: Invalid form id

{
    "success": 0,
    "error": "invalid_form_id",
}

Case 3: Invalid submission ID

{
    "success": 0,
    "error": "invalid_id",
}

Case 3: Data validation error

{
    "success": 0,
    "error": "field_validations",
        -"field_validations": {
            "first_name": "Please enter First Name",
            "email": "Please enter valid email",
            "contact": "Only numeric value allowed for contact",
            "date": "Please enter valid date value for date",
            "unique_email": "Please enter unique value for unique email",
            "image": "Image size should be less than 500 KB",
            "file": "File type should be all Allowed Types of format",
            "class_id": "Class id not exist",
            "section_id": "Section id not exist",
            "electivesubject": "Invalid elective subject ids",
        }
}
401 Unauthorized

Authorization failed

Get Form Submission Details
GET /rest/getSubmission

Authentication

Basic Authenticaion

This API allows you to get details of a particular submission.

Request parameters

id
string required

ID of the submission for which we want to retrieve the submission details

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and 0 for error or failure.

error
string

A small string representing the error type (only when success is 0).

data
Array of string

Array of all submission data with form field id as a key and related submission value as a value.

This array will include more information like related form name and submission status.

Examples

Case 1: Data retrieved successfully

{
    "success": 1
    "data": [{"id":"54", "form_name":"Form Name", "first_name":"Cary","last_name":"Baxter","gender":"Male","date_of_birth":"2014-09-21","image":"Image URL","email":"carybaxter@gmail.com","contact":"1234567890", "file":"File path", "status":"Pending", "type":"active", "created_at":"15-07-2021 08:14 AM", "modified_at":"15-07-2021 08:14 AM"}]
}

Case 2: Invalid parameters

{
    "success": 0,
    "error": "invalid_id",
}
401 Unauthorized

Authorization failed

Get Submissions Data
GET /rest/getSubmissionsData

Authentication

Basic Authenticaion

This API allows you to get submissions information.

Request parameters

filter
string optional

JSON encoded string of submission fields and values that we want to filter by. For example:

id: ID of the submission to get particular submission data (If ID is not specified, then the API returns the complete submission data.)

form_id: ID of the form for submission is created

first_name: First name of the user

last_name: Last name of the user

email: Email of the user

contact: Contact number of the user

from_date: Date of submission from you want to start retrieving submissions data

to_date: Date of submission from you want to stop retriveing submissions data

type Pass this parameter to filter the submission records based on their active/archive/draft status. Supported values are active,archive,draft and all. If we pass all then API will return all active, archive and draft submission. If we pass archive then it will return only archive submissions and same for draft. By default, it will consider all and will return all submissions.

Note: All date values should be passed in Y-m-d format. For example, the value for 1st Dec 2018 is “2018-12-01”

Example:
{"id":"4","form_id":"1","first_name":"Cary","last_name":"Baxter","email":"carybaxter@classe365.com","contact":"1234567890","type":"active""from_date":"2021-01-01","to_date":"2021-08-30"}
order
string optional

Field name and sort order type. The sort field can be: first_name: First name last_name: Last name date: Form submission date The sort order can be: asc: Ascending order desc: Descending order

Example:
{"sortField":"first_name","sortType":"desc"}
page
string required

Specify records per page and display page number. Page number starts from 1. maximum recordes per page is 200.

Example:
{"recordsPerPage":"3","pageNo":"1"}

Responses

200 OK

This section shows the different responses from the API.

Body
application/x-www-form-urlencoded
Object
success
boolean

1 for success and Zero for error or failure.

error
string

A small string representing the error type (only when success is Zero).

Examples

Case 1: Data retrieved successfully

{
	"success":1,
	"data":[{"id":"2","form_id":"11","form_name":"Project Submission Form", "status":"Pending", "type":"active", "first_name":"Classe", "last_name":"Developer", "email":"support@classe365.com", "contact":"1111111","class_id":"27","class_name":"Grade 1","section_id":"46","section_name":"Section A","elective_subject":"122,183","electivesubject":"Good Programming Skills (Grade 3 - Division A),Surveying (Architectural Acoustics Course - Section A)","date_89":"2021-07-15","country_121":"9","country_name":"Australia","created_at":"15-07-2021 08:14 AM","modified_at":"15-07-2021 08:14 AM"}]
}

Case 2: Missing Pagination Details

{
	"success":0,
	"error":"page_details_missing"
}

case 3: Maximum Recoreds Per Page

{
    "success": 0,
    "error": "recordes_per_page_max_limit_crossed"
}

case 4: Invalid Sort Field

{
    "success": 0,
    "error": "invalid_sort_field"
}

case 5: Invalid Sort Type

{
    "success": 0,
    "error": "invalid_sort_type"
}
401 Unauthorized

Authorization failed

Example 1
Example 2

Get Submissions Data

curl -X GET "https://demo.classe365.com/rest/getSubmissionsData?page={"recordsPerPage":"10","pageNo":"1"}" \
-H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"

Get Particular Submisssion

curl -X GET "https://demo.classe365.com/rest/getSubmissionsData?filter={"id":"4"}" \
-H -H "Content-Type: application/x-www-form-urlencoded" -H "Authorization: Basic ZGVtbzorQENlOUx6Unl3YjVtNXE2"