Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 35 additions & 0 deletions Topic1/pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<profiles>
<profile>
<id> noTest </id>
<properties>
<maven.test.skip>true</maven.test.skip>
</properties>
</profile>
</profiles>

<groupId>bootcampGlobant-java</groupId>
<artifactId>Topic1</artifactId>
<version>1.0-SNAPSHOT</version>

<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>




</project>
40 changes: 40 additions & 0 deletions Topic1/src/main/java/Person.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
public class Person {
String userName;
String password;
String dni;

public Person(String userName) {
this.userName = userName;
}

public Person(String myuserName, String mypassword, String myDni) {
this.userName = myuserName;
this.dni = myDni;
this.password = mypassword;
}


public String getUserName() {
return userName;
}

public void setUserName(String userName) {
this.userName = userName;
}

public String getPassword() {
return password;
}

public void setPassword(String password) {
this.password = password;
}

public String getDni() {
return dni;
}

public void setDni(String dni) {
this.dni = dni;
}
}
14 changes: 14 additions & 0 deletions Topic1/src/test/java/myTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import org.junit.Assert;
import org.junit.Test;

public class myTest {
@Test
public void myFirstTest(){
Person myPerson = new Person("name", "pass", "dni");
Assert.assertNotNull(myPerson);
Assert.assertEquals(myPerson.getUserName(), "name");
Assert.assertEquals(myPerson.getPassword(), "pass");
Assert.assertEquals(myPerson.getDni(), "dni");
}

}
24 changes: 24 additions & 0 deletions topic0/AbstractFactory/ConnectionFactory.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package AbstractFactory;

import Drivers.DriverConnection;
import Drivers.MySQLDriverManager;
import Drivers.SQLDriverManager;

public class ConnectionFactory extends ConnectionsAbstractFactory {
@Override
public DriverConnection getConnection(String SQL) {
if( SQL == null) {
return null;
}

if(SQL.equalsIgnoreCase("MySql")) {
return new MySQLDriverManager();

} else if(SQL.equalsIgnoreCase("SqlServer")) {
return new SQLDriverManager();
}

return null;

}
}
26 changes: 26 additions & 0 deletions topic0/AbstractFactory/ConnectionProducer.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package AbstractFactory;

import Connections.Connection;
import Drivers.MySQLDriverManager;
import Drivers.SQLDriverManager;

public class ConnectionProducer {
private static Connection connection;

public static Connection getConnection(String choise, String dataBase, String user, String password) {
if( choise == null) {
connection = null;
}

if(choise.equalsIgnoreCase("MySql")) {
MySQLDriverManager mySql= new MySQLDriverManager();
connection = mySql.getConnection(dataBase, user, password);

} else if(choise.equalsIgnoreCase("SqlServer")) {
SQLDriverManager sqlServer = new SQLDriverManager();
connection = sqlServer.getConnection(dataBase, user, password);
}

return connection;
}
}
7 changes: 7 additions & 0 deletions topic0/AbstractFactory/ConnectionsAbstractFactory.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package AbstractFactory;

import Drivers.DriverConnection;

public abstract class ConnectionsAbstractFactory {
abstract DriverConnection getConnection(String SQL);
}
9 changes: 9 additions & 0 deletions topic0/Builder/Builder.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package Builder;

import Connections.DataBaseConnection;

public interface Builder {

public DataBaseConnection getConnection();

}
14 changes: 14 additions & 0 deletions topic0/Builder/Director.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package Builder;

public class Director {
private Builder connectionBuilder = null;

public Director(Builder mealBuilder) {
this.connectionBuilder = mealBuilder;
}

public void constructConnection() {
connectionBuilder.getConnection();
}

}
19 changes: 19 additions & 0 deletions topic0/Builder/MySQLBuilder.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package Builder;

import Connections.DataBaseConnection;

public class MySQLBuilder implements Builder{

private DataBaseConnection myConnection;

public MySQLBuilder(String dataBase) {
myConnection.getInstance("MySql", dataBase , "sara", "myConnection");
}

@Override
public DataBaseConnection getConnection() {
return myConnection;
}


}
18 changes: 18 additions & 0 deletions topic0/Connections/Connection.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package Connections;

public class Connection {

private static Boolean connect = false;
private String dataBase = "testingDataBase";
private String user = "sara";
private String password = "myConnection";

public Connection(String database, String user, String password) {
if(this.dataBase.equals(database) && this.user.equals(user) && this.password.equals(password) ) {
connect = true;
}else {
System.out.print("You have an error in your connection. Please, try again later");
}
}

}
45 changes: 45 additions & 0 deletions topic0/Connections/DataBaseConnection.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
package Connections;

import AbstractFactory.ConnectionProducer;

public class DataBaseConnection {

private Connection myConnection;
private static DataBaseConnection dataBaseConnection = null;

private DataBaseConnection(){
try {
myConnection = ConnectionProducer.getConnection("MySql","testingDataBase", "sara", "myConnection");
} catch (Exception e) {
e.printStackTrace();
}
}


public static DataBaseConnection getInstance() {
if(dataBaseConnection == null) {
dataBaseConnection = new DataBaseConnection();
}
return dataBaseConnection;
}

//Builder Patron methods
private DataBaseConnection(String odbc, String dataBase, String user, String password) {
try {
myConnection = ConnectionProducer.getConnection(odbc, dataBase, user, password);
}catch(Exception e) {
e.printStackTrace();}
}

public static DataBaseConnection getInstance(String odbc, String dataBase, String user, String password) {
if(dataBaseConnection == null) {
dataBaseConnection = new DataBaseConnection(odbc, dataBase, user, password);
}
return dataBaseConnection;
}

public Connection getConnection() {
return myConnection;
}

}
7 changes: 7 additions & 0 deletions topic0/Drivers/DriverConnection.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package Drivers;

import Connections.Connection;

public interface DriverConnection {
public Connection getConnection(String dataBase, String u, String p);
}
13 changes: 13 additions & 0 deletions topic0/Drivers/MySQLDriverManager.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package Drivers;

import Connections.Connection;

public class MySQLDriverManager implements DriverConnection{
public MySQLDriverManager() {
}

public Connection getConnection(String dataBase, String user, String password) {
return new Connection(dataBase, user, password);
}

}
14 changes: 14 additions & 0 deletions topic0/Drivers/SQLDriverManager.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package Drivers;

import Connections.Connection;

public class SQLDriverManager implements DriverConnection{

public SQLDriverManager() {
}

public Connection getConnection(String dataBase, String user, String password) {
return new Connection(dataBase, user, password);
}

}
13 changes: 13 additions & 0 deletions topic0/Main.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@

public class Main {

public static void main(String[] args) {
Proxy aConnection = new Proxy();
if(aConnection.mySqlConnection())
System.out.print("i'm functioning");
else
System.out.print("I failed");

}

}
28 changes: 28 additions & 0 deletions topic0/Proxy.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import Builder.Director;
import Builder.MySQLBuilder;
import Connections.DataBaseConnection;

public class Proxy {
Director myConnectionDirector = null;

public Proxy() {}

/** This method return true if the connection was done
* or false if there was any error.
* */
public boolean mySqlConnection(){
boolean result=false;
try {
if(myConnectionDirector == null) {
MySQLBuilder mysql = new MySQLBuilder("testingDataBase");
this.myConnectionDirector = new Director(mysql);
this.myConnectionDirector.constructConnection();
}
result=true;
}catch(Exception e) {
e.printStackTrace();
}
return result;
}

}