Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
anonymous-student
Advanced tools
Anonymous student is used to retrieve and save information from our website users.
Anonymous student is a client which can be used to save and retrieve information about the student whether the user is logged in or not. This application also implements caching of data to reduce the number of requests made to the StudentAPI. The client is available by subscribing to the AnonymousStudentServiceReady
event using the EventAggregationService
, please refer to Events for more details.
All AnonymousStudent interfaces can be installed using
npm install @studyportals/anonymous-student-interfaces
import { Actor, IStudent, StudentField } from '@studyportals/studentdomain';
interface IAnonymousStudent {
setStudentData(studentData: IStudent, Actor?: Actor): Promise<void>;
getStudentData(studentFields: StudentField[]): Promise<IStudent>;
getStudentDataCompleteness(studentFields: StudentField[]): Promise<number>;
addDisciplines(ids: number[]): Promise<void>;
removeDisciplines(ids: number[]): Promise<void>;
addInterest(type: InterestType, ids: number[]): Promise<void>;
removeInterest(type: InterestType, ids: number[]): Promise<void>;
setName(name: string): Promise<void>;
setGPA(grade_type: string, grade_value: any): Promise<void>;
}
The anonymous student application has multiple states which each handle the retrieval and save requests differently.
Pending
In this state, the application does not yet know if the user is logged in or not. To handle this the "Pending" state keeps all request open until it knows if the user is logged in or not. After this, the requests are resolved.
Online
This is the state where the user is logged in. The data will first try to retrieve data from the local cache. If that data is not saved in the local cache (LocalStorage) than it will retrieve data from the student system.
Offline
This state is active whenever the user is not logged in. The data saved will be stored in local storage until the user logs in. When the user logs in, the data is synced to the Online
state. After syncing the AnonymousStudentProfileSynced
is triggered.
Whenever a new session is created application state will change from Online
to Offline
. As part of this state change any previously saved data in the Offline
state will be synced to the Online
state. This will follow the following rules:
AnonymousStudentServiceReady is triggered when the Anonymous Student Service is ready. A ready-for-use instance of the service is provided as a property of the event. This event has following interface:
interface AnonymousStudentServiceReady {
static EventType: string;
eventType: string;
timestamp: Date;
anonymousStudentService: IAnonymousStudentService;
}
AnonymousStudentProfileSynced is triggered when information has been synced from the Offline
state to the Online
state.
interface AnonymousStudentProfileSynced {
static EventType: string;
eventType: string;
timestamp: Date;
state: StudentRepositoryStateType;
}
AnonymousStudentProfileUpdated is triggered when student information has been updated. This event has following interface:
import { IStudent } from '@studyportals/studentdomain';
interface AnonymousStudentProfileUpdated {
static EventType: string;
eventType: string;
timestamp: Date;
state: StudentRepositoryStateType;
changes: IStudent;
}
AnonymousStudentStateChanged is triggered when anonymous student changes its state:
import { StudentRepositoryStateType } from '@studyportals/studentdomain';
interface AnonymousStudentStateChanged {
static EventType: string;
eventType: string;
timestamp: Date;
oldState: StudentRepositoryStateType;
newState: StudentRepositoryStateType;
}
The above events can be listened to by using the EventAggregationService
. Refer to the EventAggregationService documentation for more information on subscribing to domain events.
The AnonymousStudent
service depends on the SessionService
being available. Refer to the SessionService documentation for more information.
A number of domain interfaces and enums in the Student domain are required for this service. Refer to StudentDomain documentation for more information.
FAQs
Anonymous student is used to retrieve and save information from our website users.
The npm package anonymous-student receives a total of 6 weekly downloads. As such, anonymous-student popularity was classified as not popular.
We found that anonymous-student demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.