Merge pull request 'API' (#130) from API into master
continuous-integration/drone/push Build is passing Details

Reviewed-on: #130
modifStub
Hugo LIVET 2 years ago
commit 45b220c477

@ -15,6 +15,7 @@ steps:
- dotnet restore CI_MAUI.sln - dotnet restore CI_MAUI.sln
- dotnet build CI_MAUI.sln -c Release --no-restore - dotnet build CI_MAUI.sln -c Release --no-restore
- dotnet publish CI_MAUI.sln -c Release --no-restore -o CI_PROJECT_DIR/build/release - dotnet publish CI_MAUI.sln -c Release --no-restore -o CI_PROJECT_DIR/build/release
- name: tests - name: tests
image: mcr.microsoft.com/dotnet/sdk:6.0 image: mcr.microsoft.com/dotnet/sdk:6.0
commands: commands:
@ -22,6 +23,7 @@ steps:
- dotnet restore CI_MAUI.sln - dotnet restore CI_MAUI.sln
- dotnet test CI_MAUI.sln --no-restore - dotnet test CI_MAUI.sln --no-restore
depends_on: [build] depends_on: [build]
- name: code-analysis - name: code-analysis
image: hub.codefirst.iut.uca.fr/thomas.bellembois/codefirst-dronesonarplugin-dotnet6 image: hub.codefirst.iut.uca.fr/thomas.bellembois/codefirst-dronesonarplugin-dotnet6
commands: commands:
@ -42,13 +44,52 @@ steps:
sonar_token: sonar_token:
from_secret: SECRET_SONAR_LOGIN from_secret: SECRET_SONAR_LOGIN
depends_on: [tests] depends_on: [tests]
# database container deployment
- name: deploy-container-mysql - name: deploy-container-mysql
image: hub.codefirst.iut.uca.fr/thomas.bellembois/codefirst-dockerproxy-clientdrone:latest image: hub.codefirst.iut.uca.fr/thomas.bellembois/codefirst-dockerproxy-clientdrone:latest
environment: environment:
IMAGENAME: postgres IMAGENAME: mariadb:latest
CONTAINERNAME: mysql CONTAINERNAME: mariadb
COMMAND: create COMMAND: create
PRIVATE: true OVERWRITE: true
POSTGRES_PASSWORD: oui PRIVATE: false
CODEFIRST_CLIENTDRONE_ENV_MARIADB_ROOT_PASSWORD:
from_secret: db_root_password
CODEFIRST_CLIENTDRONE_ENV_MARIADB_DATABASE:
from_secret: db_database
CODEFIRST_CLIENTDRONE_ENV_MARIADB_USER:
from_secret: db_user
CODEFIRST_CLIENTDRONE_ENV_MARIADB_PASSWORD:
from_secret: db_password
- name: web-API
image: plugins/docker
settings:
dockerfile: ./Dockerfile
context: ./
registry: hub.codefirst.iut.uca.fr
repo: hub.codefirst.iut.uca.fr/vincent.astolfi/conseco
username:
from_secret: secret-registry-username
password:
from_secret: secret-registry-password
- name: deploy-web-container
image: hub.codefirst.iut.uca.fr/thomas.bellembois/codefirst-dockerproxy-clientdrone:latest
environment:
IMAGENAME: hub.codefirst.iut.uca.fr/vincent.astolfi/conseco:latest
CONTAINERNAME: conseco
COMMAND: create
OVERWRITE: true
CODEFIRST_CLIENTDRONE_ENV_DB_SERVER:
from_secret: db_server
CODEFIRST_CLIENTDRONE_ENV_MARIADB_ROOT_PASSWORD:
from_secret: db_root_password
CODEFIRST_CLIENTDRONE_ENV_MARIADB_DATABASE:
from_secret: db_database
CODEFIRST_CLIENTDRONE_ENV_MARIADB_USER:
from_secret: db_user
CODEFIRST_CLIENTDRONE_ENV_MARIADB_PASSWORD:
from_secret: db_password
depends_on: [ web-API, deploy-container-mysql ]

@ -1,20 +1,6 @@
FROM aosapps/drone-sonar-plugin AS base FROM php:8.1-apache
FROM mcr.microsoft.com/dotnet/sdk:6.0-alpine RUN apt-get update && apt-get install -y mariadb-client
RUN docker-php-ext-install mysqli pdo pdo_mysql && docker-php-ext-enable pdo_mysql
COPY --from=base /bin/drone-sonar /bin/ COPY ./Sources/API /var/www/html/
WORKDIR /bin COPY ./Sources/Data /sql/
RUN cd /sql/
RUN apk update && apk add openjdk11-jre nodejs && rm -rf /tmp/* /var/cache/apk/*
RUN dotnet tool install --global dotnet-sonarscanner
RUN dotnet tool install --global dotnet-reportgenerator-globaltool
ENV JAVA_HOME /usr/lib/jvm/default-jvm/
ENV PATH ${PATH}:${JAVA_HOME}/bin
ENV PATH $PATH:/root/.dotnet/tools
ENTRYPOINT /bin/drone-sonar
RUN dotnet sonarscanner begin /k:"ConsEco" /d:sonar.host.url="https://codefirst.iut.uca.fr/sonar" /d:sonar.login="sqp_ffc02968e133d03daeb917e8c2e6f243a80d087a"
RUN dotnet build
RUN dotnet sonarscanner end /d:sonar.login="sqp_ffc02968e133d03daeb917e8c2e6f243a80d087a"

@ -0,0 +1,32 @@
<?php
class Autoload{
private static $_instance = null;
public static function charger(){
if(null!==self::$_instance){
throw new RuntimeException(sprintf("%s is already started",__CLASS__));
}
self::$_instance=new self();
if(!spl_autoload_register(array(self::$_instance,'_autoload'),true)){
throw new RuntimeException(sprintf("%s : Could not start the autoload",__CLASS__));
}
}
private static function _autoload($class){
global $rep;
$filename = $class.'.php';
$dir=array("./","config/","controller/","modele/","modele/gateways/");
foreach($dir as $d){
$file=$rep.$d.$filename;
// echo "<p>$file</p>";
if(file_exists($file)){
include $file;
}
}
}
}
?>

@ -0,0 +1,9 @@
<?php
//prefixe
$rep=__DIR__.'/../';
$dsn='mysql:host='.getenv("DB_SERVER").';dbname='.getenv("MARIADB_DATABASE");
$dbname=getenv("MARIADB_DATABASE");
$usr=getenv("MARIADB_USER");
$mdp=getenv("MARIADB_PASSWORD");
?>

@ -0,0 +1,177 @@
<?php
class Controller{
function __construct($url){
global $dsn, $usr, $mdp;
$con = new Connection($dsn, $usr, $mdp);
$query ='DROP TABLE IF EXISTS Planification;
DROP TABLE IF EXISTS Opération;
DROP TABLE IF EXISTS Echeancier;
DROP TABLE IF EXISTS Compte;
DROP TABLE IF EXISTS InscrBanque;
DROP TABLE IF EXISTS Banque;
DROP TABLE IF EXISTS DeviseInscrit;
DROP TABLE IF EXISTS Inscrit;
DROP TABLE IF EXISTS Devise;
CREATE TABLE Devise
(
id char(3) PRIMARY KEY,
nom varchar(20)
);
CREATE TABLE Inscrit
(
id serial PRIMARY KEY,
nom varchar(40),
prenom varchar(40),
mail varchar(40) UNIQUE,
mdp varchar(40)
);
CREATE TABLE DeviseInscrit
(
devise char(3),
idInscrit serial UNIQUE,
PRIMARY KEY(devise,idInscrit),
FOREIGN KEY (devise) REFERENCES Devise(id),
FOREIGN KEY (idInscrit) REFERENCES Inscrit(id)
);
CREATE TABLE Banque
(
nom varchar(40) PRIMARY KEY,
urlsite varchar(60),
urllogo varchar(60),
urldl varchar(500)
);
CREATE TABLE InscrBanque
(
id serial PRIMARY KEY,
nomBanque varchar(40),
idInscrit serial,
UNIQUE(nomBanque,idInscrit),
FOREIGN KEY (nomBanque) REFERENCES Banque(nom),
FOREIGN KEY (idInscrit) REFERENCES Inscrit(id)
);
CREATE TABLE Compte
(
id serial PRIMARY KEY,
nom varchar(40),
idInscritBanque serial,
FOREIGN KEY (idInscritBanque) REFERENCES InscrBanque(id),
UNIQUE(idInscritBanque,nom)
);
CREATE TABLE Echeancier
(
id serial PRIMARY KEY,
nom varchar(40),
credit numeric,
compte serial,
debit numeric,
dateE date,
datecrea date,
methodePayement varchar(20),
CONSTRAINT ck_methPaye CHECK (methodePayement IN ("CB","Cheque","Espece","Prélevement")),
FOREIGN KEY(compte) REFERENCES Compte(id),
UNIQUE (datecrea,compte)
);
CREATE TABLE Opération
(
id serial PRIMARY KEY,
nom varchar(40),
credit numeric,
compte serial,
debit numeric,
dateO date,
datecrea date,
methodePayement varchar(20),
CONSTRAINT ck_methPaye CHECK (methodePayement IN ("CB","Cheque","Espece","Prélevement")),
FOREIGN KEY(compte) REFERENCES Compte(id),
UNIQUE (datecrea,compte)
);
CREATE TABLE Planification
(
id serial PRIMARY KEY,
nom varchar(40),
credit numeric,
compte serial,
debit numeric,
dateP date,
datecrea date,
methodePayement varchar(20),
CONSTRAINT ck_methPaye CHECK (methodePayement IN ("CB","Cheque","Espece","Prélevement")),
FOREIGN KEY(compte) REFERENCES Compte(id),
UNIQUE (datecrea,compte)
);,';
$con->executeQueryWithoutParameters($query);
$query='INSERT INTO Devise VALUES("EUR","EURO");
INSERT INTO Devise VALUES("USD","DOLLAR");
INSERT INTO Devise VALUES("GBP","Livre Sterling");
INSERT INTO Devise VALUES("JPY","YEN");
INSERT INTO Devise VALUES("AUD","DOLLAR AUSTRALIEN");
INSERT INTO Devise VALUES("NZD","DOLLAR NEO-ZELANDAIS");
INSERT INTO Devise VALUES("ZAR","RANd");
INSERT INTO Inscrit (nom,prenom,mail,mdp)VALUES("EVARD","LUCAS","lucasevard@gmail.com","test");
INSERT INTO Inscrit (nom,prenom,mail,mdp)VALUES("MONCUL","STEPHANE","stef@gmail.com","teststef");
INSERT INTO Inscrit (nom,prenom,mail,mdp)VALUES("MENFOUMETTOITOUTNU","RENAUD","renaudtoutnu@gmail.com","test000");
INSERT INTO Inscrit (nom,prenom,mail,mdp)VALUES("YOUVOI","BENJAMIN","BENJAMIN@gmail.com","BENJAMIN");
INSERT INTO Inscrit (nom,prenom,mail,mdp)VALUES("TUBEAU","RAOUL","raoullacouille@gmail.com","zizi");
INSERT INTO DeviseInscrit VALUES("EUR","1");
INSERT INTO DeviseInscrit VALUES("JPY","2");
INSERT INTO DeviseInscrit VALUES("USD","3");
INSERT INTO DeviseInscrit VALUES("NZD","4");
INSERT INtO Banque(nom,urlsite,urllogo) VALUES("BNP PARIBAS","mabanque","imagesitebnb.fr");
INSERT INtO Banque(nom,urlsite,urllogo) VALUES("CREDIT AGRICOLE","credit-agricole.fr","imageca");
INSERT INtO Banque(nom,urlsite,urllogo) VALUES("BANQUE POSTALE","labanquepostale.fr","imgbp");
INSERT INtO Banque(nom,urlsite,urllogo) VALUES("CAISSE D EPARGNE","caisse-epargne.fr","imgcaissedepargne");
INSERT INTO InscrBanque (nomBanque,idInscrit)VALUES("BNP PARIBAS","1");
INSERT INTO InscrBanque (nomBanque,idInscrit)VALUES("CREDIT AGRICOLE","2");
INSERT INTO InscrBanque (nomBanque,idInscrit)VALUES("BANQUE POSTALE","3");
INSERT INTO InscrBanque (nomBanque,idInscrit)VALUES("CAISSE D EPARGNE","4");
INSERT INTO Compte (nom,idInscritBanque)VALUES("LIVRET A","1");
INSERT INTO Compte (nom,idInscritBanque)VALUES("LIVRET A","2");
INSERT INTO Compte (nom,idInscritBanque)VALUES("LIVRET A","3");
INSERT INTO Compte (nom,idInscritBanque)VALUES("LIVRET A","4");
INSERT INTO Planification (nom,credit,compte,datep,datecrea,methodePayement) VALUES ("EDF","190","1",now(),now(),"CB");
INSERT INTO Planification (nom,credit,compte,datep,datecrea,methodePayement) VALUES ("SPOTIFY","190","2",now(),now(),"Prélevement");
INSERT INTO Planification (nom,credit,compte,datep,datecrea,methodePayement) VALUES ("NETFLIX","190","3",now(),now(),"Cheque");
INSERT INTO Planification (nom,credit,compte,datep,datecrea,methodePayement) VALUES ("PLAYSTATION PLUS","190","4",now(),now(),"Espece");';
$con->ExecuteQueryWithoutParameters($query);
switch($url[0]){
case "SELECT":
switch($url[1]){
case "Inscrit":
$query = 'SELECT * FROM Inscrit';
$con->executeQueryWithoutParameters($query);
$res = $con->getResults();
print(json_encode($res));
break;
}
break;
default:
echo "ERREUR";
}
}
}
?>

@ -0,0 +1,13 @@
<?php
require_once(__DIR__.'/config/Config.php');
require_once(__DIR__.'/config/Autoload.php');
Autoload::charger();
$url='';
if(isset($_GET['url'])){
$url = explode('/',$_GET['url']);
}
$cont = new Controller($url);
?>

@ -0,0 +1,36 @@
<?php
class Connection extends PDO {
private $stmt;
public function __construct(string $dsn, string $username, string $password) {
parent::__construct($dsn,$username,$password);
$this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
/** * @param string $query
* @param array $parameters *
* @return bool Returns `true` on success, `false` otherwise
*/
public function executeQuery(string $query, array $parameters = []) : bool{
$this->stmt = parent::prepare($query);
foreach ($parameters as $name => $value) {
$this->stmt->bindValue($name, $value[0], $value[1]);
}
return $this->stmt->execute();
}
public function getResults() : array {
return $this->stmt->fetchall();
}
public function executeQueryWithoutParameters($query) : bool{
$this->stmt = parent::prepare($query);
return $this->stmt->execute();
}
}
?>

@ -0,0 +1,14 @@
<?php
class MdlInscrit{
static function selectAll(){
global $dsn, $usr, $mdp;
$con = new Connection($dsn, $usr, $mdp);
$gateway = new InscritGateway($con);
return $gateway->selectAll();
}
}
?>

@ -0,0 +1,17 @@
<?php
class InscritGateway{
private $con;
function __construct($con){
$this->con=$con;
}
public function selectAll(){
$query="SELECT * FROM Inscrit;";
$this->con->executeQueryWithoutParameters($query);
return $this->con->getResults();
}
}
?>
Loading…
Cancel
Save