| @ -0,0 +1,5 @@ | ||||
| /* Copyright © 2023 Entreprise SpaceTarders */ | ||||
| canvas { | ||||
|     border: 2px solid rgb(7, 18, 41); | ||||
|     border-radius: 5px; | ||||
| } | ||||
| @ -0,0 +1,40 @@ | ||||
| /* Copyright © 2023 Entreprise SpaceTarders */ | ||||
| html{ | ||||
|     background-color: rgb(7, 18, 41); | ||||
|     cursor: crosshair; | ||||
| } | ||||
| main{ | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
| } | ||||
| #title{ | ||||
|     font-family: M42; | ||||
|     font-size:15px; | ||||
|     margin-left: 10px; | ||||
|     margin-top: 10px; | ||||
|     color: white; | ||||
|     display: flex; | ||||
|     justify-content: left; | ||||
| } | ||||
| 
 | ||||
| #menu { | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
|     justify-content: space-between; | ||||
| } | ||||
| #menu button{ | ||||
|     margin-top: 15px; | ||||
|     font-family: M42; | ||||
|     color: white; | ||||
|     font-size: 11px; | ||||
|     background-color: rgb(20, 20, 32);  | ||||
|     cursor: pointer; | ||||
| } | ||||
| #canvas { | ||||
|     border: 2px solid rgb(7, 18, 41); | ||||
|     border-radius: 5px; | ||||
| } | ||||
| @font-face { | ||||
|     font-family: M42; | ||||
|     src: url(/fonts/m42.TTF); | ||||
|   } | ||||
| @ -0,0 +1,50 @@ | ||||
| /* Copyright © 2023 Entreprise SpaceTarders */ | ||||
| html{ | ||||
|     background-color: rgb(7, 18, 41); | ||||
| } | ||||
| img{ | ||||
|     width: 10%; | ||||
|     margin-right: 30px; | ||||
| } | ||||
| .text{ | ||||
|     font-size:8px; | ||||
|     font-family: M42; | ||||
|     color: white; | ||||
| } | ||||
| header p{ | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
| } | ||||
| #title{ | ||||
|     font-family: M42; | ||||
|     font-size:20px; | ||||
|     margin-left: 10px; | ||||
|     margin-top: 50px; | ||||
|     color: white; | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
| } | ||||
| #menu { | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
|     justify-content: space-between; | ||||
| } | ||||
| #menu button{ | ||||
|     margin-top: 15px; | ||||
|     font-family: M42; | ||||
|     color: white; | ||||
|     font-size: 15px; | ||||
|     background-color: rgb(20, 20, 32);  | ||||
| } | ||||
| footer p{ | ||||
|     position: fixed; | ||||
|     bottom: 0; | ||||
| } | ||||
| canvas { | ||||
|     border: 2px solid rgb(7, 18, 41); | ||||
|     border-radius: 5px; | ||||
| } | ||||
| @font-face { | ||||
|     font-family: M42; | ||||
|     src: url(/fonts/m42.TTF); | ||||
|   } | ||||
| After Width: | Height: | Size: 3.5 KiB | 
| After Width: | Height: | Size: 3.0 KiB | 
| After Width: | Height: | Size: 3.8 KiB | 
| After Width: | Height: | Size: 969 KiB | 
| After Width: | Height: | Size: 209 KiB | 
| After Width: | Height: | Size: 315 KiB | 
| After Width: | Height: | Size: 203 KiB | 
| After Width: | Height: | Size: 135 B | 
| After Width: | Height: | Size: 767 B | 
| After Width: | Height: | Size: 579 B | 
| After Width: | Height: | Size: 729 B | 
| After Width: | Height: | Size: 675 B | 
| @ -0,0 +1,118 @@ | ||||
| let token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZGVudGlmaWVyIjoiUEVVU0RPU0FDSEEiLCJ2ZXJzaW9uIjoidjIuMS40IiwicmVzZXRfZGF0ZSI6IjIwMjMtMTItMDIiLCJpYXQiOjE3MDI1Mzk4NjUsInN1YiI6ImFnZW50LXRva2VuIn0.QL4rSruHd8pjNczeZQ3S7gof7TRnwZKqQBvkojUXgmzRrWiDZVw65kt1UBns0zHAhZF-m-bvxfUBik01uIzc-_jSO63ZndquPFmv_UY3HBkVK7UKoSaxAp_NveJsE1TOpTotUChlMd1Sv7RuyeR9fso2eN3-mBEoE5ukWmGVDfnOYefuWORhisqIkh4ti3QpaV-obycZ4XGV2ukqkiNdHqR3MQJR99e2nCEZEsarNKTgm6mgn-qCCNv4xQUGwhNbD5_p-jPqQ088vuFCeZi8j6kf7-fmT5sysBxEA5nvNPDIEL1XMuzs7N66WpiP1uc7I1Ph164m2epV9vmEvzthCw"; | ||||
| //décalage | ||||
| let offset = { | ||||
|     x: 2, | ||||
|     y: 2 | ||||
| }; | ||||
| let max = 40; | ||||
| let min = 35; | ||||
| let w = 1260; | ||||
| let h = 830; | ||||
| 
 | ||||
| const canvas = new fabric.Canvas("canvas",{ | ||||
|     width: w, | ||||
|     height: h, | ||||
|     backgroundColor:"rgb(7, 18, 41)", | ||||
|     renderOnAddRemove: false, | ||||
|     defaultCursor :'crosshair', | ||||
|     hoverCursor :'pointer' | ||||
| }); | ||||
| canvas.renderAll(); | ||||
| let planets = []; | ||||
| 
 | ||||
| function getAgent() { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: 'https://api.spacetraders.io/v2/my/agent', | ||||
|         method: 'GET', | ||||
|         headers: { | ||||
|         Accept: 'application/json', | ||||
|         Authorization: `Bearer ${token}` | ||||
|         } | ||||
|     }; | ||||
|     $.ajax(settings).done(function (reponse) { | ||||
|         let metaSystem = reponse.data.headquarters.split("-"); | ||||
|         getSystem(metaSystem[0] + "-" + metaSystem[1]); | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| function getSystem(system) { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: `https://api.spacetraders.io/v2/systems/${system}`, | ||||
|         method: 'GET', | ||||
|         headers: { | ||||
|             Accept: 'application/json' | ||||
|         } | ||||
|     }; | ||||
| 
 | ||||
|     $.ajax(settings).done(function (response) { | ||||
|         offsetOrbits(response.data.waypoints); | ||||
|         drawSystem(response.data.waypoints); | ||||
|     }); | ||||
| } | ||||
| function offsetOrbits(waypoints){ | ||||
|     waypoints.forEach((waypoint) => { | ||||
|         if (waypoint.orbits) { | ||||
|             let x = Math.floor(Math.random() * max - Math.random() * max); | ||||
|             let y =  Math.floor(Math.random() * max - Math.random() * max); | ||||
|             waypoint.orbitaldistance = { | ||||
|                 x: x, | ||||
|                 y: y | ||||
|             }; | ||||
|             waypoint.rotation = 3; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| function drawSystem(wayPoints) { | ||||
|     if(wayPoints) { | ||||
|         wayPoints.forEach(wayPoint => { | ||||
|             drawWaypoint(wayPoint); | ||||
|             //TestPlanetClicked(wayPoint); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| function drawWaypoint(wayPoint) { | ||||
|     let shadow = new fabric.Shadow({ | ||||
|         color: "white", | ||||
|         blur: 5, | ||||
|         offsetX: 0, | ||||
|         offsetY: 0, | ||||
|       }); | ||||
| 
 | ||||
|     fabric.Image.fromURL('http://127.0.0.1:5500/img/planets/planetproto.png', function(planet) { | ||||
|         //FABRICJS | ||||
|         planet.set({selectable: false}); | ||||
|         planet.set({shadow: shadow}); | ||||
|         //AJOUT DES PROPRIÉTÉS DES WAYPOINT SUR LES PLANETES | ||||
|         planet.set({left: wayPoint.x/offset.x + w/2}); | ||||
|         planet.set({top: wayPoint.y/offset.y+ h/2}); | ||||
|         planet.set({name: wayPoint.symbol}); | ||||
|         planet.set({type: wayPoint.type}); | ||||
|         canvas.add(planet); | ||||
|       }); | ||||
|     planets.push(wayPoint); | ||||
| } | ||||
| function movePlanets() { | ||||
|     planets.forEach(waypoint => { | ||||
|         if(waypoint.rotation != 0){ | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| getAgent(); | ||||
| setTimeout(function animate() { | ||||
|     movePlanets(); | ||||
|     canvas.renderAll(); | ||||
|     setTimeout(animate, 1000); | ||||
| }, 10); | ||||
| 
 | ||||
| canvas.on('mouse:up', function (e) { | ||||
|     if(e.target.shadow.color == "red"){ | ||||
|         e.target.shadow.color = "white" | ||||
|     } | ||||
|     else{ | ||||
|         e.target.shadow.color = "red" | ||||
|     } | ||||
| }) | ||||
| @ -0,0 +1,6 @@ | ||||
| const canvas = new fabric.Canvas("canvas",{ | ||||
|     width: 500, | ||||
|     height: 500, | ||||
|     backgroundColor:"black" | ||||
| }); | ||||
| canvas.renderAll(); | ||||
| @ -0,0 +1,226 @@ | ||||
| //Copyright © 2023 Entreprise SpaceTarders
 | ||||
| //variables de rotation
 | ||||
| let msPrev = window.performance.now() | ||||
| const fps = 60 | ||||
| const msPerFrame = 1000 / fps | ||||
| let frames = 0 | ||||
| //variables de tailles de planète
 | ||||
| let xxl = 20 | ||||
| let xl = 15 | ||||
| let l = 10 | ||||
| let m = 5 | ||||
| let s = 4 | ||||
| let xs = 3 
 | ||||
| let max = 40; | ||||
| let min = 35; | ||||
| //jeton d'agent
 | ||||
| let token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZGVudGlmaWVyIjoiUFJSUk9VVCIsInZlcnNpb24iOiJ2Mi4xLjQiLCJyZXNldF9kYXRlIjoiMjAyMy0xMi0wMiIsImlhdCI6MTcwMjAzODIwOCwic3ViIjoiYWdlbnQtdG9rZW4ifQ.iCm_0x9shooAE7028tBHw-p8NAXf8_EWBZl-wnqIpMIIRCe8A6rzEkaKnX-1OORBh31YQTekSOLdP5_FnA0AEP2KP00YzGEZWQBxSTndkpivtcS6X-arc4F6yJGvcLfT1m3ZD47LGylTELR3I-sXomX2Va8_13oN6kdDJyXpVWFe5OIC01bP_cwHpjztUTO-8ASPJ_8cLZH6GTSAzy5ozF1teTEdfq93s2i9oTPhynQKogdzaXAUIkAXv7hYv5XUbevorRaCfTl52CU7WK5__3org5ardHuITmbl0QyHYIWtkbpcZLcawfEGG0EK66iqwefdXIkTeWC3T1b_ERShMw"; | ||||
| //décalage
 | ||||
| let offset = { | ||||
|     x: 2, | ||||
|     y: 2 | ||||
| }; | ||||
| //Instanciation du canevas
 | ||||
| const canvas = document.getElementById("canvas"); | ||||
| canvas.style="width:100%;height:100vh;" | ||||
| let w = canvas.width = canvas.offsetWidth; | ||||
| let h = canvas.height = canvas.offsetHeight; 
 | ||||
| const ctx = canvas.getContext("2d"); | ||||
| let wayPoints = null | ||||
| //Initialisation du jeu
 | ||||
| function initGame() { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: 'https://api.spacetraders.io/v2/register', | ||||
|         method: 'POST', | ||||
|         headers: { | ||||
|           'Content-Type': 'application/json', | ||||
|           Accept: 'application/json' | ||||
|         }, | ||||
|         processData: false, | ||||
|         data: '{\n  "faction": "COSMIC",\n  "symbol": "ANNNNulax1225",\n  "email": ""\n}' | ||||
|     }; | ||||
|     
 | ||||
|     $.ajax(settings).done(function (response) { | ||||
|         console.log(response); | ||||
|     }); | ||||
| } | ||||
| //Récuperer l'agent
 | ||||
| function getAgent() { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: 'https://api.spacetraders.io/v2/my/agent', | ||||
|         method: 'GET', | ||||
|         headers: { | ||||
|         Accept: 'application/json', | ||||
|         Authorization: `Bearer ${token}` | ||||
|         } | ||||
|     }; | ||||
|     $.ajax(settings).done(function (reponse) { | ||||
|         $('.main-window').prepend(` | ||||
|         <article class="agent-card"> | ||||
|             <p class="account">${reponse.data.accountId}</p> | ||||
|             <p class="symbol">${reponse.data.symbol}</p> | ||||
|             <p class="headquarters">${reponse.data.headquarters}</p> | ||||
|             <p class="credits">${reponse.data.credits}</p> | ||||
|             <p class="startingFaction">${reponse.data.startingFaction}</p> | ||||
|             <p class="shipCount">${reponse.data.shipCount}</p> | ||||
|         </article> | ||||
|         `);
 | ||||
|         let metaSystem = reponse.data.headquarters.split("-"); | ||||
|         getSystem(metaSystem[0] + "-" + metaSystem[1]); | ||||
|     }); | ||||
| } | ||||
| //Récuperer les planètes
 | ||||
| function getWayPoint(wayPoint) { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: `https://api.spacetraders.io/v2/systems/systemSymbol/waypoints/${wayPoint}`, | ||||
|         method: 'GET', | ||||
|         headers: { | ||||
|             Accept: 'application/json' | ||||
|         } | ||||
|     }; | ||||
|       
 | ||||
|     $.ajax(settings).done(function (response) { | ||||
|         console.log(response); | ||||
|     }); | ||||
| }; | ||||
| //Récuperer le système
 | ||||
| function getSystem(system) { | ||||
|     const settings = { | ||||
|         async: true, | ||||
|         crossDomain: true, | ||||
|         url: `https://api.spacetraders.io/v2/systems/${system}`, | ||||
|         method: 'GET', | ||||
|         headers: { | ||||
|             Accept: 'application/json' | ||||
|         } | ||||
|     }; | ||||
| 
 | ||||
|     $.ajax(settings).done(function (response) { | ||||
|         response.data.waypoints.forEach((waypoint) => { | ||||
|             waypoint.rotation = 0 | ||||
|             if (waypoint.orbits) { | ||||
|                 let x = Math.floor(Math.random() * max - Math.random() * max); | ||||
|                 let y =  Math.floor(Math.random() * max - Math.random() * max); | ||||
|                 waypoint.x += x > 0 ? x + min : x - min; | ||||
|                 waypoint.y += y > 0 ? y + min : y - min; | ||||
|             } | ||||
|         }) | ||||
|         wayPoints = response.data.waypoints; | ||||
|     }); | ||||
| } | ||||
| // function drawBackground(){
 | ||||
| //     // Create gradient
 | ||||
| //     var grd = ctx.createRadialGradient(650, 450, 5, 600, 450, 550);
 | ||||
| //     grd.addColorStop(0, "rgb(15, 38, 88)");
 | ||||
| //     grd.addColorStop(1, "rgb(13, 7, 46)");
 | ||||
| //     // Fill with gradient
 | ||||
| //     ctx.fillStyle = grd;
 | ||||
| //     ctx.fillRect(0, 0, w, h);
 | ||||
| //     ctx.clearRect(0, 0, w, h);
 | ||||
| // }
 | ||||
| 
 | ||||
| //dessiner le système
 | ||||
| function drawSystem() { | ||||
|     window.requestAnimationFrame(drawSystem) | ||||
|     ctx.fillStyle = "rgb(0,0,0)" | ||||
|     ctx.fillRect(0, 0, w, h); | ||||
|     const msNow = window.performance.now() | ||||
|     const msPassed = msNow - msPrev | ||||
|   
 | ||||
|     if (msPassed < msPerFrame) return | ||||
|   
 | ||||
|     const excessTime = msPassed % msPerFrame | ||||
|     msPrev = msNow - excessTime | ||||
|   
 | ||||
|     frames++ | ||||
|     if(wayPoints) { | ||||
|     wayPoints.forEach(wayPoint => { | ||||
|             switch (wayPoint.type) { | ||||
|                 //PLANÈTE
 | ||||
|                 case "PLANET": | ||||
|                     //QG
 | ||||
|                     if(wayPoint.x/offset.x + w  == 0 && wayPoint.y/offset.y + h == 0){ | ||||
|                         drawWaypointCircle(wayPoint, ctx, w/2, h/2, 'rgb(255, 255, 0)', xxl); //jaune clair
 | ||||
|                     } | ||||
|                     else{ | ||||
|                         drawWaypointCircle(wayPoint, ctx, w/2, h/2, 'rgb(6, 218, 52)', m); //vert clair
 | ||||
|                     } | ||||
|                     break; | ||||
|                 //PLANÈTE GAZEUSE
 | ||||
|                 case "GAS_GIANT": 
 | ||||
|                     drawWaypointCircle(wayPoint, ctx, w/2, h/2, 'rgb(255, 174, 0)', l); //orange clair
 | ||||
|                     break; | ||||
|                 //LUNE
 | ||||
|                 case "MOON": | ||||
|                     drawWaypointCircle(wayPoint,ctx, w/2, h/2, 'rgb(255, 255, 255)', xs) //blanc
 | ||||
|                     break; | ||||
|                 //STATION EN ORBITE
 | ||||
|                 case "ORBITAL_STATION": | ||||
|                     drawWaypointPolygone(wayPoint,ctx, w/2, h/2, 'rgb(0, 153, 255)', 4, s) //bleu clair
 | ||||
|                     break; | ||||
|                 //PORTAIL
 | ||||
|                 case "JUMP_GATE": | ||||
|                     wayPoint.rotation += Math.PI / 50 | ||||
|                     drawWaypointPolygone(wayPoint,ctx, w/2, h/2, 'rgb(67, 0, 250)', 5, xl) //violet
 | ||||
|                     break; | ||||
|                 //ASTÉROÏDE
 | ||||
|                 case "ASTEROID": | ||||
|                     wayPoint.rotation += Math.PI / 200 | ||||
|                     drawWaypointPolygone(wayPoint,ctx, w/2, h/2, 'rgb(163, 163, 163)', 5, m) //bleu clair
 | ||||
|                     break; | ||||
|                 case "ASTEROID_FIELD": | ||||
|                 case "ASTEROID_BASE": | ||||
|                 case "ENGINEERED_ASTEROID":  
 | ||||
|                     drawWaypointCircle(wayPoint,ctx, w/2, h/2, 'rgb(255, 0, 255)', m) //jaune
 | ||||
|                     break; | ||||
|                 //NEBULEUSE
 | ||||
|                 case "NEBULA": 
 | ||||
|                     drawWaypointCircle(wayPoint,ctx, w/2, h/2, 'rgb(67, 0, 250)', m) //violet fluo
 | ||||
|                     break; 
 | ||||
|                 //CHAMP DE DÉBRIS
 | ||||
|                 case "DEBRIS_FIELD": | ||||
|                     drawWaypointCircle(wayPoint,ctx, w/2, h/2, 'rgb(107, 106, 143)', m) //gris/bleu 
 | ||||
|                     break; | ||||
|                 //PUIT DE GRAVITÉ
 | ||||
|                 case "GRAVITY_WELL": | ||||
|                 case "ARTIFICIAL_GRAVITY_WELL":    
 | ||||
|                     drawWaypointCircle(wayPoint,ctx, w/2, h/2, 'rgb()') //
 | ||||
|                     break; | ||||
|                 //STATION ESSENCE
 | ||||
|                 case "FUEL_STATION": | ||||
|                     drawWaypointPolygone(wayPoint,ctx, w/2, h/2, 'rgb(255, 0, 0)', 4, m) //rouge
 | ||||
|                     break;    
 | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| //dessiner un cercle
 | ||||
| function drawWaypointCircle(wayPoint, ctx, w, h, color, radius) { | ||||
|     ctx.beginPath(); | ||||
|     ctx.fillStyle = color; | ||||
|     ctx.arc(wayPoint.x/offset.x + w, wayPoint.y/offset.y + h, radius, 0, 2 * Math.PI); | ||||
|     ctx.fill() | ||||
| } | ||||
| //dessiner une forme polygonale
 | ||||
| function drawWaypointPolygone(wayPoint, ctx, w, h, color, nbCote, radius){ | ||||
|     let numberOfSides = nbCote; | ||||
|    	let x = wayPoint.x/offset.x + w; | ||||
|     let y = wayPoint.y/offset.y + h; | ||||
| 	let angle = 2*Math.PI/numberOfSides; | ||||
|     ctx.beginPath(); | ||||
|     ctx.fillStyle = color; | ||||
|     ctx.moveTo (x +  radius*Math.cos(wayPoint.rotation + 0), y +  radius*Math.sin(wayPoint.rotation + 0));          
 | ||||
|  		for (let i = 0; i < numberOfSides; i++) { | ||||
| 			 ctx.lineTo (x + radius*Math.cos(wayPoint.rotation + (i * angle)), y + radius*Math.sin(wayPoint.rotation +(i * angle))); | ||||
| 		} | ||||
|  	ctx.fill(); | ||||
| } | ||||
| 
 | ||||
| drawSystem(); | ||||
| getAgent(); | ||||
| @ -0,0 +1,32 @@ | ||||
| <!-- Copyright © 2023 Entreprise SpaceTarders --> | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta http-equiv="X-UA-Compatible" content="IE=edge"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <link rel="stylesheet" href="../css/styleindex.css"> | ||||
|     <link rel="icon" type="image/png" href="/img/spaceships/spaceship.png"> | ||||
|     <script src="https://code.jquery.com/jquery-3.7.1.min.js" integrity="sha256-/JqT3SQfawRcv/BIHPThkBvs0OEvtFFmqPF/lYI/Cxo=" crossorigin="anonymous"></script> | ||||
|     <script src ="/js/fabric.min.js" defer></script> | ||||
|     <script src="/js/TEST_F.JS" defer></script> | ||||
|     <title>Space Traders : by SKAMKRAFT</title> | ||||
| </head> | ||||
| <body> | ||||
|     <header> | ||||
|         <div id="title">SpaceTraders</div> | ||||
|     </header> | ||||
|     <main class="main-window"> | ||||
|         <br> | ||||
|         <canvas id="canvas"></canvas> | ||||
|     </main> | ||||
|     <footer> | ||||
|         <div id="menu"> | ||||
|             <button id="agentbutton">Agent</button> | ||||
|             <button id="factionbutton">Faction</button> | ||||
|             <button id="shipbutton">Ships</button> | ||||
|             <button id="contractbutton">Contracts</button> | ||||
|         </div> | ||||
|     </footer> | ||||
| </body> | ||||
| </html> | ||||
| @ -0,0 +1,24 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <link rel="stylesheet" href="../css/stylelogin.css"> | ||||
|     <title>Login</title> | ||||
| </head> | ||||
| <body> | ||||
|     <header> | ||||
|         <div id="title"> | ||||
|             <img src="/img/logo/logoblancnotext.png" alt="logo"> | ||||
|             <h1>SpaceTraders</h1> | ||||
|         </div> | ||||
|         <p class="text">API loaded with SKAMKRAFT</p> | ||||
|     </header> | ||||
|     <main> | ||||
| 
 | ||||
|     </main> | ||||
|     <footer> | ||||
|         <p class="text">Copyright 2023 Entreprise SKAMKRAFT</p> | ||||
|     </footer> | ||||
| </body> | ||||
| </html> | ||||
| @ -0,0 +1 @@ | ||||
| eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZGVudGlmaWVyIjoiUEVVU0RPU0FDSEEiLCJ2ZXJzaW9uIjoidjIuMS40IiwicmVzZXRfZGF0ZSI6IjIwMjMtMTItMDIiLCJpYXQiOjE3MDI1Mzk4NjUsInN1YiI6ImFnZW50LXRva2VuIn0.QL4rSruHd8pjNczeZQ3S7gof7TRnwZKqQBvkojUXgmzRrWiDZVw65kt1UBns0zHAhZF-m-bvxfUBik01uIzc-_jSO63ZndquPFmv_UY3HBkVK7UKoSaxAp_NveJsE1TOpTotUChlMd1Sv7RuyeR9fso2eN3-mBEoE5ukWmGVDfnOYefuWORhisqIkh4ti3QpaV-obycZ4XGV2ukqkiNdHqR3MQJR99e2nCEZEsarNKTgm6mgn-qCCNv4xQUGwhNbD5_p-jPqQ088vuFCeZi8j6kf7-fmT5sysBxEA5nvNPDIEL1XMuzs7N66WpiP1uc7I1Ph164m2epV9vmEvzthCw | ||||