From d2b0df0a00dc16d4318d61fea65c7785a62548f7 Mon Sep 17 00:00:00 2001 From: Azerothwav Date: Mon, 20 Jan 2025 16:28:11 +0100 Subject: [PATCH] feat: init --- .vscode/extensions.json | 5 +++ .vscode/settings.json | 6 +++ README.md | 18 +++++++++ deno.json | 12 ++++++ deno.lock | 81 +++++++++++++++++++++++++++++++++++++++++ main.ts | 50 +++++++++++++++++++++++++ package-lock.json | 6 +++ sql.sql | 40 ++++++++++++++++++++ 8 files changed, 218 insertions(+) create mode 100644 .vscode/extensions.json create mode 100644 .vscode/settings.json create mode 100644 README.md create mode 100644 deno.json create mode 100644 deno.lock create mode 100644 main.ts create mode 100644 package-lock.json create mode 100644 sql.sql diff --git a/.vscode/extensions.json b/.vscode/extensions.json new file mode 100644 index 0000000..c4eb3fe --- /dev/null +++ b/.vscode/extensions.json @@ -0,0 +1,5 @@ +{ + "recommendations": [ + "denoland.vscode-deno" + ] +} \ No newline at end of file diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..a2bb77c --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,6 @@ +{ + "deno.enablePaths": [ + "./" + ], + "editor.inlayHints.enabled": "off" +} \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..44b298f --- /dev/null +++ b/README.md @@ -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. \ No newline at end of file diff --git a/deno.json b/deno.json new file mode 100644 index 0000000..896f447 --- /dev/null +++ b/deno.json @@ -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" + } +} \ No newline at end of file diff --git a/deno.lock b/deno.lock new file mode 100644 index 0000000..45243d3 --- /dev/null +++ b/deno.lock @@ -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" + ] + } +} diff --git a/main.ts b/main.ts new file mode 100644 index 0000000..dac46cd --- /dev/null +++ b/main.ts @@ -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); diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..41456ca --- /dev/null +++ b/package-lock.json @@ -0,0 +1,6 @@ +{ + "name": "DepannToutAPI", + "lockfileVersion": 3, + "requires": true, + "packages": {} +} diff --git a/sql.sql b/sql.sql new file mode 100644 index 0000000..2c4cae9 --- /dev/null +++ b/sql.sql @@ -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);