forked from cosmos/ibc
-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Translate ics-001-ics-standard/README.md (#13)
- Loading branch information
1 parent
55690e9
commit 491ceb8
Showing
1 changed file
with
152 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,152 @@ | ||
--- | ||
ics: '1' | ||
title: ICS 사양 표준 | ||
stage: 초안 | ||
category: meta | ||
author: Christopher Goes <[email protected]> | ||
created: '2019-02-12' | ||
modified: '2019-08-25' | ||
--- | ||
|
||
## ICS 란 무엇인가? | ||
|
||
인터체인 표준(Inter-chain standard, ICS)은 어떤 프로토콜, 표준, 또는 코스모스 생태계가 사용될 것이라고 기대되는 기능들을 설명하는 설계 문서입니다. ICS는 필요한 요소들을 나열하고, 설계 근거를 설명하며, 간결하고 포괄적인 기술적인 사양을 제공해야 합니다. ICS 저자는 표준화 프로세스를 통해 제안하고, 커뮤니티의 지원이나 리뷰를 요청하며, 사회적 합의를 위해 관련된 이해 관계자와 의사소통을 해야합니다. | ||
|
||
인터 체인 표준화 프로세스는 생태계 전반의 프로토콜과 변화, 특징을 제안하는 주요 수단이 되어야 하며, ICS 문서들은 합의 후에도 향후 구현자를 위해 설계 결정사항과 각종 정보들을 유지해야 합니다. | ||
|
||
인터체인 표준은 코스모스 허브와 같은 특정 블록체인의 변경을 제안하거나, 구현상에 있어서의 특징들(언어 별 데이터 구조 등) 또는 이미 존재하는 Cosmos 블록체인의 거버넌스 제안을 위해 사용되어서는 안됩니다. 이는 코스모스 생태계에 있는 개별 블록체인들이 인터체인 표준을 사용할지 말지를 정할 거버넌스를 이용할 수 있음에도 제한됩니다. | ||
|
||
## 구성요소 | ||
|
||
ICS는 헤더, 개요, 명세, 히스토리 로그, 저작권 공시로 구성됩니다. 이 구성요소는 필수로 작성해야 합니다. 레퍼런스는 링크 형태나, 필요시 하단의 표 형태로 반드시 포함돼야 합니다. | ||
|
||
### 헤더 | ||
|
||
ICS 헤더는 관련된 메타데이터를 포함합니다. | ||
|
||
#### 필수 필드 | ||
|
||
`ics: #` - ICS 번호 (순차적으로 할당됩니다.) | ||
|
||
`title` - ICS 제목 (짧고 명료하게 표현해야 합니다.) | ||
|
||
`stage` - 현재 ICS 단계를 나타내며, 사용할 수 있는 단계들은 [PROCESS.md](../../PROCESS.md) 에서 확인할 수 있습니다. | ||
|
||
ICS의 승인 단계들에 대한 설명은 [README.md](../../README.md)을 참조하십시오. | ||
|
||
`category` - ICS 카테고리, 다음 중 하나입니다: | ||
|
||
- `meta` - ICS 절차와 관련된 표준 | ||
- `IBC/TAO` - 블록체인간 통신에서의 전송, 인증, 순서 정렬과 같은 코어 시스템 단 프로토콜에 대한 표준 | ||
- `IBC/APP` - 블록체인간 통신 시스템 어플리케이션 레이어 프로토콜 표준 | ||
|
||
`author` - ICS 저자 & 연락 정보 (선호 순서 : 이메일, Github, Twitter, 기타 응답을 요구할 수 있는 연락 방법). | ||
제 1 저자는 기본적으로 ICS의 "소유자(owner)"이고, 표준화 과정을 통해 발전시켜야 할 책임이 있습니다. 이어지는 저자들의 순서는 기여한 양에 따라 정해져야 합니다. | ||
|
||
`created` - ICS가 처음 만들어진 날짜 (`YYYY-MM-DD`) | ||
|
||
`modified` - ICS가 마지막으로 수정된 날짜 (`YYYY-MM-DD`) | ||
|
||
#### 선택적 필드 | ||
|
||
`requires` - 이 표준에서 요구하거나 의존하는 다른 ICS 표준(번호에 의해 참조됩니다.) | ||
|
||
`required-by` - 이 표준을 요구하는 다른 ICS 표준 (번호에 의해 참조됩니다.) | ||
|
||
`replaces` - 해당되는 경우, 이 표준으로 대체되는 다른 ICS 표준 | ||
|
||
`replaced-by` - 해당되는 경우, 이 표준을 대체하는 다른 ICS 표준 | ||
|
||
### 개요 (Synopsis) | ||
|
||
개요는 헤더에 이어지며, ICS는 반드시 명세에 대한 높은 수준의 설명과 논리적 근거를 제공하는 200자 이내의 간략한 개요를 포함해야 합니다. | ||
|
||
### 명세 | ||
|
||
명세는 ICS의 가장 중요한 구성요소이고, 프로토콜 문서, 설계의 논리적 근거, 필요한 레퍼런스, 그리고 적절한 기술 내용들을 포함해야 합니다. | ||
|
||
#### 하위 구성요소 (Sub-components) | ||
|
||
명세는 특정 ICS에 적합한 여러 종류의 하위 구성요소를 가질 수 있습니다. 포함되는 하위 구성요소는 아래 순서대로 나열돼야 합니다. | ||
|
||
- *Motivation* - 제안한 기능의 존재 여부, 혹은 기능 변경 제안에 대한 논리적 근거 | ||
- *Definitions* - 이 ICS에서 사용되거나 이를 이해하기 위해 필요한 새로운 용어 또는 개념 목록. 가장 상위 docs 폴더에서 정의되지 않은 용어들은 반드시 이 항목에서 정의되어야 합니다. | ||
- *Desired Properties* - 명세된 프로토콜 또는 기능이 원하는 속성, 그리고 기대 효과나 속성이 위반되었을 경우 발생하는 실패에 대한 목록입니다. | ||
- *Technical Specification* - 구문, 시맨틱, 하위 프로토콜, 자료구조, 알고리즘과 적절한 의사코드를 포함하는 모든 기술적인 내용입니다. 기술 명세는 서로 의존하지 않는 분리된 구현체들이 호환될 수 있도록 충분히 상세해야 합니다. | ||
- *Backwards Compatibility* - 이전의 기능 또는 프로토콜 버전과의 호환성(또는 비호환성)에 대한 설명 | ||
- *Forwards Compatibility* - 앞으로 구현할 예정이거나 기대되는 기능, 또는 프로토콜 버전과의 호환성(또는 비호환성)에 대한 설명 | ||
- *Example Implementation* - 구현자들에게 주요 참고 자료로 이용할 수 있는 자세한 구현 예제 또는 설명 | ||
- *Other Implementations* - 제작중이거나 완성된 구현체들의 목록(외부 참조) | ||
|
||
### 히스토리 (History) | ||
|
||
ICS는 히스토리 항목을 포함하며, 도움이되는 문서들과 중요한 변화들에 대한 로그들을 기록합니다. | ||
|
||
히스토리 항목의 예제는 [아래](#history-1)를 참조하세요. | ||
|
||
### 저작권 (Copyright) | ||
|
||
ICS는 [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0)를 통해 권리를 포기하는 저작권 항목을 포함해야 합니다. | ||
|
||
## 서식 (Formatting) | ||
|
||
### 일반 | ||
|
||
ICS 명세는 반드시 GitHub과 호환 가능한 Markdown 으로 작성되어야 합니다. | ||
|
||
Github와 호환 가능한 Markdown cheat sheet는 [여기](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet)를 참조하세요. 로컬 Markdown 렌더러의 대한 내용은 [여기](https://github.com/joeyespo/grip)를 참조하세요. | ||
|
||
### 언어 | ||
|
||
ICS 명세는 반드시 간단한 영어로 작성되어야 하며, 모호한 용어와 불필요한 전문용어는 지양해야 합니다. 간단한 영어의 좋은 예제는, [Simple English Wikipedia](https://simple.wikipedia.org/wiki/Main_Page)를 참조하세요. | ||
|
||
명세에서 "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", 그리고 "OPTIONAL" 와 같은 단어들은 [RFC 2119](https://tools.ietf.org/html/rfc2119)에서 설명된 대로 해석됩니다. | ||
|
||
### 의사코드 (Pseudocode) | ||
|
||
명세에서의 의사코드는 언어에 구애받지 않아야 하며, 줄 수, 변수, 간단한 조건문, 반복문, 또는 스케줄링 타임아웃과 같이 기능에 대한 설명이 필요한 부분은 작은 영어 문단으로 표현하는 것과 같이 간단한 표준 형태여야 합니다. LaTeX 이미지는 diff 형태로 리뷰하기 어렵기 때문에 피해야 합니다. | ||
|
||
구조체에 대한 의사코드는 간단한 TypeScript를 이용하여, 인터페이스로 작성되어야 합니다. | ||
|
||
구조체 의사코드 예제: | ||
|
||
```typescript | ||
interface Connection { | ||
state: ConnectionState | ||
version: Version | ||
counterpartyIdentifier: Identifier | ||
consensusState: ConsensusState | ||
} | ||
``` | ||
|
||
알고리즘에 대한 의사코드는 간단한 Typescript를 이용하여, 함수로 작성되어야 합니다. | ||
|
||
알고리즘 의사코드의 예제: | ||
|
||
```typescript | ||
function startRound(round) { | ||
round_p = round | ||
step_p = PROPOSE | ||
if (proposer(h_p, round_p) === p) { | ||
if (validValue_p !== nil) | ||
proposal = validValue_p | ||
else | ||
proposal = getValue() | ||
broadcast( {PROPOSAL, h_p, round_p, proposal, validRound} ) | ||
} else | ||
schedule(onTimeoutPropose(h_p, round_p), timeoutPropose(round_p)) | ||
} | ||
``` | ||
|
||
## 히스토리 | ||
|
||
이 명세는 Bitcoin의 BIP 프로세스와 Python의 PEP 프로세스에서 파생된 이더리움의 [EIP 1](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1.md)에서 크게 영감을 얻었습니다. 이전 저자들은 이 ICS 명세나 절차의 부족함에 대해 책임이 없습니다. 모든 코멘트는 ICS 레포지토리 관리자에게 보내주세요. | ||
|
||
2019년 3월 4일: 초안 작성 및 PR로 제출 | ||
2019년 3월 7일: 초안 병합 | ||
2019년 4월 11일: 의사 코드 포맷팅 업데이트, 하위 섹션 정의 추가 | ||
2019년 4월 17일: 카테고리 분류 | ||
|
||
## 저작권 | ||
|
||
여기의 모든 내용들은 [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0)에 따라 라이센스가 부여됩니다. |