feat: init
This commit is contained in:
commit
d2b0df0a00
5
.vscode/extensions.json
vendored
Normal file
5
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
{
|
||||
"recommendations": [
|
||||
"denoland.vscode-deno"
|
||||
]
|
||||
}
|
6
.vscode/settings.json
vendored
Normal file
6
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
{
|
||||
"deno.enablePaths": [
|
||||
"./"
|
||||
],
|
||||
"editor.inlayHints.enabled": "off"
|
||||
}
|
18
README.md
Normal file
18
README.md
Normal file
@ -0,0 +1,18 @@
|
||||
# Installer le serveur api
|
||||
**Windows :** ```irm https://deno.land/install.ps1 | iex```
|
||||
**Linux :** ```curl -fsSL https://deno.land/install.sh | sh```
|
||||
|
||||
|
||||
# Lancer le serveur API
|
||||
Dans un terminal a la racine du projet : ```deno main.ts```
|
||||
|
||||
# Liste des url accessibles
|
||||
- GET /interventions pour récuperer les interventions
|
||||
- GET /clients pour récuperer les clients
|
||||
- POST /client pour créer un nouveau client
|
||||
- POST /intervention pour créer une nouvelle intervention
|
||||
|
||||
# En cas d'erreur de connexion
|
||||
N'oubliez pas de modifier le string ip_adress situer dans res/values/string.xml par votre adresse IP de votre réseau.
|
||||
|
||||
N'oubliez pas d'autoriser les connexions et accès réseau dans le terminal ou vous avez lancer l'api.
|
12
deno.json
Normal file
12
deno.json
Normal file
@ -0,0 +1,12 @@
|
||||
{
|
||||
"imports": {
|
||||
"hono": "jsr:@hono/hono@^4.6.17"
|
||||
},
|
||||
"tasks": {
|
||||
"start": "deno run --allow-net main.ts"
|
||||
},
|
||||
"compilerOptions": {
|
||||
"jsx": "precompile",
|
||||
"jsxImportSource": "hono/jsx"
|
||||
}
|
||||
}
|
81
deno.lock
generated
Normal file
81
deno.lock
generated
Normal file
@ -0,0 +1,81 @@
|
||||
{
|
||||
"version": "4",
|
||||
"specifiers": {
|
||||
"jsr:@hono/hono@^4.6.17": "4.6.17"
|
||||
},
|
||||
"jsr": {
|
||||
"@hono/hono@4.6.17": {
|
||||
"integrity": "932fcc61d043b14a8b2cb65242716eb32da44e91f2ee117fd7390508669fea31"
|
||||
}
|
||||
},
|
||||
"redirects": {
|
||||
"https://deno.land/x/mysql/mod.ts": "https://deno.land/x/mysql@v2.12.1/mod.ts"
|
||||
},
|
||||
"remote": {
|
||||
"https://deno.land/std@0.104.0/_util/assert.ts": "2f868145a042a11d5ad0a3c748dcf580add8a0dbc0e876eaa0026303a5488f58",
|
||||
"https://deno.land/std@0.104.0/async/deadline.ts": "1d6ac7aeaee22f75eb86e4e105d6161118aad7b41ae2dd14f4cfd3bf97472b93",
|
||||
"https://deno.land/std@0.104.0/async/debounce.ts": "b2f693e4baa16b62793fd618de6c003b63228db50ecfe3bd51fc5f6dc0bc264b",
|
||||
"https://deno.land/std@0.104.0/async/deferred.ts": "ce81070ad3ba3294f3f34c032af884ccde1a20922b648f6eaee54bd8fd951a1e",
|
||||
"https://deno.land/std@0.104.0/async/delay.ts": "9de1d8d07d1927767ab7f82434b883f3d8294fb19cad819691a2ad81a728cf3d",
|
||||
"https://deno.land/std@0.104.0/async/mod.ts": "78425176fabea7bd1046ce3819fd69ce40da85c83e0f174d17e8e224a91f7d10",
|
||||
"https://deno.land/std@0.104.0/async/mux_async_iterator.ts": "62abff3af9ff619e8f2adc96fc70d4ca020fa48a50c23c13f12d02ed2b760dbe",
|
||||
"https://deno.land/std@0.104.0/async/pool.ts": "353ce4f91865da203a097aa6f33de8966340c91b6f4a055611c8c5d534afd12f",
|
||||
"https://deno.land/std@0.104.0/async/tee.ts": "6b8f1322b6dd2396202cfbe9cde9cab158d1e962cfd9197b0a97c6657bee79ce",
|
||||
"https://deno.land/std@0.104.0/bytes/bytes_list.ts": "a13287edb03f19d27ba4927dec6d6de3e5bd46254cd4aee6f7e5815810122673",
|
||||
"https://deno.land/std@0.104.0/bytes/mod.ts": "1ae1ccfe98c4b979f12b015982c7444f81fcb921bea7aa215bf37d84f46e1e13",
|
||||
"https://deno.land/std@0.104.0/encoding/base64.ts": "eecae390f1f1d1cae6f6c6d732ede5276bf4b9cd29b1d281678c054dc5cc009e",
|
||||
"https://deno.land/std@0.104.0/encoding/hex.ts": "5bc7df19af498c315cdaba69e2fce1b2aef5fc57344e8c21c08991aa8505a260",
|
||||
"https://deno.land/std@0.104.0/fmt/colors.ts": "d2f8355f00a74404668fc5a1e4a92983ce1a9b0a6ac1d40efbd681cb8f519586",
|
||||
"https://deno.land/std@0.104.0/fs/exists.ts": "b0d2e31654819cc2a8d37df45d6b14686c0cc1d802e9ff09e902a63e98b85a00",
|
||||
"https://deno.land/std@0.104.0/hash/_wasm/hash.ts": "313a4820227f1c45fa7204d9c28731b4f8ce97cdcc5f1e7e4efcdf2d70540d32",
|
||||
"https://deno.land/std@0.104.0/hash/_wasm/wasm.js": "792f612fbb9998e267f9ae3f82ed72444305cb9c77b5bbf7ff6517fd3b606ed1",
|
||||
"https://deno.land/std@0.104.0/hash/hasher.ts": "57a9ec05dd48a9eceed319ac53463d9873490feea3832d58679df6eec51c176b",
|
||||
"https://deno.land/std@0.104.0/hash/mod.ts": "dd339a26b094032f38d71311b85745e8d19f2085364794c1877057e057902dd9",
|
||||
"https://deno.land/std@0.104.0/io/buffer.ts": "3ead6bb11276ebcf093c403f74f67fd2205a515dbbb9061862c468ca56f37cd8",
|
||||
"https://deno.land/std@0.104.0/io/bufio.ts": "6024117aa37f8d21a116654bd5ca5191d803f6492bbc744e3cee5054d0e900d1",
|
||||
"https://deno.land/std@0.104.0/io/util.ts": "85c33d61b20fd706acc094fe80d4c8ae618b04abcf3a96ca2b47071842c1c8ac",
|
||||
"https://deno.land/std@0.104.0/log/handlers.ts": "8c7221a2408b4097e186b018f3f1a18865d20b98761aa1dccaf1ee3d57298355",
|
||||
"https://deno.land/std@0.104.0/log/levels.ts": "088a883039ece5fa0da5f74bc7688654045ea7cb01bf200b438191a28d728eae",
|
||||
"https://deno.land/std@0.104.0/log/logger.ts": "6b2dd8cbe6f407100b9becfe61595d7681f8ce3692412fad843de84d617a038e",
|
||||
"https://deno.land/std@0.104.0/log/mod.ts": "91711789b28803082b1bdfb123d2c9685a7e01767f2e79c0a82706063ad964d8",
|
||||
"https://deno.land/std@0.104.0/testing/_diff.ts": "5d3693155f561d1a5443ac751ac70aab9f5d67b4819a621d4b96b8a1a1c89620",
|
||||
"https://deno.land/std@0.104.0/testing/asserts.ts": "e4311d45d956459d4423bc267208fe154b5294989da2ed93257b6a85cae0427e",
|
||||
"https://deno.land/std@0.77.0/fmt/colors.ts": "c5665c66f1a67228f21c5989bbb04b36d369b98dd7ceac06f5e26856c81c2531",
|
||||
"https://deno.land/x/bytes_formater@v1.4.0/deps.ts": "4f98f74e21145423b873a5ca6ead66dc3e674fa81e230a0a395f9b86aafeceea",
|
||||
"https://deno.land/x/bytes_formater@v1.4.0/format.ts": "657c41b9f180c3ed0f934dcf75f77b09b6a610be98bb07525bffe2acfd5af4d5",
|
||||
"https://deno.land/x/bytes_formater@v1.4.0/mod.ts": "c6bf35303f53d74e9134eb13f666fb388fb4c62c6b12b17542bbadade250a864",
|
||||
"https://deno.land/x/mysql@v2.12.1/deps.ts": "68635959a41bb08bc87db007679fb8449febc55d48202dff20b93cc23ef5820d",
|
||||
"https://deno.land/x/mysql@v2.12.1/mod.ts": "3246c9c259434563be69cc95d5b792f8aac7ef5d10b8a6c6589aa54ebf1bd266",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/auth.ts": "129ea08b180d3e90e567c3f71e60432bb266304c224e17ea39d604bbcc1160d8",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/auth_plugin/caching_sha2_password.ts": "aab89e272382e6f408406f860ae6e79628275f4511e27a565049033543c4bdec",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/auth_plugin/crypt.ts": "8798819cce1171d95cfee8edda15fe6a652068cad4dc91f81b6e91cf90a13617",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/auth_plugin/index.ts": "8617e520ad854e38470aeefd07becdb3397c4cde16c2397dd48d5c10fdd5ab09",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/buffer.ts": "59f7e08e196f1b7e58cf5c3cf8ae8f4d0d47d1ae31430076fc468d974d3b59e7",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/client.ts": "30912964986667a2ce108c14f7153dd38e8089e55f8068e8d07697f75f2ac22f",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/connection.ts": "1d104c05441f8c94ee73123497fbbae28499f3badb0d9fef8cc82540688ada6e",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/constant/capabilities.ts": "2324c0e46ac43f59b7b03bdd878d7a14ecc5202b9e133c7e8769345a8290f2a1",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/constant/charset.ts": "253d7233679c774df623d1f974ebb358f3678c18fd6a623e25983311d97d959b",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/constant/errors.ts": "923bab27d524e43199fa21fdfcbe025580ca76d8b32254ad9505765c502f238a",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/constant/mysql_types.ts": "79c50de8eb5919b897e81e2ff2366ee1ffdbb4297f711e15003bdb787bbc8e6c",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/constant/packet.ts": "a1e7e00ce30c551c5f95c05d233b8d83f8e1fc865de97be3b317058e173630a9",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/deferred.ts": "35d087619d919961e849e382c33b2bfea15b4119f55eca2d9c9047f30512a2cb",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/logger.ts": "eb5feb3efdb9fd4887f6eccd5c06b5702591ac032af9857a12bbae86ceefe21b",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/builders/auth.ts": "0b53dd5fa0269427aa54c3f6909bd830ffb426009061df89df262c504d6c9b70",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/builders/client_capabilities.ts": "1000f2c1a20e0e119b9a416eb4ea4553cc1c5655d289a66e9077bf7a5993d52d",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/builders/query.ts": "caf426a72ebe545ff5bab14c8b7b5e412dd8827c091322959cdf4e9aa89ef900",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/builders/tls.ts": "2abb4a2fa74c47914372b221cb6f178f6015df54421daf0e10e54d80d7156498",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/packet.ts": "d7800cc142226f7dfd3c5f647f03cd3ef308f9d8551b4edb2e1bfb9c758d33b6",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/parsers/authswitch.ts": "aa34f21336c4907b3ae968108fcdad8f1c43a303088efd83d972e6c7b258c166",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/parsers/err.ts": "4110c4ddc2ae8358d6661fa2522f8eda2e603900d1e433e3684765ed50e88ed8",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/parsers/handshake.ts": "88f7ee34e9e0ef089bc5fdefacaccf256ef002b2f7a8ad684e35327682039e73",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/packets/parsers/result.ts": "8ab16f1adae67415eefcc17803b0eb828c1f4c6a24c55f25949f418e862d3ec8",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/pool.ts": "978ba2813b3886d68be007678360ad43c54dab14b1aea1c07fcdb41222fcc432",
|
||||
"https://deno.land/x/mysql@v2.12.1/src/util.ts": "83d38e87cc3901da00ac44bfcd53c0e8d24525262f5c7647c912dccf3ed2dbb5",
|
||||
"https://deno.land/x/sql_builder@v1.9.1/util.ts": "b9855dc435972704cf82655019f4ec168ac83550ab4db596c5f6b6d201466384"
|
||||
},
|
||||
"workspace": {
|
||||
"dependencies": [
|
||||
"jsr:@hono/hono@^4.6.17"
|
||||
]
|
||||
}
|
||||
}
|
50
main.ts
Normal file
50
main.ts
Normal file
@ -0,0 +1,50 @@
|
||||
import { Hono } from "hono";
|
||||
|
||||
const app = new Hono();
|
||||
|
||||
import { Client } from "https://deno.land/x/mysql/mod.ts";
|
||||
|
||||
const client = await new Client().connect({
|
||||
hostname: "127.0.0.1",
|
||||
username: "root",
|
||||
db: "depannTout",
|
||||
password: "root",
|
||||
});
|
||||
|
||||
async function getAllInterventions() {
|
||||
const today = new Date().toISOString().split("T")[0];
|
||||
return await client.query("SELECT * FROM interventions WHERE date = ?", [
|
||||
today,
|
||||
]);
|
||||
}
|
||||
|
||||
async function getAllClients() {
|
||||
return await client.query("SELECT * FROM clients");
|
||||
}
|
||||
|
||||
app.get("/interventions", async (c) => {
|
||||
const interventions = await getAllInterventions();
|
||||
return c.json(interventions);
|
||||
});
|
||||
|
||||
app.get("/clients", async (c) => {
|
||||
const clients = await getAllClients();
|
||||
return c.json(clients);
|
||||
});
|
||||
|
||||
app.post("/client", async (c) => {
|
||||
const newClient = await c.req.json();
|
||||
console.log(newClient);
|
||||
client.query(
|
||||
"INSERT INTO clients (prenom, nom, email, telephone, adresse) VALUES (?, ?, ?, ?, ?)",
|
||||
[
|
||||
newClient.prenom,
|
||||
newClient.nom,
|
||||
newClient.email,
|
||||
newClient.telephone,
|
||||
newClient.adresse,
|
||||
]
|
||||
);
|
||||
});
|
||||
|
||||
Deno.serve(app.fetch);
|
6
package-lock.json
generated
Normal file
6
package-lock.json
generated
Normal file
@ -0,0 +1,6 @@
|
||||
{
|
||||
"name": "DepannToutAPI",
|
||||
"lockfileVersion": 3,
|
||||
"requires": true,
|
||||
"packages": {}
|
||||
}
|
40
sql.sql
Normal file
40
sql.sql
Normal file
@ -0,0 +1,40 @@
|
||||
CREATE TABLE clients (
|
||||
idClient INT PRIMARY KEY AUTO_INCREMENT,
|
||||
nom VARCHAR(255),
|
||||
prenom VARCHAR(255),
|
||||
adresse VARCHAR(255),
|
||||
email VARCHAR(255),
|
||||
telephone VARCHAR(255)
|
||||
);
|
||||
|
||||
CREATE TABLE interventions (
|
||||
idIntervention INT PRIMARY KEY AUTO_INCREMENT,
|
||||
observation LONGTEXT,
|
||||
date DATE,
|
||||
idClient INT,
|
||||
FOREIGN KEY (idClient) REFERENCES clients(idClient)
|
||||
);
|
||||
|
||||
INSERT INTO clients (nom, prenom, adresse, email, telephone) VALUES
|
||||
('Doe', 'John', '123 Main St', 'johndoe@example.com', '123-456-7890'),
|
||||
('Smith', 'Jane', '456 Elm St', 'janesmith@example.com', '987-654-3210'),
|
||||
('Johnson', 'Bob', '789 Oak St', 'bobjohnson@example.com', '555-123-4567'),
|
||||
('Williams', 'Alice', '321 Maple St', 'alicewilliams@example.com', '901-234-5678'),
|
||||
('Jones', 'Mike', '901 Pine St', 'mikejones@example.com', '111-222-3333'),
|
||||
('Brown', 'Emma', '234 Cedar St', 'emmabrown@example.com', '444-555-6666'),
|
||||
('Davis', 'Tom', '567 Spruce St', 'tomdavis@example.com', '777-888-9999'),
|
||||
('Miller', 'Lily', '890 Walnut St', 'lilymiller@example.com', '333-444-5555'),
|
||||
('Wilson', 'Sam', '345 Hickory St', 'samwilson@example.com', '666-777-8888'),
|
||||
('Moore', 'Olivia', '678 Beech St', 'oliviamoore@example.com', '999-000-1111');
|
||||
|
||||
INSERT INTO interventions (observation, date, idClient) VALUES
|
||||
('Test intervention 1', '2022-01-01', 1),
|
||||
('Test intervention 2', '2022-01-02', 2),
|
||||
('Test intervention 3', '2022-01-03', 3),
|
||||
('Test intervention 4', '2022-01-04', 4),
|
||||
('Test intervention 5', '2022-01-05', 5),
|
||||
('Test intervention 6', '2022-01-06', 6),
|
||||
('Test intervention 7', '2022-01-07', 7),
|
||||
('Test intervention 8', '2022-01-08', 8),
|
||||
('Test intervention 9', '2022-01-09', 9),
|
||||
('Test intervention 10', '2022-01-10', 10);
|
Loading…
x
Reference in New Issue
Block a user