반응형

이번 포스팅에서는 키스토어의 계정을 연동해서 keystore를 이용해서 이더를 송금하는 실습을 진행해보겠습니다.

keystore를 최신으로 업데이트하여야합니다. 우선 전체 코드입니다. 

package com.example.samsungblockchainsdk;
import androidx.appcompat.app.AppCompatActivity;
import com.samsung.android.sdk.blockchain.account.Account;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.Toast;
import com.samsung.android.sdk.blockchain.CoinType;
import com.samsung.android.sdk.blockchain.ListenableFutureTask;
import com.samsung.android.sdk.blockchain.SBlockchain;
import com.samsung.android.sdk.blockchain.account.ethereum.EthereumAccount;
import com.samsung.android.sdk.blockchain.coinservice.CoinNetworkInfo;
import com.samsung.android.sdk.blockchain.coinservice.CoinServiceFactory;
import com.samsung.android.sdk.blockchain.coinservice.ethereum.EthereumService;
import com.samsung.android.sdk.blockchain.exception.HardwareWalletException;
import com.samsung.android.sdk.blockchain.exception.RootSeedChangedException;
import com.samsung.android.sdk.blockchain.network.EthereumNetworkType;
import com.samsung.android.sdk.blockchain.ui.CucumberWebView;
import com.samsung.android.sdk.blockchain.ui.OnSendTransactionListener;
import com.samsung.android.sdk.blockchain.wallet.HardwareWallet;
import com.samsung.android.sdk.blockchain.wallet.HardwareWalletType;

import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

import java.math.BigInteger;
import java.util.Arrays;
import java.util.List;
import java.util.concurrent.ExecutionException;

public class Main2Activity extends AppCompatActivity implements OnSendTransactionListener {
    Button connect;
    Button generateAccount;
    Button getAccounts;
    Button paymentsheet;
  //  Button sendSmartContract;
    // 웹뷰버튼
    Button webViewInitBtn;


    private SBlockchain sBlockchain ;
    private HardwareWallet wallet;
    private CucumberWebView webView; // 웹뷰 변수 선언
    Account generateAccount1;
    private List<Account> accounts;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        // Blockchain SDK Init
        sBlockchain = new SBlockchain(); // Blockchain SDK Init
        try {
            sBlockchain.initialize(this);
        } catch (Exception e) {
            e.printStackTrace();
        }
        // 끝


        //이벤트 리스너 호출 //
        connect = findViewById(R.id.connect);
        generateAccount =  findViewById(R.id.generateAccount);
        getAccounts = findViewById(R.id.getAccounts);
        paymentsheet = findViewById(R.id.paymentsheet);
        //cucumber 이벤트 리스너 호출
        webViewInitBtn = findViewById(R.id.webviewinit); // 웹뷰버튼 객체생성
        webView = findViewById(R.id.cucumber); //큐컴버 웹뷰 객체생성

        connect.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(getApplicationContext(),"connect버튼이 눌러졌습니다.",Toast.LENGTH_SHORT).show();
                connected();
            }
        });

        generateAccount.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(getApplicationContext(),"generateAccount버튼이 눌러졌습니다.",Toast.LENGTH_SHORT).show();
                generate();
            }
        });

        getAccounts.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(getApplicationContext(),"getAccounts버튼이 눌러졌습니다.",Toast.LENGTH_SHORT).show();
                setgetAccounts();

            }
        });

      paymentsheet.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View v) {
              Toast.makeText(getApplicationContext(),"paymentsheet버튼이 눌러졌습니다.",Toast.LENGTH_SHORT).show();
              setPaymentsheet();
          }
      });

      webViewInitBtn.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View v) {

              webViewInit();
          }
      });

        //이벤트 리스너 호출  끝//
    }




    //1. connect
    public void connected(){
       sBlockchain.getHardwareWalletManager()
               .connect(HardwareWalletType.SAMSUNG,true) //하드웨어 wallet을 반환하는 형태입니다.
               .setCallback(new ListenableFutureTask.Callback<HardwareWallet>() { //비동기화  자기혼자 쓰레드로 돌아가기 위해서
                   @Override
                   public void onSuccess(HardwareWallet hardwareWallet) {
                        wallet = hardwareWallet;
                   }

                   @Override
                   public void onFailure(ExecutionException e) {
                       Throwable cause = e.getCause();

                       if (cause instanceof HardwareWalletException) {
                           // handling hardware wallet error
                       } else if (cause instanceof RootSeedChangedException) {
                           // handling root seed changed exception
                       }
                   }

                   @Override
                   public void onCancelled(InterruptedException e) {

                   }
               });
    }




    //2. generateAccount
    private  void generate() { //계정생성
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"// 퍼블릭 노드인 공짜인 주소를 가져온거야  + ropsten.infura.io로 들어가서 퍼블릭 노드 불러오기
        );

        sBlockchain.getAccountManager()
                .generateNewAccount(wallet, coinNetworkInfo)
                .setCallback(new ListenableFutureTask.Callback< Account >() {
                    @Override
                    public void onSuccess(Account account) {
                        generateAccount1 = account;
                        Log.e("MyApp", account.toString());
                    }

                    @Override
                    public void onFailure(@NotNull ExecutionException e) {
                        Log.e("MyApp fail",e.toString());

                    }

                    @Override
                    public void onCancelled(@NotNull InterruptedException e) {
                        Log.e("MyApp cancel",e.toString());
                    }
                });

    }



    //3. getAccounts
    private  void setgetAccounts() { //
        accounts = sBlockchain.getAccountManager()
                .getAccounts(wallet.getWalletId(),CoinType.ETH, EthereumNetworkType.ROPSTEN);
        Log.d("MyApp", Arrays.toString(new List[]{accounts})); // 리스트형태로 로그메시지 출력
    }



    //4. paymentsheet
    private  void setPaymentsheet(){ //계정으로 0.01이더만큼 전송합니다.
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"// 퍼블릭 노드인 공짜인 주소를 가져온거야  + ropsten.infura.io로 들어가서 퍼블릭 노드 불러오기
        );

        sBlockchain.getAccountManager() //우리 어카운트가 잇겟죠
                .getAccounts(wallet.getWalletId(),
                        CoinType.ETH,
                        EthereumNetworkType.ROPSTEN
                        );
        // 메타마스크와 삼성키스토어의 계좌번호는 서로 다르다. 규칙이 다르기 때문이다.

        EthereumService service = (EthereumService) CoinServiceFactory.getCoinService(this,coinNetworkInfo);
        Intent intent = service
                .createEthereumPaymentSheetActivityIntent(
                        this,
                        wallet,
                        (EthereumAccount) accounts.get(0),
                        "0x94e44C14e7A5863fed31a68AAD9bbc7d30d6A019",
                        new BigInteger("10000000000000000"),
                        null,
                        null
                );
        startActivityForResult(intent,0);


    }
    //5. 웹을 가져오는 실습
    private void webViewInit() {
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"
        );
        EthereumService service = (EthereumService) CoinServiceFactory.getCoinService(this, coinNetworkInfo);

        accounts =  sBlockchain.getAccountManager()
                .getAccounts(wallet.getWalletId(), CoinType.ETH, EthereumNetworkType.ROPSTEN);

        webView.init(service, accounts.get(0), this);
        webView.loadUrl("https://faucet.metamask.io/");
    }

    @Override
    public void onSendTransaction(
            @NotNull String requestId,
            @NotNull EthereumAccount fromAccount,
            @NotNull String toAddress,
            @org.jetbrains.annotations.Nullable BigInteger value,
            @org.jetbrains.annotations.Nullable String data,
            @org.jetbrains.annotations.Nullable BigInteger nonce
    ) {
        HardwareWallet wallet =
                sBlockchain.getHardwareWalletManager().getConnectedHardwareWallet();

        Intent intent =
                webView.createEthereumPaymentSheetActivityIntent(
                        this,
                        requestId,
                        wallet,
                        toAddress,
                        value,
                        data,
                        nonce
                );

        startActivityForResult(intent, 0);

    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode != 0) {
            return;
        }
        webView.onActivityResult(requestCode, resultCode, data);
    }



}

 

버튼객체선언입니다.

 Button connect;
    Button generateAccount;
    Button getAccounts;
    Button paymentsheet;
    // 웹뷰버튼
    Button webViewInitBtn;

SBlockchain은 1) samsung Blockchain SDK Init을 하고,  2) 하드웨어 wallet을 반환받고, 3) coinNetworkInfo에서 받은 네트워크 정보로 계정을 생성하는데 사용됩니다. 이후 계정에 대한 정보를 해당객체를 통해 얻어옵니다.

wallet은 메소드를 통해 하드웨어 wallet에 대한 정보를 받아와 저장하는 역할입니다. generateAccount1은 계정에 대한 정보를 받아오는 default형 객체이고 List형태로 계정들의 정보를 가져오는 accounts도 선언했습니다. (웹뷰에 관한 내용은 이더송금과는 별개이기에 생략하겠습니다.)

 private SBlockchain sBlockchain ;
    private HardwareWallet wallet;
    private CucumberWebView webView; // 웹뷰 변수 선언
    Account generateAccount1;
    private List<Account> accounts;

SBlockchain의 객체를 초기화합니다.

 // Blockchain SDK Init
        sBlockchain = new SBlockchain(); // Blockchain SDK Init
        try {
            sBlockchain.initialize(this);
        } catch (Exception e) {
            e.printStackTrace();
        }

이벤트 리스너 호출을 위해 객체들을 생성합니다.

 //이벤트 리스너 호출 //
        connect = findViewById(R.id.connect);
        generateAccount =  findViewById(R.id.generateAccount);
        getAccounts = findViewById(R.id.getAccounts);
        paymentsheet = findViewById(R.id.paymentsheet);
        //cucumber 이벤트 리스너 호출
        webViewInitBtn = findViewById(R.id.webviewinit); // 웹뷰버튼 객체생성
        webView = findViewById(R.id.cucumber); //큐컴버 웹뷰 객체생성

이후 각각의 리스너객체에서는 toast메시지를 출력하고 각각에 해당하는 메소드들을 호출하는 구조입니다.

1. connect입니다. 하드웨어 wallet정보를 가져와서 계정과 연결하는 함수입니다. 

//1. connect
    public void connected(){
       sBlockchain.getHardwareWalletManager()
               .connect(HardwareWalletType.SAMSUNG,true) //하드웨어 wallet을 반환하는 형태입니다.
               .setCallback(new ListenableFutureTask.Callback<HardwareWallet>() { //비동기화  자기혼자 쓰레드로 돌아가기 위해서
                   @Override
                   public void onSuccess(HardwareWallet hardwareWallet) {
                        wallet = hardwareWallet;
                   }

                   @Override
                   public void onFailure(ExecutionException e) {
                       Throwable cause = e.getCause();

                       if (cause instanceof HardwareWalletException) {
                           // handling hardware wallet error
                       } else if (cause instanceof RootSeedChangedException) {
                           // handling root seed changed exception
                       }
                   }

                   @Override
                   public void onCancelled(InterruptedException e) {

                   }
               });
    }

2. 네트워크정보를 받습니다. 이때 퍼블릭노드가 필요한데, "https://ropsten.infura.io/" 에 들어가셔서 로그인 하시면 퍼블릭노드를 얻을 수 있습니다. CoinType.ETH, EthereumNetworkType.ROPSTEN로 설정합니다.

해당 네트워크정보와 wallet정보로 계정을 생성합니다. 디버그를 통해 계정의 주소를 알 수 있고 메타마스크에 추가도 할 수 있습니다. 

 

    //2. generateAccount
    private  void generate() { //계정생성
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"// 퍼블릭 노드인 공짜인 주소를 가져온거야  + ropsten.infura.io로 들어가서 퍼블릭 노드 불러오기
        );

        sBlockchain.getAccountManager()
                .generateNewAccount(wallet, coinNetworkInfo)
                .setCallback(new ListenableFutureTask.Callback< Account >() {
                    @Override
                    public void onSuccess(Account account) {
                        generateAccount1 = account;
                        Log.e("MyApp", account.toString());
                    }

                    @Override
                    public void onFailure(@NotNull ExecutionException e) {
                        Log.e("MyApp fail",e.toString());

                    }

                    @Override
                    public void onCancelled(@NotNull InterruptedException e) {
                        Log.e("MyApp cancel",e.toString());
                    }
                });

    }

3. 계정들의 정보를 리스트형태로 저장하고 log에 출력하는 구문입니다. 

    //3. getAccounts
    private  void setgetAccounts() { //
        accounts = sBlockchain.getAccountManager()
                .getAccounts(wallet.getWalletId(),CoinType.ETH, EthereumNetworkType.ROPSTEN);
        Log.d("MyApp", Arrays.toString(new List[]{accounts})); // 리스트형태로 로그메시지 출력
    }

 

4. 결제창을 띄우는 코드입니다. 네트워크정보와 어카운트매니저를 불러오고, EthereumService의 객체를 생성해서 인텐트를 구현합니다. 라이브러리에 의해 인텐트되는 것이고 아래 "0x94e44C14e7A5863fed31a68AAD9bbc7d30d6A019"는

보낼 주소 new BigInteger("10000000000000000")는 1wei단위의 이더리움을 의미합니다. 이렇게 하면 0.1이더를 보내는 형태가 될것입니다. 

 

 private  void setPaymentsheet(){ //계정으로 0.01이더만큼 전송합니다.
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"// 퍼블릭 노드인 공짜인 주소를 가져온거야  + ropsten.infura.io로 들어가서 퍼블릭 노드 불러오기
        );

        sBlockchain.getAccountManager() //우리 어카운트가 잇겟죠
                .getAccounts(wallet.getWalletId(),
                        CoinType.ETH,
                        EthereumNetworkType.ROPSTEN
                        );
        // 메타마스크와 삼성키스토어의 계좌번호는 서로 다르다. 규칙이 다르기 때문이다.

        EthereumService service = (EthereumService) CoinServiceFactory.getCoinService(this,coinNetworkInfo);
        Intent intent = service
                .createEthereumPaymentSheetActivityIntent(
                        this,
                        wallet,
                        (EthereumAccount) accounts.get(0),
                        "0x94e44C14e7A5863fed31a68AAD9bbc7d30d6A019",
                        new BigInteger("10000000000000000"),
                        null,
                        null
                );
        startActivityForResult(intent,0);


    }

 

5. 웹뷰를 통해서 웹의 화면은 앱으로 보여주는 역할을 합니다. 어렵기도 하지만 하나의 규칙처럼 사용되기도 하고, 복잡하여서 설명을 생략하겠습니다.

 

  //5. 웹을 가져오는 실습
    private void webViewInit() {
        CoinNetworkInfo coinNetworkInfo = new CoinNetworkInfo(
                CoinType.ETH,
                EthereumNetworkType.ROPSTEN,
                "https://ropsten.infura.io/v3/70ddb1f89ca9421885b6268e847a459d"
        );
        EthereumService service = (EthereumService) CoinServiceFactory.getCoinService(this, coinNetworkInfo);

        accounts =  sBlockchain.getAccountManager()
                .getAccounts(wallet.getWalletId(), CoinType.ETH, EthereumNetworkType.ROPSTEN);

        webView.init(service, accounts.get(0), this);
        webView.loadUrl("https://faucet.metamask.io/");
    }

    @Override
    public void onSendTransaction(
            @NotNull String requestId,
            @NotNull EthereumAccount fromAccount,
            @NotNull String toAddress,
            @org.jetbrains.annotations.Nullable BigInteger value,
            @org.jetbrains.annotations.Nullable String data,
            @org.jetbrains.annotations.Nullable BigInteger nonce
    ) {
        HardwareWallet wallet =
                sBlockchain.getHardwareWalletManager().getConnectedHardwareWallet();

        Intent intent =
                webView.createEthereumPaymentSheetActivityIntent(
                        this,
                        requestId,
                        wallet,
                        toAddress,
                        value,
                        data,
                        nonce
                );

        startActivityForResult(intent, 0);

    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode != 0) {
            return;
        }
        webView.onActivityResult(requestCode, resultCode, data);
    }

 

다음시간에는 블록체인 sdk 심화과정이 있겠습니다. 

모르시는 부분은 아래 댓글에 남겨주세요. 

반응형

'Blockchain 개발 > SAMSUNG Blockchain SDK' 카테고리의 다른 글

SAMSUNG Blockchain SDK 따라하기(1)  (0) 2020.02.10
반응형

The Samsung Blockchain Platform SDK brings developers and consumers to the blockchain world by providing a full set of functions that the Decentralized App (DApp) or Blockchain App needs. It helps developers to manage blockchain accounts easily and to make a transaction easier by abstracted transfer APIs for each type of ledger system. The Samsung Blockchain Platform SDK offers a cryptocurrency payment solution with its UI.

 

 삼성 블록 체인 플랫폼 SDK는 분산 앱 (DApp) 또는 블록 체인 앱에 필요한 모든 기능을 제공하여 개발자와 소비자를 블록 체인 세계에 제공합니다. 개발자는 각 유형의 원장 시스템에 대한 추상 전송 API를 통해 블록 체인 계정을 쉽게 관리하고 거래를 쉽게 할 수 있습니다. Samsung Blockchain Platform SDK는 UI와 함께 cryptocurrency 지불 솔루션을 제공합니다.

 

즉, Dapp을 개발하는 툴입니다. SAMSUNG Blockchain은  platform SDK와 keystore로 나누어집니다. SDK는 실제 dapp을개발하는데 필요한 다양한 라이브러리와 keystore과의 연결을 지원합니다. keystore는 개인키를 스마트폰에서 쉽고  안전하게 관리할 수 있도록 도와줍니다. 

자세한 내용은 아래 링크에서 확인해보세요.

https://developer.samsung.com/blockchain/platform/overview.html

불러오는 중입니다...

 

준비물:  안드로이드 스튜디오, 갤럭시 s10이상의 keystore를 지원하는 삼성 스마트폰

 

우선 기본설정들은 알아보겠습니다. 

 

1. 위 링크에서 BlockchainPlatformSDK_1.0.00.aar, KeystoreSDK_v1.2.0.aar 를 다운받아서 안드로이드 스튜디오 프로젝트안에 app >> lib 안에 추가합니다. 

 

그다음에 build.gradle에서 dependencies부분을 이렇게 수정합니다. 

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test.ext:junit:1.1.0'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'


    // sdk 를 위해 추가한 부분
    repositories {
        flatDir {
            dirs 'libs'
        }
    }

    implementation name: 'BlockchainPlatformSDK_1.0.00', ext: 'aar'

// network
    implementation 'com.squareup.retrofit2:retrofit:2.6.0'
    implementation 'com.squareup.retrofit2:converter-gson:2.6.0'
    implementation 'com.squareup.okhttp3:logging-interceptor:3.8.0'
    implementation 'com.google.code.gson:gson:2.8.5'

// KeyStore SDK
    implementation name: 'KeystoreSDK_v1.2.0', ext: 'aar'

// web3j
    implementation 'org.web3j:core:4.2.0-android'

// for check developer mode
    implementation 'org.ini4j:ini4j:0.5.4'

// ledger
    implementation 'com.ledger.lib:ledger-android-library:1.0.0'

// dagger
    implementation 'com.google.dagger:dagger:2.21'
    annotationProcessor 'com.google.dagger:dagger-compiler:2.21'
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.50"

}

AndroidManifest.xml 파일 하단에 아래 코드를 추가합니다.

<uses-permission android:name="android.permission.INTERNET" />

 

기본셋팅은 이정도로 하고 다음 포스팅에서는 계정과 연결하는 실습을 진행해보겠습니다. 

반응형

'Blockchain 개발 > SAMSUNG Blockchain SDK' 카테고리의 다른 글

SAMSUNG Blockchain SDK 따라하기(2)  (0) 2020.02.11
반응형

dApp을 개발함에 있어서는 크게 두 파트로 나누어진다. 

첫 파트는 블록체인과 연결되는 스마트 컨트랙트 코드, 프론트엔드 코드이다.

 

 

 결국 스마트 컨트랙트 코드 + 프론트엔드 코드 + 기타를 합쳐서 dApp을 구성하게되는데, 이 때 프론트엔드 코드가 스마트 컨트랙트 코드 함수에서 실행되는 것에 대해서 소통을 하기 위해서 이용되는 것이 바로 Event이다.

스마트 컨트랙트가 Event를 send하면 프론트엔드 코드에서 listen하는 식으로 동작한다.

 

 

Event(이하 이벤트)란 트랜잭션 내에서 호출될 수 있는 일종의 리턴값이 없는 함수입니다. 이벤트를 호출하면 그 호출한 기록이 Transaction Receipt라 불리는 트랜잭션 결과에 저장됩니다. 일종의 로그(log)입니다. 

 



출처: https://joojis.tistory.com/entry/Solidity-프로그래밍-2 [블록체인 개발 블로그]

반응형

'Blockchain 개발 > Solidity 프로그래밍' 카테고리의 다른 글

Solidity 이더리움 송금하기  (0) 2020.02.09
Solidity 문법  (0) 2020.02.09
Solidity 실행하기  (0) 2020.02.08
반응형

사람 뿐만 아니라, 스마트 계약도 내부적으로 이더리움 계정1를 가집니다. 스마트 계약은 계약 계정를 통해 이더를 거래합니다.
예를 들어, 계약을 통해 A가 B에게 10 이더를 보내는 계약을 호출할 때, 이더는 사실 다음과 같이 이동합니다.

  1. A가 A 계정에서 계약 계정으로 10 이더를 송금
  2. 계약이 계약 계정에서 B 계정으로 10이더를 송금

 

 

payable 키워드

payable 키워드는 계약 계정에 외부에서 이더를 송금 받을 수 있도록 합니다. 즉, 계약이 A에게 송금을 받으려면 A가 호출하는 함수에 payable 키워드가 있어야합니다.

 

 

아래코드를 실행해보세요.

pragma solidity ^0.4.24;

contract Solution {
    uint256 balance = 0;

    function sending() payable public {
        balance = msg.value;
        emit Sended(msg.value, balance);
    }

    event Sended(
        uint256 _value,
        uint256 _balance
    );
}

 

payable 키워드를 사용해 계약에게 이더를 보내는 방법을 선언합니다. 

 

 

반응형

'Blockchain 개발 > Solidity 프로그래밍' 카테고리의 다른 글

Solidity Event란?  (0) 2020.02.09
Solidity 문법  (0) 2020.02.09
Solidity 실행하기  (0) 2020.02.08
반응형

주요 자료형

  • uint : 부호가 없는 정수형
  • int : 정수형
  • bool : 논리 자료형
  • string : UTF-8 인코딩 문자열
  • bytes : 바이트
  • address : 이더리움 주소 값 (0xaDc7192A0…)

레퍼런스 자료형

  • 배열 : 자료형이 같은 데이터를 묶은 자료 구조입니다.
  • 구조체 : 다양한 자료형의 데이터를 묶은 자료 구조입니다.

 

예제 1번

 

다음과 같이 입력해주시고 다시 compile을 하고 run에서 create 버튼을 클릭합니다. 

 

pragma solidity ^0.4.24;
 
contract Simpleexample {
    
    string public name = "James";
    uint128 public birthday = 20180328;
   
    uint[] setOfYear = [2018, 2019, 2020];
    uint year = setOfYear[0];
    bool isHappy = true;
    
    function getYear() public view returns (uint) {
        
        return year;
    }
 
    function getHappy() public constant returns (bool) {
        return isHappy;
    }
    
    
}


public으로 선언된 값들 위처럼 확인하실수 있습니다. 

 

 

string public name = "James";
uint128 public birthday = 20180328;   
uint[] setOfYear = [2018, 2019, 2020];
uint year = setOfYear[0];
bool isHappy = true;

각각의 자료형에 맞는 변수를 선언하고 값을 대입합니다. public이라고 명시를 하는경우만 접근지정자가 public이 되는 것을 확인하실 수 있습니다. 

 

 

function getYear() public view returns (uint) {
        return year;
    }
function getHappy() public constant returns (bool) {
        return isHappy;
    }
함수의 선언방식입니다. 기존언어들과는 다르게 접근지정자를 뒤에 쓰는게 인상적입니다.  returns (자료형) 으로 반환할 자료형을 전달하는 형식이고 return에 반환할 값을 입력하는 형태입니다. 

 

그리고 주석은 c와 동일하게 줄주석은 // 구역주석은 /* */ 를 사용합니다. 

 

 

 

 

솔리디티의 연산자(Operator)

  • 논리 연산자: !, &&, ||
  • 비교 연산자 : <=, <, ==, !=, >=, >
  • 비트 연산자: &, |, ^, <<, >> (시프트 연산자)
  • 단항(unary) 산술 연산자: +, -
  • 이항(binary) 산술 연산자: +, -, *, / (몫), % (나머지), ** (거듭 제곱)

제어문(Control Structures)

  • 조건문: if, else, ? : (삼항 연산자)
  • 반복문: while, do, for
  • 반복문 분기: break, continue
  • 반환문: return

 

예제 2번

 

 

pragma solidity ^0.4.24;
 
contract Simpleexample {
    
    uint t1 = 0;
    bool t2 = false;

    function playground() public returns (uint, bool) { // multi return type

        for (uint i = 0; i < 10; i++) {
            t1++;
        }

        t2 = 2 ** 3  == 8 &&t1 == 10;
        

      
        return (t1, t2);
    }

   
}


 

 

결과는 직접확인해보세요!

 

: 솔리디티가 부동소수점을 지원하지 않는 이유

부동소수점 타입으로는 수를 정확하게 표현하지 못합니다.
수를 정확히 다룰 수 없는 타입은 이더(Ether)를 다룰 수 없어, 솔리디티는 부동소수점을 지원하지 않습니다.

반응형

'Blockchain 개발 > Solidity 프로그래밍' 카테고리의 다른 글

Solidity Event란?  (0) 2020.02.09
Solidity 이더리움 송금하기  (0) 2020.02.09
Solidity 실행하기  (0) 2020.02.08
반응형

Solidity는 스마트 계약을 작성하기위한 객체 지향 프로그래밍 언어입니다. 다양한 블록 체인 플랫폼, 특히 이더 리움에서 스마트 계약을 구현하는 데 사용됩니다. 이전의 이더 리움 핵심 참여자들이 Ethereum과 같은 블록 체인 플랫폼에서 현명한 계약을 작성할 수 있도록 개발했습니다.

 

Influenced by

JavaScript, C++, Python, PowerShell

 

 

스마트 컨트랙터를 만들기 위해 Solidity라는 언어를 알아야 합니다. 개발환경은 Remix라는 브라우저 기반의 개발환경을 사용하려고 합니다. 보통 통합 개발 환경을 Integrated Development Environment의 약자인 IDE로 부릅니다.

Remix는 아래 링크를 따라 가면 접속됩니다.

 

https://github.com/ethereum/remix-live/tree/gh-pages

 

ethereum/remix-live

Live deployment of the remix IDE. Contribute to ethereum/remix-live development by creating an account on GitHub.

github.com

clone-download 버튼을 누르고 압축을 풀고, index.html을 클릭합니다.

 

화면과 같은 개발도구가 실행될것입니다. 왼쪽 상단에 +버튼을 누르고 Simpleexample.sol을 생성하세요.

그리고 아래에 코드를 복사해서 넣어주세요.

 

pragma solidity ^0.4.24;
 
contract Simpleexample {
    uint storedData;
 
    function set(uint x) public {
        storedData = x;
    }
 
    function get() public constant returns (uint) {
        return storedData;
    }
}

 

다음은 셋팅에서 Solidity version을 맞춰줍니다. 

다시 compile로 돌아오셔서 start to compile 버튼을 누르시면 컴파일이 완료됩니다. 

run에 들어가셔서 아래처럼 맞춰주시고  get, set함수의 버튼을 누르시면 하단의 아웃풋값이 출력되는것을 볼 수 있습니다. 

 

 

  • Web3 Provider :
    외부 도구가 필요합니다. geth가 로컬에서 작동되고 있어야 하며 이더를 할당하거나 직접 마이닝 해야 합니다.
  • Injected Provider :
    역시 외부 도구가 필요합니다. Mist 브라우저나 MetaMask를 통해 테스트넷에 연결하여 사용합니다.
  • JavaScript VM :
    셋 중 가장 간단하고 편하며, 이번에 알아볼 방법입니다. 외부 도구가 필요 없으며 Remix의 메모리상에서 모든 작업이 이루어집니다.

다음 포스팅에서는 쏠리디티 문법에 대해서 공부해보도록 하겠습니다. 

반응형

'Blockchain 개발 > Solidity 프로그래밍' 카테고리의 다른 글

Solidity Event란?  (0) 2020.02.09
Solidity 이더리움 송금하기  (0) 2020.02.09
Solidity 문법  (0) 2020.02.09
반응형

 founders 3기 2일차 교육과정을 받았습니다.
삼성전자 서초사옥 대강의장에서 교육을 받았고, 테조스코리아의 최민철, 페어스퀘어랩의 김흥범, 코인원의 강하다, 플라네타리움의 서기준멘토님들께서 강연을 해주었습니다.

 

 우선 블럭체인앱을 DAPP이라고 합니다. 예를 들어, 이더리움코인을 이용해 배팅을 하는 게임 같은 것들이 DAPP에 속합니다.

 아래그림은 우리나의 블록체인 기업들을 묶어놓은 그림입니다. 

 이렇게 다양한 기업들이 있고, 각각의 역할을 수행하며 발전하고 있습니다. 

이중에 DAPP 서비스 생태계에 대해서 알아보겠습니다. 총 4가지로 나눌 수 있습니다. 블록체인 개발사(EX: 이더리움,EOS), 지갑 개발사(METAMASK, SCATTER), SDK 기술 솔루션 개발사(loom, onther), dapp 개발사(Dapp radar, eos knights)이 있습니다.  

 

 첫번째로 블록체인 개발사(EX: 이더리움,EOS)는 우리가 흔히 알고있는 코인과 가장 밀접한 분야로써 블럭체인이 돌아가는 Base를 의미합니다. 지갑 개발사는 블록체인의 프라이빗키를 보관하는 보관소입니다. DAPP을사용하는데에쓰이는signing기능서비스를 담당합니다. 개발 기술사는 dapp를 개발하는데 필요한 프레임워크, 툴을 제공하는 곳 입니다. Loom, onther등이 대표적입니다. 마지막으로 dapp개발사들이 있습니다. dapp개발사들은 자신들의 서비스를 구현하여 사용자에게 서비스를 전달합니다.  

 

 

최근 트렌드는 defi, did등이 있다고 합니다. 

강하다멘토님은 블록체인 기술로 무슨 문제를 해결할 건지, 그것이 현실에 어떻게 적용될 것인지, 그리고 어떻게 널리 알릴 것 인지를 해결하기 위해서는 나만의 철학이 필요하다고 말씀하셨습니다. 이를 위해서 문제를 발현하고 기술을 이해하는데 집착하라고 말씀해주셨습니다.

반응형
반응형

FOUNDERS X SAMSUNG Blockchain

 

 

founders 3기 2일차 교육과정을 받았습니다.
삼성전자 서초사옥 대강의장에서 교육을 받았고, 테조스코리아의 최민철, 페어스퀘어랩의 김흥범, 코인원의 강하다, 플라네타리움의 서기준멘토님들께서 강연을 해주었습니다. 

너무 많은 내용을 배웠기 때문에 2개로 나누어 포스팅하겠습니다. 

 

최민철멘토님은 블록체인 플랫폼 전반에 대해 설명해주셨습니다. 

 

블록체인이란?

 

 블록체인은 관리 대상 데이터를 '블록'이라고 하는 소규모 데이터들이 P2P 방식을 기반으로 생성된 체인 형태의 연결고리 기반 분산 데이터 저장 환경에 저장하여 누구라도 임의로 수정할 수 없고 누구나 변경의 결과를 열람할 수 있는 분산 컴퓨팅 기술 기반의 원장 관리 기술입니다. (P2P는 쉽게 얘기하면 토렌트의 원리입니다. 서버에서 데이터를 받아오는 것 이 아닌 각 클라이언트에서 데이터를 전달해주는 형태입니다.)

즉,데이터를 분산처리하는 ‘탈중앙화’를 핵심으로 하는 기술입니다. 대표적인 예시로는 비트코인이 있습니다. 

 

-블록체인: 블록 안에 데이터를 기록하고 이러한 블록들이 순차적으로 연결되어 만들어진 블록의 집합체

-블록체인은 분산 데이터 저장 기술로서, 블록체인 네트워크 안의 (허가된) 모든 사용자가 거래 내역 등의 데이터를 생성,
기록, 검증, 보관하는 기술이다.

-특정 기관 또는 중앙 서버가 아닌 P2P 네트워크를 통해 다수의 사용자가 해당 데이터에 접근할 수 있기 때문에 '분산 거래 장부'라고 부르기도 한다.

 

 우선 트랜잭션은 모두가 공유하고 있는 장부의 상태(Global State)를 변화시키는 행위입니다. 그리고 블럭은 블록체인의 상태를 변화시키는 연산자로써 하나의 단위라고 생각하시면 됩니다.

블록체인에서 각각의 노드들은 트랜잭션이 발생하면 인접한 노드(PEER)들에게 해당 트랜잭션을 전달하게 되며 모든 노드들에 전달이 됩니다. 이때 일정한 주기에 따라 트랜잭션의 모음인 블럭이 형성이 됩니다블럭에는 이전 블럭의 번호, 트랜잭션들이 저장이 됩니다. 

 다음으로 스마트 컨트랙트는 1996년 닉 자보가 제안한 방식으로 계약 내용들을 디지털 형태로 기록하자는 것이다. 스마트 컨트랙트는 프로그래밍 코드에 의해 이뤄지기 때문에 공정성하고 이러한 과정이 투명하다. 이러한 스마트 컨트랙트의 기능이 블럭체인에 있기 때문에 많은 사람들이 비트코인를 신뢰하고 구매할 수 있는 것이다. 블럭체인 서비스에 이러한 스마트컨트랙트의 공정성이 있기 때문에 이더리움코인을 담보로 달러를 빌려주는 것도 존재한다.

스마트컨트랙트의 동작절차는 1. 등록 2. 실행 3. 삭제로 매우 간단하다. 

 

스마트컨트랙트 플랫폼에는 우리가 일반적으로 잘 알고 있는 이더리움, EOS등이 있다. 그리고 현재 페이스북에서 개발중이 LIBRA등이 포함된다. 

각각의 플랫폼에는 장단점이 존재한다. 우월한 한가지의 플랫폼이 있을 수 없는것이다. 

 

이 3가지요소가 대립하는데, 플랫폼들의 차이점은 어느요소에 어느정도로 더 중점을 두는지에 따라 다른 것이다. 

 

김흥범멘토님은 실제로 이더리움을 사용하고 DAPPS중 하나인 COMPOUND를 사용하는 절차를 보여주셨다. 꽤나 번거로운 절차이지만, 실제로 돈을 빌리는 것에 비하면 굉장히 자유로운 편이다. 우선 사람의 신용정보를 고려하지 않는다. 

이더리움코인의 가치를 담보로 돈을 빌려주는 것이다. 직접 은행에 갈 필요도 없고, 나의 신원증명또한 필요하지 않는 굉장히 파격적인 방법이였다. 

 

다음포스팅에서는 블럭체인산업시장의 구조와 DAPPS에 대해 알아보겠습니다. 

반응형

+ Recent posts