diff --git a/.idea/caches/build_file_checksums.ser b/.idea/caches/build_file_checksums.ser
index d655409..37735c1 100644
Binary files a/.idea/caches/build_file_checksums.ser and b/.idea/caches/build_file_checksums.ser differ
diff --git a/app/build.gradle b/app/build.gradle
index ef38851..e7ff473 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -29,7 +29,9 @@ android {
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
+ implementation 'com.android.support:design:27.1.1'
testImplementation 'junit:junit:4.12'
+ testImplementation 'org.json:json:20140107'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index dfd28bf..98d711f 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -37,7 +37,10 @@
-
+
+
+
+
\ No newline at end of file
diff --git a/app/src/main/java/monnethic/mobile/homepage/LoginActivity.java b/app/src/main/java/monnethic/mobile/homepage/LoginActivity.java
index 6d39295..2d542af 100644
--- a/app/src/main/java/monnethic/mobile/homepage/LoginActivity.java
+++ b/app/src/main/java/monnethic/mobile/homepage/LoginActivity.java
@@ -17,6 +17,7 @@ import org.json.JSONObject;
import monnethic.mobile.restApi.Config;
import monnethic.mobile.restApi.HttpCallHandler;
import monnethic.mobile.user.UserAccountActivity;
+import monnethic.mobile.wallet.HomeWalletActivity;
public class LoginActivity extends AppCompatActivity {
private EditText email;
@@ -81,9 +82,12 @@ public class LoginActivity extends AppCompatActivity {
try{
if(result!=null){
if(result.getInt("status") == 200){
- Intent accountIntent = new Intent(LoginActivity.this, UserAccountActivity.class);
- accountIntent.putExtra("userHash", result.getString("userHash"));
- LoginActivity.this.startActivity(accountIntent);
+ //Intent accountIntent = new Intent(LoginActivity.this, UserAccountActivity.class);
+ Intent walletHomeIntent = new Intent(LoginActivity.this, HomeWalletActivity.class);
+ walletHomeIntent.putExtra("USER_HASH", result.getString("userHash"));
+ walletHomeIntent.putExtra("USER_PWD",password.getText().toString());
+ walletHomeIntent.putExtra("SESSION_ID","0");
+ LoginActivity.this.startActivity(walletHomeIntent);
finish();
}else{
Toast.makeText(mContext, result.getString("response"), Toast.LENGTH_SHORT).show();
diff --git a/app/src/main/java/monnethic/mobile/restApi/Config.java b/app/src/main/java/monnethic/mobile/restApi/Config.java
index 3a17cf7..89d3878 100644
--- a/app/src/main/java/monnethic/mobile/restApi/Config.java
+++ b/app/src/main/java/monnethic/mobile/restApi/Config.java
@@ -3,10 +3,10 @@ package monnethic.mobile.restApi;
public class Config {
//BASE
static private String BASE_URL = "http://10.0.2.2:10053/";
-
- //DATABASE
+ //static private String BASE_URL = "http://localhost:10053/";
static private String BASE_URL_USER = BASE_URL+"api/rest/user/";
static private String BASE_URL_TRANSACTION = BASE_URL+"api/rest/transaction/";
+ static private String BASE_URL_WALLET = BASE_URL+"api/rest/wallet/";
//USER
static public String USER_LOGIN = BASE_URL_USER+"login";
@@ -21,6 +21,14 @@ public class Config {
static public String TRANSACTION_RECEIVED = BASE_URL_TRANSACTION+"received";
static public String TRANSACTION_SAVE = BASE_URL_TRANSACTION+"save";
+ //WALLET
+ static public String WALLET_CREATE = BASE_URL_WALLET+"create";
+ static public String WALLET_GET_WALLET = BASE_URL_WALLET+"getWallet";
+ static public String WALLET_GET_USER_WALLETS = BASE_URL_WALLET+"getUserWallets";
+ static public String WALLET_DELETE = BASE_URL_WALLET+"delete";
+ static public String WALLET_TRANSFER = BASE_URL_WALLET+"transfer";
+
+
//BLOCKCHAIN
static private String BASE_URL_QUERY = BASE_URL+"/api/rest/query/";
diff --git a/app/src/main/java/monnethic/mobile/restApi/HttpCallHandler.java b/app/src/main/java/monnethic/mobile/restApi/HttpCallHandler.java
index d576d9d..61722d7 100644
--- a/app/src/main/java/monnethic/mobile/restApi/HttpCallHandler.java
+++ b/app/src/main/java/monnethic/mobile/restApi/HttpCallHandler.java
@@ -14,6 +14,36 @@ import monnethic.mobile.database.User;
public class HttpCallHandler {
+ public String getHttp(URL url) throws Exception {
+ InputStream inputStream;
+ BufferedReader bufferedReader = null;
+ HttpURLConnection urlConnection = null;
+
+ urlConnection = (HttpURLConnection) url.openConnection();
+ urlConnection.setRequestMethod("GET");
+ urlConnection.connect();
+
+ int responseCode = urlConnection.getResponseCode();
+ if(responseCode != 200){
+ throw new Exception("ERROR != 200");
+ }
+ inputStream = urlConnection.getInputStream();
+ if(inputStream == null){
+ throw new Exception("ERROR inputStream");
+ }
+
+ bufferedReader = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
+ StringBuilder stringBuilder = new StringBuilder();
+ String line;
+
+ while ((line = bufferedReader.readLine())!=null){
+ stringBuilder.append(line);
+ }
+
+ return stringBuilder.toString();
+ }
+
+
public String executeGetHttp(String urlParam, String[] params){
InputStream inputStream;
BufferedReader bufferedReader = null;
diff --git a/app/src/main/java/monnethic/mobile/restApi/WalletApiHandler.java b/app/src/main/java/monnethic/mobile/restApi/WalletApiHandler.java
new file mode 100644
index 0000000..af8bfb3
--- /dev/null
+++ b/app/src/main/java/monnethic/mobile/restApi/WalletApiHandler.java
@@ -0,0 +1,42 @@
+package monnethic.mobile.restApi;
+
+import org.json.JSONArray;
+import org.json.JSONObject;
+
+import java.net.URL;
+import java.util.ArrayList;
+
+import monnethic.mobile.wallet.Wallet;
+
+public class WalletApiHandler {
+
+ public ArrayList getUserWallets(String[] params){
+ ArrayList walletList = new ArrayList<>();
+ HttpCallHandler httpCallHandler = new HttpCallHandler();
+ try {
+ String url = Config.WALLET_GET_USER_WALLETS+"?userHash="+params[0];
+ String responseCall = httpCallHandler.getHttp(new URL(url));
+ JSONArray jsonArray = new JSONArray(responseCall);
+
+ for(int i=0; i userWallets;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_select_wallet);
+
+ ListView listView = (ListView) findViewById(R.id.listViewWallet);
+ Intent intent = getIntent();
+ String user_hash = intent.getStringExtra("USER_HASH");
+ String[] params = {user_hash};
+
+ Log.i("SelectWalletActivity", "user_hash : "+user_hash);
+ try {
+ userWallets = new getUserWalletTask().execute(params).get();
+ } catch (Exception e){
+ e.printStackTrace();
+ }
+
+ Log.i("SelectWalletActivity", "userWallets : "+userWallets);
+ ArrayAdapter adapter = new ArrayAdapter(this, R.layout.activity_select_wallet, userWallets);
+ listView.setAdapter(adapter);
+
+ //TODO
+ //ON CLICK ITEM
+ listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
+ @Override
+ public void onItemClick(AdapterView> adapterView, View view, int i, long l) {
+ Wallet w = (Wallet) listView.getItemAtPosition(i);
+ Toast.makeText(getBaseContext(),w.getType(),Toast.LENGTH_SHORT).show();
+ }
+ });
+ }
+
+ //AsyncTask for login
+ static private class getUserWalletTask extends AsyncTask> {
+ @Override
+ protected ArrayList doInBackground(String... params) {
+ ArrayList walletsList = new ArrayList<>();
+ try{
+ WalletApiHandler walletApiHandler = new WalletApiHandler();
+ walletsList = walletApiHandler.getUserWallets(params);
+ Log.i("SelectWalletActivity", "walletsList : "+walletsList);
+ }catch (Exception e){
+ e.printStackTrace();
+ }
+ Log.i("SelectWalletActivity", "BEFORE RETURN : walletsList : "+walletsList);
+ return walletsList;
+ }
+ }
+}
diff --git a/app/src/main/java/monnethic/mobile/wallet/Wallet.java b/app/src/main/java/monnethic/mobile/wallet/Wallet.java
new file mode 100644
index 0000000..65529ed
--- /dev/null
+++ b/app/src/main/java/monnethic/mobile/wallet/Wallet.java
@@ -0,0 +1,102 @@
+package monnethic.mobile.wallet;
+
+public class Wallet {
+ private int wallet_id;
+ private String wallet_hash;
+ private String user_hash;
+ private String type;
+ private Double balance;
+ private long creation_date;
+ private long modification_date;
+ private boolean is_active;
+
+ //Constructors
+ //Default constructor for ORMLite
+ public Wallet() {
+ }
+
+ public Wallet(String type,String user_hash){
+ this.type=type;
+ this.user_hash=user_hash;
+ }
+
+ public Wallet(String wallet_hash, String user_hash, String type, boolean isActive) {
+ this.wallet_hash = wallet_hash;
+ this.user_hash = user_hash;
+ this.type = type;
+ this.is_active = isActive;
+ }
+
+ public Wallet(String wallet_hash, String user_hash, String type, Double balance, boolean isActive) {
+ this.wallet_hash = wallet_hash;
+ this.user_hash = user_hash;
+ this.type = type;
+ this.balance = balance;
+ this.is_active = isActive;
+ }
+
+ public int getWallet_id() {
+ return wallet_id;
+ }
+
+ public void setWallet_id(int wallet_id) {
+ this.wallet_id = wallet_id;
+ }
+
+ public String getWallet_hash() {
+ return wallet_hash;
+ }
+ public void setWallet_hash(String wallet_hash) {
+ this.wallet_hash = wallet_hash;
+ }
+
+ public String getUser_hash() {
+ return user_hash;
+ }
+ public void setUser_hash(String user_hash) {
+ this.user_hash = user_hash;
+ }
+
+ public String getType() {
+ return type;
+ }
+ public void setType(String type) {
+ this.type = type;
+ }
+
+ public Double getBalance() {
+ return balance;
+ }
+ public void setBalance(Double balance) {
+ this.balance = balance;
+ }
+
+ public boolean is_active() {
+ return is_active;
+ }
+
+ public void setIs_active(boolean is_active) {
+ this.is_active = is_active;
+ }
+
+ public long getCreation_date() {
+ return creation_date;
+ }
+
+ public void setCreation_date(long creation_date) {
+ this.creation_date = creation_date;
+ }
+
+ public long getModification_date() {
+ return modification_date;
+ }
+
+ public void setModification_date(long modification_date) {
+ this.modification_date = modification_date;
+ }
+
+ @Override
+ public String toString() {
+ return "{wallet_hash:"+wallet_hash+",user_hash:"+user_hash+",type:"+type+",balance:"+balance+"}";
+ }
+}
diff --git a/app/src/main/res/layout/activity_create_wallet.xml b/app/src/main/res/layout/activity_create_wallet.xml
new file mode 100644
index 0000000..715e4ee
--- /dev/null
+++ b/app/src/main/res/layout/activity_create_wallet.xml
@@ -0,0 +1,60 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/app/src/main/res/layout/activity_home_wallet.xml b/app/src/main/res/layout/activity_home_wallet.xml
new file mode 100644
index 0000000..1cd0f37
--- /dev/null
+++ b/app/src/main/res/layout/activity_home_wallet.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
diff --git a/app/src/main/res/layout/activity_select_wallet.xml b/app/src/main/res/layout/activity_select_wallet.xml
new file mode 100644
index 0000000..4f5a2c8
--- /dev/null
+++ b/app/src/main/res/layout/activity_select_wallet.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+
+
diff --git a/app/src/main/res/menu/menu_select_wallet.xml b/app/src/main/res/menu/menu_select_wallet.xml
new file mode 100644
index 0000000..382b283
--- /dev/null
+++ b/app/src/main/res/menu/menu_select_wallet.xml
@@ -0,0 +1,10 @@
+
diff --git a/app/src/main/res/values/dimens.xml b/app/src/main/res/values/dimens.xml
index 47c8224..965aa37 100644
--- a/app/src/main/res/values/dimens.xml
+++ b/app/src/main/res/values/dimens.xml
@@ -2,4 +2,7 @@
16dp16dp
+ 180dp
+ 16dp
+ 16dp
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index a42cc49..1db11c1 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -14,4 +14,95 @@
"Contacts permissions are needed for providing email
completions."
+ SelectWalletActivity
+
+ "Material is the metaphor.\n\n"
+
+ "A material metaphor is the unifying theory of a rationalized space and a system of motion."
+ "The material is grounded in tactile reality, inspired by the study of paper and ink, yet "
+ "technologically advanced and open to imagination and magic.\n"
+ "Surfaces and edges of the material provide visual cues that are grounded in reality. The "
+ "use of familiar tactile attributes helps users quickly understand affordances. Yet the "
+ "flexibility of the material creates new affordances that supercede those in the physical "
+ "world, without breaking the rules of physics.\n"
+ "The fundamentals of light, surface, and movement are key to conveying how objects move, "
+ "interact, and exist in space and in relation to each other. Realistic lighting shows "
+ "seams, divides space, and indicates moving parts.\n\n"
+
+ "Bold, graphic, intentional.\n\n"
+
+ "The foundational elements of print based design typography, grids, space, scale, color, "
+ "and use of imagery guide visual treatments. These elements do far more than please the "
+ "eye. They create hierarchy, meaning, and focus. Deliberate color choices, edge to edge "
+ "imagery, large scale typography, and intentional white space create a bold and graphic "
+ "interface that immerse the user in the experience.\n"
+ "An emphasis on user actions makes core functionality immediately apparent and provides "
+ "waypoints for the user.\n\n"
+
+ "Motion provides meaning.\n\n"
+
+ "Motion respects and reinforces the user as the prime mover. Primary user actions are "
+ "inflection points that initiate motion, transforming the whole design.\n"
+ "All action takes place in a single environment. Objects are presented to the user without "
+ "breaking the continuity of experience even as they transform and reorganize.\n"
+ "Motion is meaningful and appropriate, serving to focus attention and maintain continuity. "
+ "Feedback is subtle yet clear. Transitions are efficient yet coherent.\n\n"
+
+ "3D world.\n\n"
+
+ "The material environment is a 3D space, which means all objects have x, y, and z "
+ "dimensions. The z-axis is perpendicularly aligned to the plane of the display, with the "
+ "positive z-axis extending towards the viewer. Every sheet of material occupies a single "
+ "position along the z-axis and has a standard 1dp thickness.\n"
+ "On the web, the z-axis is used for layering and not for perspective. The 3D world is "
+ "emulated by manipulating the y-axis.\n\n"
+
+ "Light and shadow.\n\n"
+
+ "Within the material environment, virtual lights illuminate the scene. Key lights create "
+ "directional shadows, while ambient light creates soft shadows from all angles.\n"
+ "Shadows in the material environment are cast by these two light sources. In Android "
+ "development, shadows occur when light sources are blocked by sheets of material at "
+ "various positions along the z-axis. On the web, shadows are depicted by manipulating the "
+ "y-axis only. The following example shows the card with a height of 6dp.\n\n"
+
+ "Resting elevation.\n\n"
+
+ "All material objects, regardless of size, have a resting elevation, or default elevation "
+ "that does not change. If an object changes elevation, it should return to its resting "
+ "elevation as soon as possible.\n\n"
+
+ "Component elevations.\n\n"
+
+ "The resting elevation for a component type is consistent across apps (e.g., FAB elevation "
+ "does not vary from 6dp in one app to 16dp in another app).\n"
+ "Components may have different resting elevations across platforms, depending on the depth "
+ "of the environment (e.g., TV has a greater depth than mobile or desktop).\n\n"
+
+ "Responsive elevation and dynamic elevation offsets.\n\n"
+
+ "Some component types have responsive elevation, meaning they change elevation in response "
+ "to user input (e.g., normal, focused, and pressed) or system events. These elevation "
+ "changes are consistently implemented using dynamic elevation offsets.\n"
+ "Dynamic elevation offsets are the goal elevation that a component moves towards, relative "
+ "to the component’s resting state. They ensure that elevation changes are consistent "
+ "across actions and component types. For example, all components that lift on press have "
+ "the same elevation change relative to their resting elevation.\n"
+ "Once the input event is completed or cancelled, the component will return to its resting "
+ "elevation.\n\n"
+
+ "Avoiding elevation interference.\n\n"
+
+ "Components with responsive elevations may encounter other components as they move between "
+ "their resting elevations and dynamic elevation offsets. Because material cannot pass "
+ "through other material, components avoid interfering with one another any number of ways, "
+ "whether on a per component basis or using the entire app layout.\n"
+ "On a component level, components can move or be removed before they cause interference. "
+ "For example, a floating action button (FAB) can disappear or move off screen before a "
+ "user picks up a card, or it can move if a snackbar appears.\n"
+ "On the layout level, design your app layout to minimize opportunities for interference. "
+ "For example, position the FAB to one side of stream of a cards so the FAB won’t interfere "
+ "when a user tries to pick up one of cards.\n\n"
+
+ Settings
diff --git a/app/src/main/res/values/styles.xml b/app/src/main/res/values/styles.xml
index 5e404d9..853f205 100644
--- a/app/src/main/res/values/styles.xml
+++ b/app/src/main/res/values/styles.xml
@@ -8,4 +8,8 @@
@color/colorAccent
+
+
+
+
diff --git a/app/src/test/java/monnethic/mobile/test/blockchainApi/walletTest.java b/app/src/test/java/monnethic/mobile/test/blockchainApi/walletTest.java
new file mode 100644
index 0000000..8834aba
--- /dev/null
+++ b/app/src/test/java/monnethic/mobile/test/blockchainApi/walletTest.java
@@ -0,0 +1,52 @@
+package monnethic.mobile.test.blockchainApi;
+
+import org.json.JSONArray;
+import org.json.JSONObject;
+import org.junit.Test;
+import java.net.URL;
+import java.util.ArrayList;
+
+import monnethic.mobile.restApi.Config;
+import monnethic.mobile.restApi.HttpCallHandler;
+import monnethic.mobile.wallet.Wallet;
+
+public class walletTest {
+
+ @Test
+ public void getUsersWallet(){
+ ArrayList walletList = new ArrayList<>();
+ try {
+ String url = Config.WALLET_GET_USER_WALLETS+"?userHash="+"$2a$10$GzyMhD3n05Z2lwCnoGi2dusjKrNAmHhtn5fw1xLpes5.cEV5T7lve";
+ System.out.println("call : "+url);
+ HttpCallHandler httpCallHandler = new HttpCallHandler();
+ String response = httpCallHandler.getHttp(new URL(url));
+
+ System.out.println("RESPONSE IS : "+response);
+
+ JSONArray jsonArray = new JSONArray(response);
+
+ for(int i=0; i