#api #web #async #epitech #web-api #api-client #intranet

epitech_api

A library for interacting with the EPITECH intranet API

20 releases

0.2.0 Jan 16, 2020
0.1.18 Nov 10, 2019
0.1.17 Oct 23, 2019
0.1.15 Dec 3, 2018
0.1.8 Jul 3, 2018

#424 in #web-api

MIT/Apache

32KB
908 lines

EPITECH-API

This is a Rust library built on top of reqwest for interacting with the EPITECH intranet.
This library focuses on ease-of-use and type-safety.

Goal

This project aims to stick a type on intranet resources so that every possible members are clearly represented and safely accessible.

How to use

Everything originates from the Client struct.

You can create an Client this way:

use epitech_api::{Client, Error};

let result = Client::builder()
    .autologin("[INSERT AUTOLOGIN LINK HERE]")
    .authenticate()
    .await; // This returns a `Result<Client, Error>`.

let client = match result {
    Ok(client) => client,
    Err(err) => , // Handle authentication error here.
};

Right after this, you're already authenticated to the intranet and ready to proceed with requests.

You can, for instance, request the list of all students in a promotion this way:

// This makes the request and returns a `Result<Vec<UserEntry>, Error>`.
let result = client.fetch_student_list()
    .location(Location::Strasbourg)
    .promo(Promo::Tek2)
    .year(2020)
    .send()
    .await;

Client::make_request allows you to make an arbitrary request to the intranet:

// Notice that only the path component of the route can be passed to the method.
let my_student_infos = match client.make_request("/user").await {
    Ok(text: String) => , // Here, `text` represents the raw intranet response body.
    Err(err: Error) => , // Handle request error here.
};

Dependencies

~5–10MB
~185K SLoC