반응형

NFT가 뭐고 왜 해야 하고 그딴 시덥잖은 이야긴 다른 글을 참조하시고 바로 실전으로 들어간다.
묻지도 따지지도 말고 일단 IPFS에 파일 올리는것부터 해야 하는데 IPFS를 이용하는 이유는 NFT는 그림, 음원, 비디오 그딴건데 파일을 안 올리면 어쩌겠는가?
그런데 이걸 한 개인의 서버에 올리면?
서버 다운되거나 해킹되면?
그러니 분산 파일 시스템인 IPFS에 올리는거

궁금하면 더보기~

더보기

NFT(Non-Fungible Token)는 고유한 디지털 자산을 나타내는 토큰으로, 블록체인 기술을 기반으로 합니다. IPFS(InterPlanetary File System)는 분산 파일 시스템으로, 파일을 분산된 네트워크에 저장하고 검색할 수 있게 해줍니다. NFT를 만들 때 IPFS를 이용하는 이유는 여러 가지가 있습니다:

분산 저장: IPFS는 파일을 여러 노드에 분산하여 저장하므로 중앙 서버에 의존하지 않습니다. 이는 단일 지점의 장애나 특정 서버의 다운으로 인한 데이터 손실을 방지할 수 있습니다.

내구성과 신뢰성: IPFS는 데이터를 여러 노드에 복제하여 내구성과 신뢰성을 높입니다. 파일이 한 노드에서 손상되거나 사용 불가능해지더라도 여러 다른 노드에서 해당 파일을 찾아 사용할 수 있습니다.

비용 효율성: IPFS를 사용하면 파일을 저장하고 검색하는 데 필요한 비용을 최적화할 수 있습니다. 중앙화된 서버를 운영하고 유지하는 데 필요한 비용을 줄일 수 있습니다.

방대한 용량과 확장성: IPFS는 대용량 파일을 효과적으로 처리할 수 있으며, 필요에 따라 확장될 수 있습니다. 블록체인이나 중앙 서버에서 처리하기 어려운 큰 용량의 미디어 파일을 다룰 수 있습니다.

안전성과 보안: IPFS는 데이터를 암호화하고 해시값을 통해 무결성을 검증하여 안전성과 보안을 강화합니다. 블록체인과 결합하여 높은 수준의 보안을 제공합니다.

이러한 이유로, NFT를 만들 때 IPFS를 이용하여 디지털 자산을 저장하고 관리하는 것이 일반적으로 권장됩니다. 이를 통해 더 분산화되고 안전한 환경에서 NFT를 다룰 수 있습니다.

IPFS를 다운받기 위해 공홈에 가보면 
https://docs.ipfs.tech/install/ipfs-desktop/#windows

요런 다운로드 페이지 안내 문구를 발견할 수 있다. 
눌러보면 아래 링크로 이동되는데
https://github.com/ipfs/ipfs-desktop/releases
웃기는건 window용 exe가 없다.

Show all 17 assets를 눌러야 아래처럼 윈도우용 IPFS 인스톨 파일을 확인할 수 있다. -_-

다운받고 실행하면 설치할 위치 선택해주고

설치완료되면 실행 가능하다.

기본 설치 경로로 설치하면 IPFS.exe파일은 아래 경로에 들어가 있다.
C:\Program Files\IPFS Desktop\resources\app.asar.unpacked\node_modules\kubo\kubo

이게 왜 중요하냐면
윈도우용은 설치 후 실행되는 프로그램이 daemon의 일을 맡아 하지만 어떤 책에 보면 이런 설명 조차 없이 daemon을 실행하라고만 해서 한참을 헤매게 만들기 때문이다.

설치 후 IPFS를 실행해보면 저런 화면이 나오는데 상태와 파일 등등 좌측 메뉴를 눌러보면 뭐 대충 잘 동작하는것 같다.

만약 웹브라우저로 확인해보고 싶다면
http://127.0.0.1:5001/webui
이렇게 해도 동일한 화면 확인이 가능하다.

별건으로 IPFS를 어디서든 동작하게 하려면 환경변수에 IPFS를 등록해야 하는데

아까 설치한 경로를 등록해주면 된다.
C:\Program Files\IPFS Desktop\resources\app.asar.unpacked\node_modules\kubo\kubo

그리고 실행된 IPFS Desktop은 트레이 아이콘으로 동작중인걸 확인할 수 있다.

눌러보면 재시작, 중지 등 추가 작업이 가능하다.

여기까지 IPFS를 설치하였다면 이제 node.js로 IPFS에 파일 업로드를 해보겠다.
node와 npm설치하는 방법은 다른 구글링하여 블로그를 참조하기 바란다.
엄청 쉽다. (https://nodejs.org/ko 여기서 다운받고 설치하면 그만이다.)

IPFS를 설치하면 포트가 5001로 동작하고 파일 업로드시 필요한 모듈은 ipfs-api, fs, bl 정도이다.
일단 프로젝트의 위치를 지정하겠다.
나는 D:\Project\NFT로 지정하였다.

이제 cmd를 눌러 D:\로 이동 후 CD Project, CD NFT를 입력하여 위치를 이동시키자.
모듈 설치하자.  
npm i ipfs-api
npm i fs
npm i bl
각각의 모듈이 무슨 일을 하는지는 chatgpt에게 물어보라. ㅎㅎ

vscode를 실행하여 아래 코드를 타이핑 후 app.js로 저장하자.
당연히 위치는 D:\Project\NFT다.

const IPFS = require("ipfs-api");
const fs = require("fs");
const bl = require('bl'); // 'bl' 모듈을 추가


const ipfs = new IPFS({
    host: "127.0.0.1",
    port: 5001,
    protocol: "http"
});

const file = fs.readFileSync("./test.txt");
const fileBuffer = bl(new Buffer.from(file)); // 'bl' 모듈로 Buffer를 래핑

ipfs.files.add(fileBuffer, (err, result) => {
    if (err) {
        console.error(err);
    } else {
        console.log("File add success! result :", result[0].hash);
    }
});

이제 node로 만든 app.js를 아래처럼 실행하면 성공 메세지와 함께 암호문자열을 확인 가능할것이다.
참고로 업로드할 파일인 test.txt파일은 D:\Project\NFT에 test.txt 파일을 미리 만들어 두자

result 자체를 찍어보면 다음과 같이 나온다.
  {
    path: '******NVAiMNRcGu6x1AwQ4c5SBnJMH',
    hash: '******NVAiMNRcGu6x1AwQ4c5SBnJMH',
    size: 6
  }
path는 경로 cid는 컨텐츠 식별자 size는 파일 용량이다. path와 cid가 동일함을 알 수 있다.

만약 아래처럼 오류가 난다면 IPFS 프로그램이 중지되었기 때문이다.
IPFS를 실행해둔 상태에서 하길 바란다.
(만약 난 좀 있어보이고 싶다란 사람이라면 cmd창에서 ipfs daemon이라 실행하면 동일한 효과를 볼 수 있다.)

한가지 주의해야 할 점은 이후 node.js로 IPFS로 파일을 업로드 시켜볼 예정인데 이 파일 메뉴에 내가 올린 파일이 바로 나오지 않는다란 점이다.

아까 node.js로 업로드 후 성공 메세지로 받았던 문자열을 Browse에 입력하고 검색하면 확인이 가능하다.
File add success! result : Q *************....H

이렇게 잘 나온다.

만약 빈 파일을 업로드했다면 이렇게 나오니 당황하지 말자.

반응형

'NFT' 카테고리의 다른 글

NFT 개발하기 - 2편 IPFS에 node.js로 파일 다운로드하기  (0) 2024.01.19
Posted by Hippalus
,

반응형

정릉시장에 줄서서 먹는다는 호떡집인 남기남 호떡이 있다길래 차를 몰고 정릉시장으로 고고하였다.
호떡을 남기남? (아재 아재~~)

위치를 몰랐는데 정릉시장 공영주차장으로 가는길에 남기남 호떡 집이 있었다.
그런데 줄이 없넹? 춥지도 않은 날인데... 
참고로 주차장에서 한 50m 정도 된다.

호떡 세개를 샀다.
각각 1,500원이었는데 맛은 뭐 평범했다.
맛보다 호떡 하나에 1,500원이라니
하.... 코로나와 러우전쟁 때문에 세상이 이상해져 버렸다.

굳이 멀리서 줄서가며 먹을만한 그런집은 아니었다.

신포도겠지만 사라다 빵과 꽈배기가 맛있어 보였다.

호떡 한개씩 취식하고 발걸음을 정릉 시장 안쪽으로 옮겼다.
시장 여기저기 한바꾸 돌다 보니 엔틱한 이발관이 시야에 들어와 한컷 담아봤다.
왠지 물조리개와 바리깡이 있을 법한 외관이다.

시장에서 가장 마음에 들던 건물이었다.
여기저기 아기자기한 카페들도 있고 하천도 흐르고
여름에 와서 맥주 한 잔 하기 괜찮은 분위기였다.

시장 자체는 다른 시장들에 비해 좀 작은 느낌.
사진은 안 찍었지만 중간쯤 튀김집 색이 아주 쌧노란것이.. 하마터면 지갑 열 뻔 했다.

새로운 그리고 간만의 재래시장 방문이라 시장 투어 자체는 뭐 쏘쏘~

다만 여기 주차가 정말 쉣이다.
공영주차장이랍시고 하나 있는데 주차가능 대수가 15대 정도 되려나? 그중에서 장애인도 1대
유료주차장인데 이중주차에 들어오는 차 나가려는 차 뒤엉키고 난리다.
저렇게 하꼬방만한 주차장을 공영이랍시고 만들어 두고 참 불편하다.
그런데도 재래시장 방문해주세요 뿌잉뿌잉, 주말엔 마트 의무휴일인거 아시죠?
이딴 정책은 정말이지 한심하기 짝이 없다.

보여주기식 정책에 효과도 없는 대형마트 일요일 의무휴업 폐지하는 정치인 나오면 무족헌~ 뽑아준다.
효과 없는거 공식 확인도 됐는데 표 눈치 보느라 생명 연장하는 짓은 이젠 좀 그만둘 때도 되지 않았는가

반응형
Posted by Hippalus
,

반응형

아드님이 호떡이 드시고 싶으시단다.
유명한 호떡집 남기남이 정릉시장에 있다하여 차를 몰고 정릉시장에 방문하였다.
시장을 둘러보니 시장기가 돌아 사전에 조사한 숯불 닭갈비냐 돈까스냐 서울불고기 집이냐 고민하다 서울 불고기에서 돼지갈비를 먹기로 하여 방문.

정릉시장 초입에 있는 서울 불고기집은 가정 양옥을 개조한 집이다.

가격은 대충 이러하다.

육회는 가격이 좀 나가고 돼지갈비가 300g에 15,000원
된장찌개는 2,000원 되신다.

아드님께선 돼지갈비를 드실 땐 항상 된장찌개 두부를 건져 밥과 함께 드신다.
나와는 식성이 정 반대다.
돈 아깝게시리 돈을 주고 된장찌개를 굳이?

돼지갈비 3인분을 주문하여 나왔는데 대부분 뼈가 붙어 있었다.
뼈 있는거 싫은데 -_- (아마 뼈 없는걸로만 달라 요청하면 가능할것이다. 대부분의 돼지갈비 집들이 그러하니)
고기도 약간 다른 집들과는 달랐다.
얇다고 해야 하나.. 그렇다고 중량이 적진 않으니 이점은 그저 취향의 차이

양배추 소스도 나오고

된장찌개도 나왔다.
주문 할 때 "두부 좀..."이라 말씀드리니 센스 있으시게 "아~ 많이요~ ^^" 이래주신다.
정말 두부가 많이 들어 있었다.
약간 아쉬운건 찌개 두부는 아닌것 같았... 

여하튼 고기를 얹고

굽고

구웠다.

창 안으로 햇빛이 비춰 먹음직스럽길래 사진도 여러장 찍었다.
사실 블로그 하려고 찍은건 아니었는데.
찍다보니 블로그에 올려야겠기에 더 찍었다.

전체적인 상차림은 대략 이렇다.
사진에 짤려 안 보이는데 마늘과 쌈장 그리고 동치미가 접시에 조금 나온다.

정말 솔직하게 식후감을 말하자면 막 맛집 그런건 아니다. 평범한 집이다.

아쉬웠던 점은 좁은 방에 테이블이 4개인가 있었는데 그 중 3테이블에서 고기를 굽느라 방안에 연기가 한 가득이었다.
일행은 눈이 아플 지경이었다 했다.
식사를 다 끝낼 때 쯤에서야 환풍기를 돌려주셨고 그래도 안되어서 창문도 열어주셔서... -_-a
1년 동안 마실 미세먼지를 다 마신것 같다.

정릉시장 구경갈 겸 돼지갈비로 식사하실 분은 방문하셔도 괜찮다.
서울페이(제로페이)가맹점이라 서울페이가 있는 분이라면 이용하시길
서울페이 되는집인데 막상 찾아가면 결제 못하는 집들 상당수 있는데 이 집은 된다.

위치와 정보는 네이버~
https://map.naver.com/p/search/%EC%A0%95%EB%A6%89%EC%8B%9C%EC%9E%A5%20%EC%84%9C%EC%9A%B8%EB%B6%88%EA%B3%A0%EA%B8%B0/place/38341807?placePath=?entry=pll&from=nx&fromNxList=true&searchType=place&c=15.00,0,0,0,dh

반응형
Posted by Hippalus
,

반응형

어지간해선 허경영이란 사람을 모르는 사람은 없을것이다.
매번 낙선을 거듭하지만 꾸준하게 대선에 출마하고 그때마다 내놓는 공약이 허황된 공약이라며 사람들에게 놀림을 넘어 손가락질을 받기만 했던 그의 공약.

무서운건 한심한건 그중 상당수 공약은 현실화가 되었다.
토요휴무제, 65세 이상 월 70만원 노인수당, 3천만원 출산수당, 1억원 결혼수당, 청년취업지원금 등

난 허경영의 공약을 보며 왠지 생텍쥐페리의 어린왕자의 한 에피소드가 떠오른다.

터키의 한 천문학자가 소행성 B612를 발견하고, 이를 학계에 보고했지만, 끝내 사실로 인정받지 못한다.
당시 천문학자가 입고 있었던 터키의 전통 복식 때문이었다.
나중에 그는 양복을 입고 다시 한 번 그 별의 좌표를 증명했고, 세계천문학회는 그제서야 그의 발견을 인정했다.

만약 허경영이 아닌 당시 유력했던 거물급 정치인이 발표하였다면 군중은 어떻게 반응했을까 싶다.

요즘 발표되는 정책들은 청년을 위한 정책들로 대홍수를 이룬다.
과연 이 땅의 청년들만 고되고 암울하고 부족한 것일까 물어보고 싶다.
길거리 아무 누구나 붙잡고 요즘 힘드시죠? 라 물으면 백이면 이백 모두 "아 힘들어요 ㅜㅜ" 라 답하지 않을 사람이 있겠는가.

그럼에도 불구하고 왜 청년들에게 온갖 복지와 지원 정책이 쏟아지는가
다 인구와 관련되어 있다.

어차피 선거는 표로 결정되는 구조이니 당연히 MZ세대와 그의 부모 세대의 인구가 차지하는 비율을 보면 납득이 간다.

표는 그렇다 치고 미래를 위해 생각해보자.

요즘 인구 소멸이 사회적 문제로 거론되고 있다.
청년들이 결혼과 출산을 꺼려하는데 그 이유는 과열경쟁으로 쓴맛을 본 청년들이 똑같은 삶을 넘겨주기 싫어하기 때문이다.
상황이 이러하니 정부에선 기껏 내놓은 정책이 청년들에게 돈 몇 푼 쥐어주고 영화 문화 생활 하라 등떠미는 수준인데 그렇다 한들 그들이 안 하던 결혼을 하고 안하던 출산을 하겠는가?
대가리를 굴려도 최소한 상대가 몇년은 속을 만큼 대가리를 굴려 정책을 내놔야지 
이따위 정책들은 내놔봐야 체리피커 성격의 정책 딱 그 수준일 뿐이다.

그럼 어쩌자란 말인가?
허경영처럼 당시엔 허황된 급진적인 정책일지라도 방향타를 꺾어 버리지 않고선 답이 없다.
한국인의 평범한 삶의 궤적은 알다시피 태어나서 어린이집 다니다 유치원 그리고 초중고 내내 학원으로 절어 살다 대학가고 초봉 월 2~300이냐 월 4~500이냐로 인생이 결정난다.
한 번 중소로 시작하면 계속 중소고 한 번 공기업, 대기업으로 시작하면 계속 안정된(?) 삶이 이어진다.
그러니 경쟁에 내몰리고 밤 10시 11시까지 학원질 하다 시장에 나온 애들은 현실이 냉혹하다 못해 불공정해 보인다.
본전 생각이 간절해진다.
난 똑똑한데 저 무능한 자들은 윗자리에 버티며 월급이나 축내고 부당한 지시를 내린다 착각한다.
그러니 헛된 공정을 부르짖고 성별 갈등은 기본이고 세대 간 갈등이 발생한다. 

결국 문제의 시발점인 사교육 철폐 말고는 답이 없다.
사교육에 부모들은 허리가 거꾸로 접히고(최근 발표된 기술 폴더폰은 거꾸로 뒤집힌다더라 기술의 발전이 놀랍도록 닮았다.) 아이들은 경쟁에 올인하고 돈 버는건 불안을 부추기는 사교육 시장이니 돈의 흐름이 자유롭지 못하다.
그렇게 개고생을 한들 한정된 고급 일자리는 어차피 뱁새들에겐 무지개 끝 황금단지일 뿐이다.

그럼 사교육 없이 고급 일자리는 어떻게 가란 말인가?
답은 간단하다.
계층간 이동 사다리를 걷어 차버리면 된다.
너나 나 말고 쟤가 가면 된다.
대신 쟤가 너와 나를 먹여 살리면 된다.
(어쩌면 너가 쟤일수도 있겠다.)
저~ 유럽의 어느 먼 나라처럼 세금은 많이 걷고 어차피 고급 일자리는 엘리트로 채워지고 있는 그 나라처럼 말이다.
다들 가고싶어 하는 삼성도 천재 1명이 10만명 먹여 살린다하지 않았던가?

하지만 사교육의 꿀맛을 본 자들은 이런저런 이유를 들먹이며 절대 동의하지 않는다.
그러니 다함께 인구 소멸을 받아들이자!~

끝으로 
인구절벽을 넘어 인구 소멸이 현실화 되고 있는 요즘 앞서 현실화 되었던 그의 허황된 공약들 중 유력한 공약은
국회의원 100명 감축, 징병제 폐지 및 모병제 전환, 경기도 전체를 서울로 편입, 충남·충북강원을 합쳐 ‘충강도’, 경북·전북을 합쳐 ‘경전도’ 전남·경남을 합쳐 ‘전경도’로의 통합 처럼 인구 소멸로 인해 자연스럽게 현실화 될 것이 유력해 보인다.

반응형
Posted by Hippalus
,

반응형

아이폰 앱스토어에 심사를 제출하려면 이런게 뜬다.

수출 규정 관련 문서가 누락이라니 뭔 소리여
그냥 관리 눌러주고 나오는 팝업이 나오는데
뭔 요상한 암호냐 싶지만 그냥 마지막 위에 언급된 알고리즘에 모두 해당하지 않음을 선택하면 된다.

매번 이러기 싫다면 프로젝트의 Info.plist 파일에서 아래와 같이 필드를 추가해 주면 된다.

앱스토어든 구글 플레이스토어든 매번 이상한 기준을 열심히 마련하고 강요해대는데 법적으로 이슈가 생겨서 그런건 알겠지만 매번 느끼지만 너무 불친절하다.

반응형
Posted by Hippalus
,

반응형

즐겨찾기 해놓은 sessions(서버)리스트에서 마우스 우측을 눌러 Edit session 메뉴를 호출하자

그러면 저렇게 덩거러니 빈 화면이 나오는데 여기서 Advanced SSH settings 탭을 누른다.

그리곤 Execute command에 아래와 같이 입력해준다.
export TMOUT=0
이어서 우측에 Do not exit after command ends 체크박스에도 체크를 해준다.


그리곤 OK를 눌러 저장 후 재접속 하여 사용하면 된다.




반응형
Posted by Hippalus
,

반응형


VSCode의 좌측 하단의 톱니바퀴를 눌러서 검색에서 tab size를 입력하고 숫자를 변경하라던데 아무리 해봐도 안되더라

그냥 편집기 상태에서 우측 하단에 보면 저렇게 공백: 4라고 보일것이다. (숫자는 각자 상황에 따라 다름)

공백 부분을 클릭해주면 아래처럼 상단에 메뉴가 뜬다.
여기서 공백을 사용한 들여쓰기를 눌러준다.

그리고 원하는 탭의 크기를 선택해주자.

난 space 4개는 있어야 한다. 
속이 다 시원하다.






반응형
Posted by Hippalus
,

반응형

일단 root 권한으로 접속을 하자.
su 입력 후 관리자 비번을 입력하면 요렇게 접속이 된다.

(반대로 이전 이용자로 돌아가려면 su - [아이디] 엔터로 복귀 가능하다.)

root권한을 획득 하였으면 lsof를 설치하자.
내 리눅스는 레드헷 계열이므로 
sudo yum install lsof 

설치가 됐다면 이제 사용중인 포트로 조회가 가능하다.

lsof -i :8976


요롷게 프로세스 ID (PID)가 나타난다.
이걸 죽여는 명령어는 아래와 같다.
kill -9 <프로세스ID>

프로세스 ID가 15083이니까
kill -9 15083 을 입력하면 되겠다.

반응형
Posted by Hippalus
,

반응형

Node.js로 FCM 푸시 서버를 만들어 항상 백그라운드에서 동작하도록 하려면 여러 가지 방법이 있다. 
가장 일반적인 방법은 forever나 pm2와 같은 프로세스 관리 도구를 사용하는 것으로 이러한 도구를 사용하면 서버가 비정상적으로 종료되더라도 자동으로 다시 시작되도록 설정할 수 있다.

일단 pm2를 전역으로 설치한다.
이때 반드시 su 계정으로 로그인하여야 한다.
다시 일반 계정으로 복귀하고자 한다면 su - 일반계정이름 엔터를 치면 된다.

npm install -g pm2
그런 다음, Node.js 애플리케이션을 pm2로 실행할 수 있다.

bash
Copy code
pm2 start your_fcm_server.js
이제 your_fcm_server.js는 백그라운드에서 계속 실행된다.

만약 서버를 중지하려면 다음 명령어를 사용한다.
pm2 stop your_fcm_server.js

또는 모든 프로세스를 중지하려면
pm2 stop all

더 나은 안정성을 위해, 서버가 리부팅될 때 자동으로 시작되도록 만들 수 있다.
이를 위해서는 다음 명령어를 실행한다.

pm2 startup
이 명령어를 실행하면 pm2가 서버 리부팅 시에도 자동으로 시작되도록 설정된다.
이렇게 하면 Node.js 애플리케이션이 항상 백그라운드에서 실행되도록 할 수 있다.

기본적으로 pm2는 로그와 관련된 다양한 기능을 제공하므로, 서버의 상태를 모니터링하고 문제를 디버깅하는 데 도움이 된다.
pm2 logs

특정 프로세스의 로그만 확인하려면 프로세스 이름 또는 ID를 지정할 수 있다.

pm2 logs your_fcm_server

로고 출력 설정:
pm2에서는 로그의 출력을 여러 가지 형식으로 설정할 수 있다.
예를 들어, JSON 형식으로 출력하려면 다음과 같이 명령어를 사용한다.

pm2 logs --json

로그 위치 확인
pm2는 각 프로세스의 로그를 파일로 저장한다. 
로그 파일은 기본적으로 ~/.pm2/logs/ 디렉토리에 저장되며, 특정 프로세스의 로그 파일 위치를 확인하려면 다음과 같이 명령어를 사용한다.

pm2 show your_fcm_server
이 명령어는 프로세스의 상세 정보를 보여주는데, 그 중에서 "log_path" 항목이 로그 파일의 경로를 나타낸다.

로그 파일을 삭제하려면 pm2 flush 명령어를 사용한다.
pm2 flush

실시간 로그 모니터링 중지인 
pm2 logs 명령은 실시간 로그 모니터링을 위한 것이기 때문에 Ctrl+C를 누르면 모니터링이 중지된다.

반응형
Posted by Hippalus
,

반응형

SVN으로 형상관리시 수정된 또는 수정할 소스를 충돌현상이 발생할 경우 

먼저 대상 소스를 마우스 우클릭

Team > Synchronize with Repository 선택


update or commit시 충돌인 conflict가 발생하게 된다.

이때 
Override and Update는 SVN 서버의 소스를 내 로컬 소스로 overwrite (SVN소스가 오리지널)
Override and commit는 내 로컬 소스를 SVN으로 overwrite (내소스가 오리지널)

반응형
Posted by Hippalus
,