├── .gitignore
├── .idea
    ├── caches
    │   └── build_file_checksums.ser
    ├── codeStyles
    │   └── Project.xml
    ├── gradle.xml
    ├── misc.xml
    ├── runConfigurations.xml
    └── vcs.xml
├── README.md
├── app
    ├── .gitignore
    ├── build.gradle
    ├── proguard-rules.pro
    └── src
    │   ├── androidTest
    │       └── java
    │       │   └── com
    │       │       └── et
    │       │           └── web3j
    │       │               └── web3jdemo
    │       │                   └── ExampleInstrumentedTest.java
    │   ├── main
    │       ├── AndroidManifest.xml
    │       ├── java
    │       │   └── com
    │       │   │   └── et
    │       │   │       └── web3j
    │       │   │           ├── MainActivity.java
    │       │   │           └── util
    │       │   │               └── SecureRandomUtils.java
    │       └── res
    │       │   ├── drawable-v24
    │       │       └── ic_launcher_foreground.xml
    │       │   ├── drawable
    │       │       └── ic_launcher_background.xml
    │       │   ├── layout
    │       │       └── activity_main.xml
    │       │   ├── mipmap-anydpi-v26
    │       │       ├── ic_launcher.xml
    │       │       └── ic_launcher_round.xml
    │       │   ├── mipmap-hdpi
    │       │       ├── ic_launcher.png
    │       │       └── ic_launcher_round.png
    │       │   ├── mipmap-mdpi
    │       │       ├── ic_launcher.png
    │       │       └── ic_launcher_round.png
    │       │   ├── mipmap-xhdpi
    │       │       ├── ic_launcher.png
    │       │       └── ic_launcher_round.png
    │       │   ├── mipmap-xxhdpi
    │       │       ├── ic_launcher.png
    │       │       └── ic_launcher_round.png
    │       │   ├── mipmap-xxxhdpi
    │       │       ├── ic_launcher.png
    │       │       └── ic_launcher_round.png
    │       │   └── values
    │       │       ├── colors.xml
    │       │       ├── strings.xml
    │       │       └── styles.xml
    │   └── test
    │       └── java
    │           └── com
    │               └── et
    │                   └── web3j
    │                       └── web3jdemo
    │                           └── ExampleUnitTest.java
├── build.gradle
├── gradle.properties
├── gradle
    └── wrapper
    │   ├── gradle-wrapper.jar
    │   └── gradle-wrapper.properties
├── gradlew
├── gradlew.bat
└── settings.gradle
/.gitignore:
--------------------------------------------------------------------------------
 1 | *.iml
 2 | .gradle
 3 | /local.properties
 4 | /.idea/libraries
 5 | /.idea/modules.xml
 6 | /.idea/workspace.xml
 7 | .DS_Store
 8 | /build
 9 | /captures
10 | .externalNativeBuild
11 | 
--------------------------------------------------------------------------------
/.idea/caches/build_file_checksums.ser:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/.idea/caches/build_file_checksums.ser
--------------------------------------------------------------------------------
/.idea/codeStyles/Project.xml:
--------------------------------------------------------------------------------
 1 | 
 2 |   
 3 |     
 4 |       
 5 |         
 6 |         
 7 |         
 8 |         
 9 |         
10 |         
11 |         
12 |         
13 |         
14 |       
15 |       
16 |         
17 |         
18 |         
19 |         
20 |         
21 |         
22 |       
23 |       
24 |         
25 |         
26 |       
27 |     
28 |   
29 | 
--------------------------------------------------------------------------------
/.idea/gradle.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |   
 4 |     
17 |   
18 | 
--------------------------------------------------------------------------------
/.idea/misc.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |   
 4 |     
 5 |     
 6 |     
 7 |       
 8 |         
 9 |           10 |
11 |
12 |
13 |
14 |
15 |       
16 |     
17 |     
18 |       
19 |
20 |           21 |
22 |
23 |
24 |
25 |       
26 |     
27 |   
28 |   
29 |     
30 |   
31 |   
32 |     
33 |   
34 | 
--------------------------------------------------------------------------------
/.idea/runConfigurations.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |   
 4 |     
 5 |       
 6 |         
 7 |         
 8 |         
 9 |       
10 |     
11 |   
12 | 
--------------------------------------------------------------------------------
/.idea/vcs.xml:
--------------------------------------------------------------------------------
1 | 
2 | 
3 |   
4 |     
5 |   
6 | 
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
 1 | # Web3j-demo
 2 | (ETH Wallet)This is a demo for testing web3j and how to create HD-Wallet with Mnemonic((以太坊钱包)本demo使用web3j和bitcoinj创建包含助记词的钱包,支持助记词钱包导入).
 3 | You can telk to me some functions that you want to achieve or anything you think about, Thinking is without boundaries.兄die
 4 | 
 5 | 通用的以太坊基于bip44协议的助记词路径(有三种取回路径,默认使用第一种)
 6 | 
 7 | * "m/44'/60'/0'/0/0";
 8 | * "m/44'/60'/0'/0";
 9 | * "m/44'/60'/1'/0/0";
10 | 
11 | demo: 
12 | 
13 | https://play.google.com/store/apps/details?id=com.et.ewallet
14 | 
15 | https://www.coolapk.com/apk/199976
16 | 
--------------------------------------------------------------------------------
/app/.gitignore:
--------------------------------------------------------------------------------
1 | /build
2 | 
--------------------------------------------------------------------------------
/app/build.gradle:
--------------------------------------------------------------------------------
 1 | apply plugin: 'com.android.application'
 2 | 
 3 | android {
 4 |     compileSdkVersion 28
 5 |     defaultConfig {
 6 |         applicationId "com.et.web3j.web3jdemo"
 7 |         minSdkVersion 15
 8 |         targetSdkVersion 28
 9 |         versionCode 1
10 |         versionName "1.0"
11 |         testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
12 |         multiDexEnabled true
13 |     }
14 |     buildTypes {
15 |         release {
16 |             minifyEnabled false
17 |             proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
18 |         }
19 |     }
20 | }
21 | 
22 | dependencies {
23 |     implementation fileTree(dir: 'libs', include: ['*.jar'])
24 |     implementation 'com.android.support:appcompat-v7:28.0.0-alpha3'
25 |     implementation 'com.android.support.constraint:constraint-layout:1.1.2'
26 |     testImplementation 'junit:junit:4.12'
27 |     androidTestImplementation 'com.android.support.test:runner:1.0.2'
28 |     androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
29 | 
30 |     implementation'org.bitcoinj:bitcoinj-core:0.14.3'
31 |     implementation 'org.web3j:crypto:3.3.1-android'
32 |     implementation 'com.orhanobut:logger:2.1.1'
33 |     implementation 'com.github.zzz40500:android-shapeLoadingView:1.0.3.2'
34 | }
35 | 
--------------------------------------------------------------------------------
/app/proguard-rules.pro:
--------------------------------------------------------------------------------
 1 | # Add project specific ProGuard rules here.
 2 | # You can control the set of applied configuration files using the
 3 | # proguardFiles setting in build.gradle.
 4 | #
 5 | # For more details, see
 6 | #   http://developer.android.com/guide/developing/tools/proguard.html
 7 | 
 8 | # If your project uses WebView with JS, uncomment the following
 9 | # and specify the fully qualified class name to the JavaScript interface
10 | # class:
11 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12 | #   public *;
13 | #}
14 | 
15 | # Uncomment this to preserve the line number information for
16 | # debugging stack traces.
17 | #-keepattributes SourceFile,LineNumberTable
18 | 
19 | # If you keep the line number information, uncomment this to
20 | # hide the original source file name.
21 | #-renamesourcefileattribute SourceFile
22 | 
--------------------------------------------------------------------------------
/app/src/androidTest/java/com/et/web3j/web3jdemo/ExampleInstrumentedTest.java:
--------------------------------------------------------------------------------
 1 | package com.et.web3j.web3jdemo;
 2 | 
 3 | import android.content.Context;
 4 | import android.support.test.InstrumentationRegistry;
 5 | import android.support.test.runner.AndroidJUnit4;
 6 | 
 7 | import org.junit.Test;
 8 | import org.junit.runner.RunWith;
 9 | 
10 | import static org.junit.Assert.*;
11 | 
12 | /**
13 |  * Instrumented test, which will execute on an Android device.
14 |  *
15 |  * @see Testing documentation
16 |  */
17 | @RunWith(AndroidJUnit4.class)
18 | public class ExampleInstrumentedTest {
19 |     @Test
20 |     public void useAppContext() {
21 |         // Context of the app under test.
22 |         Context appContext = InstrumentationRegistry.getTargetContext();
23 | 
24 |         assertEquals("com.et.web3j.web3jdemo", appContext.getPackageName());
25 |     }
26 | }
27 | 
--------------------------------------------------------------------------------
/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 4 | 
 5 |     
 6 |     
 7 | 
 8 |     
15 |         
16 |             
17 |                 
18 | 
19 |                 
20 |             
21 |         
22 |     
23 | 
24 | 
--------------------------------------------------------------------------------
/app/src/main/java/com/et/web3j/MainActivity.java:
--------------------------------------------------------------------------------
  1 | package com.et.web3j;
  2 | 
  3 | import android.Manifest;
  4 | import android.content.pm.PackageManager;
  5 | import android.os.Build;
  6 | import android.os.Handler;
  7 | import android.support.annotation.RequiresApi;
  8 | import android.support.v4.content.ContextCompat;
  9 | import android.support.v7.app.AppCompatActivity;
 10 | import android.os.Bundle;
 11 | import android.view.View;
 12 | import android.widget.Button;
 13 | import android.widget.EditText;
 14 | import android.widget.TextView;
 15 | import android.widget.Toast;
 16 | 
 17 | import com.et.web3j.util.SecureRandomUtils;
 18 | import com.et.web3j.web3jdemo.R;
 19 | import com.mingle.widget.LoadingView;
 20 | import com.orhanobut.logger.AndroidLogAdapter;
 21 | import com.orhanobut.logger.Logger;
 22 | 
 23 | import org.bitcoinj.crypto.ChildNumber;
 24 | import org.bitcoinj.crypto.DeterministicKey;
 25 | import org.bitcoinj.crypto.HDKeyDerivation;
 26 | import org.bitcoinj.wallet.DeterministicSeed;
 27 | import org.web3j.crypto.CipherException;
 28 | import org.web3j.crypto.Credentials;
 29 | import org.web3j.crypto.ECKeyPair;
 30 | import org.web3j.crypto.Keys;
 31 | import org.web3j.crypto.Wallet;
 32 | import org.web3j.crypto.WalletFile;
 33 | import org.web3j.crypto.WalletUtils;
 34 | import org.web3j.utils.Numeric;
 35 | 
 36 | import java.security.SecureRandom;
 37 | import java.util.Arrays;
 38 | import java.util.List;
 39 | 
 40 | public class MainActivity extends AppCompatActivity {
 41 | 
 42 |     private Button btCreate, btImport, btCleanData;
 43 |     private EditText etMnemonic;
 44 |     private TextView tvResult;
 45 |     private LoadingView loadingView;
 46 | 
 47 |     private final String password = "test1011";
 48 |     /**
 49 |      * 通用的以太坊基于bip44协议的助记词路径 (imtoken jaxx Metamask myetherwallet)
 50 |      */
 51 |     public static String ETH_JAXX_TYPE = "m/44'/60'/0'/0/0";
 52 |     public static String ETH_LEDGER_TYPE = "m/44'/60'/0'/0";
 53 |     public static String ETH_CUSTOM_TYPE = "m/44'/60'/1'/0/0";
 54 | 
 55 |     /**
 56 |      * 随机
 57 |      */
 58 |     private static final SecureRandom secureRandom = SecureRandomUtils.secureRandom();
 59 | 
 60 |     public static final int REQUEST_CODE_EXTERNAL = 1;
 61 | 
 62 |     @RequiresApi(api = Build.VERSION_CODES.M)
 63 |     @Override
 64 |     protected void onCreate(Bundle savedInstanceState) {
 65 |         super.onCreate(savedInstanceState);
 66 |         setContentView(R.layout.activity_main);
 67 |         initView();
 68 |         initPermission();
 69 |     }
 70 | 
 71 |     /**
 72 |      * check the permission
 73 |      */
 74 |     @RequiresApi(api = Build.VERSION_CODES.M)
 75 |     private void initPermission() {
 76 |         Logger.addLogAdapter(new AndroidLogAdapter() {
 77 |             @Override
 78 |             public boolean isLoggable(int priority, String tag) {
 79 |                 return true;
 80 |             }
 81 |         });
 82 | 
 83 |         if(!(ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED)) {
 84 |             requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, REQUEST_CODE_EXTERNAL);
 85 |         }
 86 |     }
 87 | 
 88 |     /**
 89 |      * get the result from user action
 90 |      * @param requestCode
 91 |      * @param permissions
 92 |      * @param grantResults
 93 |      */
 94 |     @Override
 95 |     public void onRequestPermissionsResult(int requestCode, @android.support.annotation.NonNull String[] permissions, @android.support.annotation.NonNull int[] grantResults) {
 96 |         super.onRequestPermissionsResult(requestCode, permissions, grantResults);
 97 |         switch (requestCode) {
 98 |             case REQUEST_CODE_EXTERNAL:
 99 |                 if (!(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED)) {    // 权限申请成功
100 |                     Toast.makeText(MainActivity.this, "Write storage permissions are required", Toast.LENGTH_SHORT).show();
101 |                     new Handler().postDelayed(new Runnable() {
102 |                         @Override
103 |                         public void run() {
104 |                             finish();
105 |                         }
106 |                     }, 1000);
107 |                 }
108 |                 break;
109 |         }
110 |     }
111 | 
112 |     private void initView() {
113 |         btCreate = findViewById(R.id.bt_create);
114 |         btImport = findViewById(R.id.bt_import);
115 |         etMnemonic = findViewById(R.id.et_mnemonic);
116 |         tvResult = findViewById(R.id.tv_result);
117 |         btCleanData = findViewById(R.id.bt_clean_data);
118 |         loadingView = findViewById(R.id.loadView);
119 | 
120 |         btCreate.setOnClickListener(new View.OnClickListener() {
121 |             @Override
122 |             public void onClick(View view) {
123 |                 new Thread(new Runnable() {
124 |                     @Override
125 |                     public void run() {
126 |                         String[] pathArray = ETH_JAXX_TYPE.split("/");
127 |                         String passphrase = "";
128 |                         long creationTimeSeconds = System.currentTimeMillis() / 1000;
129 |                         DeterministicSeed ds = new DeterministicSeed(secureRandom, 128, passphrase, creationTimeSeconds);
130 |                         createWallet(ds, pathArray);
131 |                     }
132 |                 }).start();
133 | 
134 |             }
135 |         });
136 | 
137 |         btImport.setOnClickListener(new View.OnClickListener() {
138 |             @Override
139 |             public void onClick(View view) {
140 |                 final String data = etMnemonic.getText().toString().trim();
141 |                 if (!data.equals("")) {
142 |                     new Thread(new Runnable() {
143 |                         @Override
144 |                         public void run() {
145 |                             importWallet(data);
146 |                         }
147 |                     }).start();
148 |                     etMnemonic.setText("");
149 |                 } else {
150 |                     Toast.makeText(MainActivity.this, "pls input mnemonic", Toast.LENGTH_SHORT).show();
151 |                 }
152 |             }
153 |         });
154 | 
155 |         btCleanData.setOnClickListener(new View.OnClickListener() {
156 |             @Override
157 |             public void onClick(View view) {
158 |                 tvResult.setText("");
159 |             }
160 |         });
161 |     }
162 | 
163 |     /**
164 |      * import mnemonic wallet
165 |      * @param mnemonic
166 |      */
167 |     private void importWallet(String mnemonic) {
168 |         String[] pathArray = ETH_JAXX_TYPE.split("/");
169 |         if (pathArray.length <= 1) {
170 |             //内容不对
171 |             return ;
172 |         }
173 |         String passphrase = "";
174 |         long creationTimeSeconds = System.currentTimeMillis() / 1000;
175 |         DeterministicSeed ds = new DeterministicSeed(Arrays.asList(mnemonic.split(" ")), null, passphrase, creationTimeSeconds);
176 |         createWallet(ds, pathArray);
177 |     }
178 | 
179 |     /**
180 |      * create wallet
181 |      */
182 |     private void createWallet(DeterministicSeed ds, String[] pathArray) {
183 |         runOnUiThread(new Runnable() {
184 |             @Override
185 |             public void run() {
186 |                 tvResult.setVisibility(View.GONE);
187 |                 loadingView.setVisibility(View.VISIBLE);
188 |             }
189 |         });
190 | 
191 |         byte[] seedBytes = ds.getSeedBytes();
192 |         List mnemonicCode = ds.getMnemonicCode();
193 | 
194 |         DeterministicKey masterPrivateKey = HDKeyDerivation.createMasterPrivateKey(seedBytes);
195 | 
196 |         for (int i = 1; i < pathArray.length; i++) {
197 |             ChildNumber childNumber;
198 |             if (pathArray[i].endsWith("'")) {
199 |                 int number = Integer.parseInt(pathArray[i].substring(0, pathArray[i].length() - 1));
200 |                 childNumber = new ChildNumber(number, true);
201 |             } else {
202 |                 int number = Integer.parseInt(pathArray[i]);
203 |                 childNumber = new ChildNumber(number, false);
204 |             }
205 | 
206 |             masterPrivateKey = HDKeyDerivation.deriveChildKey(masterPrivateKey, childNumber);
207 |         }
208 | 
209 |         ECKeyPair ecKeyPair = ECKeyPair.create(masterPrivateKey.getPrivKeyBytes());
210 |         WalletFile walletFile;
211 |         try {
212 |             walletFile = Wallet.create(password, ecKeyPair, 1024, 1);
213 | 
214 |             String address = Numeric.prependHexPrefix(Keys.getAddress(ecKeyPair));
215 |             String mnemonic = convertMnemonicList(mnemonicCode);
216 |             Logger.d("Et Mnemonic : " + mnemonic);
217 |             Logger.d("Et Address : " + address);
218 |             final StringBuilder builder = new StringBuilder();
219 |             builder.append("Et Mnemonic : " + mnemonic + "\n");
220 |             builder.append("Et Address : " + address + "\n" + "\n");
221 |             runOnUiThread(new Runnable() {
222 |                 @Override
223 |                 public void run() {
224 |                     tvResult.setVisibility(View.VISIBLE);
225 |                     loadingView.setVisibility(View.GONE);
226 |                     tvResult.setText(builder.toString());
227 |                 }
228 |             });
229 | 
230 |         } catch (CipherException e) {
231 |             e.printStackTrace();
232 |         }
233 |     }
234 | 
235 |     /**
236 |      * covert mnemonic string to List
237 |      * @param mnemonics
238 |      * @return
239 |      */
240 |     private static String convertMnemonicList(List mnemonics) {
241 |         StringBuilder sb = new StringBuilder();
242 |         for (String mnemonic : mnemonics
243 |                 ) {
244 |             sb.append(mnemonic);
245 |             sb.append(" ");
246 |         }
247 |         return sb.toString();
248 |     }
249 | }
250 | 
--------------------------------------------------------------------------------
/app/src/main/java/com/et/web3j/util/SecureRandomUtils.java:
--------------------------------------------------------------------------------
 1 | package com.et.web3j.util;
 2 | 
 3 | import org.web3j.crypto.LinuxSecureRandom;
 4 | 
 5 | import java.security.SecureRandom;
 6 | 
 7 | /**
 8 |  * Created by Et on 2018/7/23 09:16
 9 |  * email:x313371005@126.com
10 |  */
11 | public class SecureRandomUtils {
12 | 
13 |     private static final SecureRandom SECURE_RANDOM;
14 | 
15 |     static {
16 |         if (isAndroidRuntime()) {
17 |             new LinuxSecureRandom();
18 |         }
19 |         SECURE_RANDOM = new SecureRandom();
20 |     }
21 | 
22 |     public static SecureRandom secureRandom() {
23 |         return SECURE_RANDOM;
24 |     }
25 | 
26 |     // Taken from BitcoinJ implementation
27 |     // https://github.com/bitcoinj/bitcoinj/blob/3cb1f6c6c589f84fe6e1fb56bf26d94cccc85429/core/src/main/java/org/bitcoinj/core/Utils.java#L573
28 |     private static int isAndroid = -1;
29 | 
30 |     static boolean isAndroidRuntime() {
31 |         if (isAndroid == -1) {
32 |             final String runtime = System.getProperty("java.runtime.name");
33 |             isAndroid = (runtime != null && runtime.equals("Android Runtime")) ? 1 : 0;
34 |         }
35 |         return isAndroid == 1;
36 |     }
37 | 
38 |     private SecureRandomUtils() { }
39 | 
40 | }
41 | 
--------------------------------------------------------------------------------
/app/src/main/res/drawable-v24/ic_launcher_foreground.xml:
--------------------------------------------------------------------------------
 1 | 
 7 |     
12 |         
13 |             
19 |22 |
25 |             
26 |         
27 |     
28 |     
34 | 
35 | 
--------------------------------------------------------------------------------
/app/src/main/res/drawable/ic_launcher_background.xml:
--------------------------------------------------------------------------------
  1 | 
  2 | 
  7 |     
 10 |     
 15 |     
 20 |     
 25 |     
 30 |     
 35 |     
 40 |     
 45 |     
 50 |     
 55 |     
 60 |     
 65 |     
 70 |     
 75 |     
 80 |     
 85 |     
 90 |     
 95 |     
100 |     
105 |     
110 |     
115 |     
120 |     
125 |     
130 |     
135 |     
140 |     
145 |     
150 |     
155 |     
160 |     
165 |     
170 | 
171 | 
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_main.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
10 | 
11 | 
12 |     
18 | 
19 |     
25 |     
29 |         
35 | 
36 |     
37 |     
40 |         
48 |         
53 |     
54 | 
55 |     
61 | 
62 | 
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml:
--------------------------------------------------------------------------------
1 | 
2 | 
3 |     
4 |     
5 | 
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml:
--------------------------------------------------------------------------------
1 | 
2 | 
3 |     
4 |     
5 | 
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/values/colors.xml:
--------------------------------------------------------------------------------
1 | 
2 | 
3 |     #3F51B5
4 |     #303F9F
5 |     #FF4081
6 | 
7 | 
--------------------------------------------------------------------------------
/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 | 
2 |     Web3j Demo
3 | 
4 | 
--------------------------------------------------------------------------------
/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |     
 4 |     
10 | 
11 | 
12 | 
--------------------------------------------------------------------------------
/app/src/test/java/com/et/web3j/web3jdemo/ExampleUnitTest.java:
--------------------------------------------------------------------------------
 1 | package com.et.web3j.web3jdemo;
 2 | 
 3 | import org.junit.Test;
 4 | 
 5 | import static org.junit.Assert.*;
 6 | 
 7 | /**
 8 |  * Example local unit test, which will execute on the development machine (host).
 9 |  *
10 |  * @see Testing documentation
11 |  */
12 | public class ExampleUnitTest {
13 |     @Test
14 |     public void addition_isCorrect() {
15 |         assertEquals(4, 2 + 2);
16 |     }
17 | }
--------------------------------------------------------------------------------
/build.gradle:
--------------------------------------------------------------------------------
 1 | // Top-level build file where you can add configuration options common to all sub-projects/modules.
 2 | 
 3 | buildscript {
 4 |     
 5 |     repositories {
 6 |         google()
 7 |         jcenter()
 8 |     }
 9 |     dependencies {
10 |         classpath 'com.android.tools.build:gradle:3.1.3'
11 |         
12 | 
13 |         // NOTE: Do not place your application dependencies here; they belong
14 |         // in the individual module build.gradle files
15 |     }
16 | }
17 | 
18 | allprojects {
19 |     repositories {
20 |         google()
21 |         jcenter()
22 |         maven {
23 |             url "https://jitpack.io"
24 |         }
25 |     }
26 | }
27 | 
28 | task clean(type: Delete) {
29 |     delete rootProject.buildDir
30 | }
31 | 
--------------------------------------------------------------------------------
/gradle.properties:
--------------------------------------------------------------------------------
 1 | # Project-wide Gradle settings.
 2 | # IDE (e.g. Android Studio) users:
 3 | # Gradle settings configured through the IDE *will override*
 4 | # any settings specified in this file.
 5 | # For more details on how to configure your build environment visit
 6 | # http://www.gradle.org/docs/current/userguide/build_environment.html
 7 | # Specifies the JVM arguments used for the daemon process.
 8 | # The setting is particularly useful for tweaking memory settings.
 9 | org.gradle.jvmargs=-Xmx1536m
10 | # When configured, Gradle will run in incubating parallel mode.
11 | # This option should only be used with decoupled projects. More details, visit
12 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
13 | # org.gradle.parallel=true
14 | 
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AndrosEt/Web3j-demo/5ca7b1e91c60a128973d20ecdc7453790100d333/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | #Mon Jul 23 15:26:28 CST 2018
2 | distributionBase=GRADLE_USER_HOME
3 | distributionPath=wrapper/dists
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 | distributionUrl=https\://services.gradle.org/distributions/gradle-4.4-all.zip
7 | 
--------------------------------------------------------------------------------
/gradlew:
--------------------------------------------------------------------------------
  1 | #!/usr/bin/env sh
  2 | 
  3 | ##############################################################################
  4 | ##
  5 | ##  Gradle start up script for UN*X
  6 | ##
  7 | ##############################################################################
  8 | 
  9 | # Attempt to set APP_HOME
 10 | # Resolve links: $0 may be a link
 11 | PRG="$0"
 12 | # Need this for relative symlinks.
 13 | while [ -h "$PRG" ] ; do
 14 |     ls=`ls -ld "$PRG"`
 15 |     link=`expr "$ls" : '.*-> \(.*\)$'`
 16 |     if expr "$link" : '/.*' > /dev/null; then
 17 |         PRG="$link"
 18 |     else
 19 |         PRG=`dirname "$PRG"`"/$link"
 20 |     fi
 21 | done
 22 | SAVED="`pwd`"
 23 | cd "`dirname \"$PRG\"`/" >/dev/null
 24 | APP_HOME="`pwd -P`"
 25 | cd "$SAVED" >/dev/null
 26 | 
 27 | APP_NAME="Gradle"
 28 | APP_BASE_NAME=`basename "$0"`
 29 | 
 30 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
 31 | DEFAULT_JVM_OPTS=""
 32 | 
 33 | # Use the maximum available, or set MAX_FD != -1 to use that value.
 34 | MAX_FD="maximum"
 35 | 
 36 | warn () {
 37 |     echo "$*"
 38 | }
 39 | 
 40 | die () {
 41 |     echo
 42 |     echo "$*"
 43 |     echo
 44 |     exit 1
 45 | }
 46 | 
 47 | # OS specific support (must be 'true' or 'false').
 48 | cygwin=false
 49 | msys=false
 50 | darwin=false
 51 | nonstop=false
 52 | case "`uname`" in
 53 |   CYGWIN* )
 54 |     cygwin=true
 55 |     ;;
 56 |   Darwin* )
 57 |     darwin=true
 58 |     ;;
 59 |   MINGW* )
 60 |     msys=true
 61 |     ;;
 62 |   NONSTOP* )
 63 |     nonstop=true
 64 |     ;;
 65 | esac
 66 | 
 67 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
 68 | 
 69 | # Determine the Java command to use to start the JVM.
 70 | if [ -n "$JAVA_HOME" ] ; then
 71 |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
 72 |         # IBM's JDK on AIX uses strange locations for the executables
 73 |         JAVACMD="$JAVA_HOME/jre/sh/java"
 74 |     else
 75 |         JAVACMD="$JAVA_HOME/bin/java"
 76 |     fi
 77 |     if [ ! -x "$JAVACMD" ] ; then
 78 |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
 79 | 
 80 | Please set the JAVA_HOME variable in your environment to match the
 81 | location of your Java installation."
 82 |     fi
 83 | else
 84 |     JAVACMD="java"
 85 |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
 86 | 
 87 | Please set the JAVA_HOME variable in your environment to match the
 88 | location of your Java installation."
 89 | fi
 90 | 
 91 | # Increase the maximum file descriptors if we can.
 92 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
 93 |     MAX_FD_LIMIT=`ulimit -H -n`
 94 |     if [ $? -eq 0 ] ; then
 95 |         if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
 96 |             MAX_FD="$MAX_FD_LIMIT"
 97 |         fi
 98 |         ulimit -n $MAX_FD
 99 |         if [ $? -ne 0 ] ; then
100 |             warn "Could not set maximum file descriptor limit: $MAX_FD"
101 |         fi
102 |     else
103 |         warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
104 |     fi
105 | fi
106 | 
107 | # For Darwin, add options to specify how the application appears in the dock
108 | if $darwin; then
109 |     GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
110 | fi
111 | 
112 | # For Cygwin, switch paths to Windows format before running java
113 | if $cygwin ; then
114 |     APP_HOME=`cygpath --path --mixed "$APP_HOME"`
115 |     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
116 |     JAVACMD=`cygpath --unix "$JAVACMD"`
117 | 
118 |     # We build the pattern for arguments to be converted via cygpath
119 |     ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
120 |     SEP=""
121 |     for dir in $ROOTDIRSRAW ; do
122 |         ROOTDIRS="$ROOTDIRS$SEP$dir"
123 |         SEP="|"
124 |     done
125 |     OURCYGPATTERN="(^($ROOTDIRS))"
126 |     # Add a user-defined pattern to the cygpath arguments
127 |     if [ "$GRADLE_CYGPATTERN" != "" ] ; then
128 |         OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
129 |     fi
130 |     # Now convert the arguments - kludge to limit ourselves to /bin/sh
131 |     i=0
132 |     for arg in "$@" ; do
133 |         CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
134 |         CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option
135 | 
136 |         if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition
137 |             eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
138 |         else
139 |             eval `echo args$i`="\"$arg\""
140 |         fi
141 |         i=$((i+1))
142 |     done
143 |     case $i in
144 |         (0) set -- ;;
145 |         (1) set -- "$args0" ;;
146 |         (2) set -- "$args0" "$args1" ;;
147 |         (3) set -- "$args0" "$args1" "$args2" ;;
148 |         (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
149 |         (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
150 |         (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
151 |         (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
152 |         (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
153 |         (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
154 |     esac
155 | fi
156 | 
157 | # Escape application args
158 | save () {
159 |     for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
160 |     echo " "
161 | }
162 | APP_ARGS=$(save "$@")
163 | 
164 | # Collect all arguments for the java command, following the shell quoting and substitution rules
165 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
166 | 
167 | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
168 | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
169 |   cd "$(dirname "$0")"
170 | fi
171 | 
172 | exec "$JAVACMD" "$@"
173 | 
--------------------------------------------------------------------------------
/gradlew.bat:
--------------------------------------------------------------------------------
 1 | @if "%DEBUG%" == "" @echo off
 2 | @rem ##########################################################################
 3 | @rem
 4 | @rem  Gradle startup script for Windows
 5 | @rem
 6 | @rem ##########################################################################
 7 | 
 8 | @rem Set local scope for the variables with windows NT shell
 9 | if "%OS%"=="Windows_NT" setlocal
10 | 
11 | set DIRNAME=%~dp0
12 | if "%DIRNAME%" == "" set DIRNAME=.
13 | set APP_BASE_NAME=%~n0
14 | set APP_HOME=%DIRNAME%
15 | 
16 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
17 | set DEFAULT_JVM_OPTS=
18 | 
19 | @rem Find java.exe
20 | if defined JAVA_HOME goto findJavaFromJavaHome
21 | 
22 | set JAVA_EXE=java.exe
23 | %JAVA_EXE% -version >NUL 2>&1
24 | if "%ERRORLEVEL%" == "0" goto init
25 | 
26 | echo.
27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
28 | echo.
29 | echo Please set the JAVA_HOME variable in your environment to match the
30 | echo location of your Java installation.
31 | 
32 | goto fail
33 | 
34 | :findJavaFromJavaHome
35 | set JAVA_HOME=%JAVA_HOME:"=%
36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
37 | 
38 | if exist "%JAVA_EXE%" goto init
39 | 
40 | echo.
41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
42 | echo.
43 | echo Please set the JAVA_HOME variable in your environment to match the
44 | echo location of your Java installation.
45 | 
46 | goto fail
47 | 
48 | :init
49 | @rem Get command-line arguments, handling Windows variants
50 | 
51 | if not "%OS%" == "Windows_NT" goto win9xME_args
52 | 
53 | :win9xME_args
54 | @rem Slurp the command line arguments.
55 | set CMD_LINE_ARGS=
56 | set _SKIP=2
57 | 
58 | :win9xME_args_slurp
59 | if "x%~1" == "x" goto execute
60 | 
61 | set CMD_LINE_ARGS=%*
62 | 
63 | :execute
64 | @rem Setup the command line
65 | 
66 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
67 | 
68 | @rem Execute Gradle
69 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
70 | 
71 | :end
72 | @rem End local scope for the variables with windows NT shell
73 | if "%ERRORLEVEL%"=="0" goto mainEnd
74 | 
75 | :fail
76 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
77 | rem the _cmd.exe /c_ return code!
78 | if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
79 | exit /b 1
80 | 
81 | :mainEnd
82 | if "%OS%"=="Windows_NT" endlocal
83 | 
84 | :omega
85 | 
--------------------------------------------------------------------------------
/settings.gradle:
--------------------------------------------------------------------------------
1 | include ':app'
2 | 
--------------------------------------------------------------------------------