diff --git a/README.md b/README.md index 5a5c32e..a8265ef 100644 --- a/README.md +++ b/README.md @@ -15,13 +15,13 @@ sources in text w/ formatting in markdown conventions ## 2023 -Wed April 26th, 2023 - [**Query the (Open) Ethereum Blockchain (Database) with Contract Services**](https://github.com/viennacrypto/viennacrypto.github.io/tree/master/ethers) - Using Strongly-Typed Application Binary Interfaces (ABIs) With ethers.js (v6) Via JSON-RPC @ Vienna.js +Wed April 26th, 2023 - [**Query the (Open) Ethereum Blockchain (Database) with Contract Services**](ethers.md) - Using Strongly-Typed Application Binary Interfaces (ABIs) With ethers.js (v6) Via JSON-RPC @ Vienna.js Tue March 28th, 2023 - [**Inside Ordinal Inscriptions - Turn the Blockchain Into A Database For Digital Artefacts**](https://github.com/pixelartexchange/ordinals.sandbox/tree/master/insideordinals) @ Technologieplauscherl LXXX (Linz, Austria) -Wed March 8th, 2023 - [**GoReleaser In Action - Deliver Go Binaries As Fast and Easily As Possible (For Windows, Mac, Linux & Co.) Via GitHub Actions (Workflow)**](https://github.com/pixelartexchange/artbase.server/tree/master/goreleaser) @ Vienna.go +Wed March 8th, 2023 - [**GoReleaser In Action - Deliver Go Binaries As Fast and Easily As Possible (For Windows, Mac, Linux & Co.) Via GitHub Actions (Workflow)**](goreleaser.md) @ Vienna.go @@ -42,46 +42,49 @@ https://github.com/cryptopunksnotdead/punkbase/tree/master/insidepunkbase) @ Sta ## 2019 -Wed May 15th, 2019 - [**JavaScript in 2019 - Teach Yourself Web Programming in ~24 Hours~ 10 Minutes**](https://github.com/geraldb/talks/blob/master/javascript2019.md) @ Inhouse (Private) +Wed May 15th, 2019 - [**JavaScript in 2019 - Teach Yourself Web Programming in ~24 Hours~ 10 Minutes**](javascript2019.md) @ Inhouse (Private) Tue April 30th, 2019 - -[**Contract Scripting for Everyone: (Hyperledger) Car Registration Sample - From Go Chaincode to (Secure) Ruby Contract Script**](https://github.com/geraldb/talks/blob/master/fabcar.md) -@ [Vienna Hyperledger Meetup](https://meetup.com/Hyperledger-Vienna/events/260252086) +[**Contract Scripting for Everyone: (Hyperledger) Car Registration Sample - From Go Chaincode to (Secure) Ruby Contract Script**](fabcar.md) +@ Vienna Hyperledger Meetup Thu April 4th, 2019 - -[**The State of Bool - Everything You Never Wanted to Know**](https://github.com/geraldb/talks/blob/master/bool.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) - +[**The State of Bool - Everything You Never Wanted to Know**](bool.md) +@ Vienna Ruby Meetup Tue March 12th, 2019 - -[**Contracts, Contracts, Contracts - Code Your Own (Crypto Blockchain) Contracts w/ Ruby (sruby), Universum & Co**](https://github.com/geraldb/talks/blob/master/contracts.md) -@ [Vienna Crypto Programming Meetup](https://viennacrypto.github.io) +[**Contracts, Contracts, Contracts - Code Your Own (Crypto Blockchain) Contracts w/ Ruby (sruby), Universum & Co**](contracts.md) +@ Vienna Crypto Programming Meetup + ## 2018 Thu October 18th, 2018 - -[**Mining for Gold Using the World's #1 and Most Popular Data Format**](https://github.com/geraldb/talks/blob/master/csv.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +[**Mining for Gold Using the World's #1 and Most Popular Data Format**](csv.md) +@ Vienna Ruby Meetup Wed June 20th, 2018 - -[**Stay Static - Build Static Websites w/ VuePress (and Text with Formatting Conventions in Markdown)**](https://github.com/geraldb/talks/blob/master/vuepress.md) -@ [Vienna Vue.js Meetup](https://meetup.com/Vue-js-Vienna/events/249255348) +[**Stay Static - Build Static Websites w/ VuePress (and Text with Formatting Conventions in Markdown)**](vuepress.md) +@ Vienna Vue.js Meetup + Wed April 11th, 2018 - -[**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in Go from Zero (Scratch)**](https://github.com/geraldb/talks/blob/master/blockchain_go.md) -@ [Vienna Go Meetup](https://meetup.com/vienna-go-Vienna-Go-User-Group/events/248920971) +[**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in Go from Zero (Scratch)**](blockchain_go.md) +@ Vienna Go Meetup + Tue March 13th, 2018 - -[**Blockchain vs (Hyper) Ledger -- Inside (Hyper) Ledger Lite - Add Transactions One Block at a Time and Balance the Accounts (Books)**](https://github.com/geraldb/talks/blob/master/hyperledger.md) -@ [Hyperledger Vienna](https://meetup.com/Hyperledger-Vienna/events/246847194) +[**Blockchain vs (Hyper) Ledger -- Inside (Hyper) Ledger Lite - Add Transactions One Block at a Time and Balance the Accounts (Books)**](hyperledger.md) +@ Hyperledger Vienna + +Mon March 12th, 2018 - [**Build (Online) Presentations / Talks (and Handout Notes) with (Structured) Text with Formatting in Markdown Markup Conventions and (Off-the-Shelf Open Free) Slide Design Themes (Reveal.js, Bespoke.js, Impress.js, Shower.js, S6, ...) and the Jekyll (Static) Website Compiler**](slideshow-s9.md) +@ Austria.TXT Meetup -Mon March 12th, 2018 - [**Build (Online) Presentations / Talks (and Handout Notes) with (Structured) Text with Formatting in Markdown Markup Conventions and (Off-the-Shelf Open Free) Slide Design Themes (Reveal.js, Bespoke.js, Impress.js, Shower.js, S6, ...) and the Jekyll (Static) Website Compiler**](https://github.com/geraldb/talks/blob/master/slideshow-s9.md) -@ [Austria.TXT Meetup](https://github.com/austriacodes/austria.txt) -Thu March 8th, 2018 - [**Build (Online) Books and Documentation with Markdown and Octobook Themes and the Jekyll (Static) Website Compiler - Incl. Yuki & Moto Press Bookshelf Case Study**](https://github.com/geraldb/talks/blob/master/octobook.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +Thu March 8th, 2018 - [**Build (Online) Books and Documentation with Markdown and Octobook Themes and the Jekyll (Static) Website Compiler - Incl. Yuki & Moto Press Bookshelf Case Study**](octobook.md) +@ Vienna Ruby Meetup @@ -89,21 +92,22 @@ Thu March 8th, 2018 - [**Build (Online) Books and Documentation with Markdown an ## 2017 -Thu December 7th, 2017 - [**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in Ruby from Zero (Scratch)**](https://github.com/geraldb/talks/blob/master/blockchain_ruby.md) • +Thu December 7th, 2017 - [**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in Ruby from Zero (Scratch)**](blockchain_ruby.md) • [(Slides)](http://slideshow-s9.github.io/demos/blockchain_ruby.html), [(Print)](http://slideshow-s9.github.io/demos/blockchain_ruby.pdf.html) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +@ Vienna Ruby Meetup Mon November 13rd, 2017 - [**Build Blazing Fast (Static) Websites with GraphQL (and Gatsby)**](gatsby2.md#whats-graphql) • [(Slides)](http://slideshow-s9.github.io/demos/gatsby2.html), [(Print)](http://slideshow-s9.github.io/demos/gatsby2.pdf.html) -@ [GraphQL Vienna Meetup](https://meetup.com/GraphQL-Vienna/events/243984437) +@ GraphQL Vienna Meetup Wed September 27th, 2017 - -[**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in JavaScript from Zero (Scratch)**](https://github.com/geraldb/talks/blob/master/blockchain.md) • +[**Blockchain! Blockchain! Blockchain! - Build Your Own Blockchains in JavaScript from Zero (Scratch)**](blockchain.md) • [(Slides)](http://slideshow-s9.github.io/demos/blockchain.html), [(Print)](http://slideshow-s9.github.io/demos/blockchain.pdf.html) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/236300243) +@ Vienna JavaScript Meetup + Wed September 20th, 2017 - [**Progressive Web Apps (PWAs) and Lighthouse - From Responsive to Mobile to Offline First Design**](progressive.md) @@ -111,33 +115,34 @@ Wed September 20th, 2017 - Thu September 14th, 2017 - [**JSON - What's Next for the No 1. Universal (Non-Binary/Human) Data Exchange Format**](jsonnext.md) -@ [Microservices Vienna Meetup](https://meetup.com/microservices-vienna/events/241960207) +@ Microservices Vienna Meetup Tue September 5th, 2017 - [**Gastsby 1.0 - Build Single-Page Static Websites in React w/ Gatsby and GraphQL**](gatsby2.md) -@ [React (JavaScript) Vienna Meetup](https://meetup.com/ReactVienna/events/242821292) +@ React (JavaScript) Vienna Meetup Tue July 4th, 2017 - [**Quik - The Missing Project Scaffolder for Ruby - Quick Start Your Ruby Gems, Your Sinatra Apps, Your Jekyll Sites 'n' More**](quik.md) -@ [Ruby Linz Meetup](https://meetup.com/Ruby-User-Group-Linz-RUGL/events/240388912) +@ Ruby Linz Meetup Thu June 8th, 2017 - [**Meet Jason Feed - The New Web Feed & Syndication Guy (Ruby Edition)**](webfeeds2.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +@ Vienna Ruby Meetup Wed May 31st, 2017 - [**Meet Jason Feed - The New Web Feed & Syndication Guy (JavaScript Edition)**](jsonfeed.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/236300238) +@ Vienna JavaScript Meetup Wed May 17th, 2017 - [**Building Static Websites with Jigsaw 'n' Blade (in PHP)**](jigsaw.md) -@ [Laravel (PHP) Vienna Meetup](https://meetup.com/Laravel-Frameworkers-Vienna/events/237725787) +@ Laravel (PHP) Vienna Meetup + Fri May 5th, 2017 - [**The World Factbook - Explore the World with Free Open Public Domain Datasets**](factbook.md) -@ [Linuxwochen Wien '17](http://www.linuxwochen.at/Wien) +@ Linuxwochen Wien '17 Free Open Public Domain Data :: 250+ Country Profiles (Incl. Flags 'n' Maps) @@ -156,7 +161,7 @@ Wed April 19th, 2017 - Thu April 6th, 2017 - [**New Horizons - Build Your Own (Static) Planet News Site with Pluto (and Ruby)**](planet.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +@ Vienna Ruby Meetup The talk covers how to read web feeds in ruby w/ the standard rss module and 3rd party libraries such as the universal feedparser gem and @@ -170,11 +175,12 @@ wrap up discussing the future of planet ruby. Wed March 29th, 2017 - [**factbook.json - How to model the world with JavaScript**](factbook.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/230066469) +@ Vienna JavaScript Meetup Wed March 15th, 2017 - [**Jekyll vs Middleman - Build static websites with Ruby**](jekyll_vs_middleman.md) -@ [Ruby Linz Meetup](https://meetup.com/Ruby-User-Group-Linz-RUGL/events/237342046) +@ Ruby Linz Meetup + ## 2016 @@ -182,34 +188,36 @@ Wed March 15th, 2017 - Thu November 17th, 2016 - Part I) [**factbook.json - Turn the World Factbook into Open (Structured) Data**](factbook.md) Part II) [**factbook.json - Using Git (and GitHub) for (Publishing) Data**](git_for_data.md) -@ [Vienna Open Data Meetup](https://meetup.com/Open-Knowledge-Oesterreich/events/233208866) +@ Vienna Open Data Meetup Thu September 22nd, 2016 - [**Building Static Websites with Jigsaw 'n' Blade (in PHP)**](jigsaw.md) -@ [Vienna PHP Meetup](https://meetup.com/viennaphp/events/232763541) +@ Vienna PHP Meetup Wed August 31rd, 2016 - [**Building static websites with the Great Gatsby and React.js web components**](gatsby.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/230515294) +@ Vienna JavaScript Meetup + Thu August 11th, 2016 - Part I) [**Building static websites with Metalsmith**](metalsmith2.md) Part II) [**Building static websites with Gatsby**](gatsby.md) -@ [Stahlstadt JavaScript Linz Meetup](https://meetup.com/stahlstadt-js/events/232729094) +@ Stahlstadt JavaScript Linz Meetup Wed July 20th, 2016 - [**The New New JavaScript / ECMAScript (ES6, ES7, ES8)**](es6.md) @ Inhouse (Private) Wed July 13rd, 2016 - [**Stay Static - Build Single-Page Websites with the Great Gatsby**](gatsby.md) -@ [React (JavaScript) Vienna Meetup](https://meetup.com/ReactVienna/events/232438531) +@ React (JavaScript) Vienna Meetup Thu June 9th, 2016 - [**Stay Static - Build Static Websites with Hugo and the Go Template Language**](gohugo.md) -@ [Vienna Go Meetup](https://meetup.com/Vienna-Golang-Meetup/events/230458823) +@ Vienna Go Meetup -Sat April 30th, 2016 @ [Linuxwochen Wien '16](http://www.linuxwochen.at/Wien) + +Sat April 30th, 2016 @ Linuxwochen Wien '16 I) [**The New HTML - Markdown - Use Plain Text for Websites, Presentations and Books**](markdown.md) @@ -226,11 +234,12 @@ In 2016 you can get pretty far with just HTML, JS and CSS. The talk shows how to Tue March 8th, 2016 - [**Building Static Websites with Metalsmith (+Handelbars/Nunjucks)**](metalsmith2.md) -@ [Node (JavaScript) Vienna Meetup](https://meetup.com/nodejs-vienna/events/228638709) +@ Node (JavaScript) Vienna Meetup + Thu March 3rd, 2016 - [**Stay Static - Jekyll vs. Middleman - Build Static Websites with Ruby**](jekyll_vs_middleman.md) -@ [Vienna Ruby Meetup](https://viennarb.github.io) +@ Vienna Ruby Meetup Wed March 2nd, 2016 - @@ -241,13 +250,14 @@ Wed March 2nd, 2016 - Thu October 15, 2015 - [**Dr. Jekyll and Mr. Hyde: The Missing Theme Package Manager & Quick Start Script Wizard**](drjekyll.md) -@ [Vienna Ruby Meetup](https://meetup.com/vienna-rb/events/225097350) +@ Vienna Ruby Meetup Wed September 30, 2015 - [**Add (Deep) Anchor Links to Your Website**](anchor.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/220339170) +@ Vienna JavaScript Meetup + -Fri May 8th, 2015 @ [Linuxwochen Wien '15](http://www.linuxwochen.at/Wien) +Fri May 8th, 2015 @ Linuxwochen Wien '15 I) **Building Websites, Blogs, Books w/ Static Site Generators** @@ -277,11 +287,11 @@ Join to learn more and discuss the state of open data with a focus on practical Wed August 27th, 2014 - [**Building Your Own Web Components (Tags / Elements)**](webcomponents2.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/135052012) +@ Vienna JavaScript Meetup -Sat May 10th, 2014 @ [Linuxwochen Wien '14](http://www.linuxwochen.at/Wien) +Sat May 10th, 2014 @ Linuxwochen Wien '14 I) **Use Markdown for Websites, Presentations and Books** @@ -298,7 +308,7 @@ What's the state of open data for the World Cup? And football in general? What o Wed April 30th, 2014 - [**Using Open Football Data - Get Ready for the World Cup in Brazil w/ JavaScript**](open_data_world_cup_with_js.md) -@ [Vienna JavaScript Meetup](https://meetup.com/viennajs/events/126159362) +@ Vienna JavaScript Meetup @@ -308,7 +318,7 @@ Mon Oct 7th, 2013 - [**(J)Ruby in Action - Web Apps w/ Rails 'n' Jetty"**](jruby_web_apps.md) @ Java Austria -Fri May 3rd, 2013 @ [Linuxwochen Wien '13](http://www.linuxwochen.at/Wien) +Fri May 3rd, 2013 @ Linuxwochen Wien '13 **football.db - Using Open Football Data** diff --git a/ethers.md b/ethers.md new file mode 100644 index 0000000..d6da081 --- /dev/null +++ b/ethers.md @@ -0,0 +1,940 @@ +# Query the (Open) Ethereum Blockchain (Database) with Contract Services + +using strongly-typed application binary interfaces (ABIs) with ethers.js (v6) via JSON-RPC + + + +Abstract: + +I am a no-coiner (HODLing 0 ethers) and a (big) fan of open data / transactions / art. +There's lot of misunderstandings of blockchains and crypto - +this talk shows how you can use the ethers.js library to query ("on-chain") +contract services on ethereum (for free). + +The ABI (application binary interface) - "serialized" in JSON - for contract services +is kind of emerging as a new (open) standard / spec for (yes, strongly-typed) apis +(that you can use in any programming language incl. - of course - javascript). +Learn the difference between "on-chain" and "off-chain" tokens +or how to query for "on-chain" (generative) art and much more. + + + + +## Ethers.js v5 vs v6? What's News? + +> Big Numbers +> +> One of the biggest changes in v6 is that the BigNumber +> class has been replaced with the built-in ES2020 BigInt +> offered by modern JavaScript environments. +> +> There is plenty of online documentation to get you started with JavaScript ES2020 BigInt. +> Keep in mind, just like BigNumber, a ES2020 BigInt can only operate on integers. + + + +## Numbers in JavaScript + +No Integer! All Numbers are (64-Bit) Double Precision Floating Point Numbers +(w/ 52 bits to represent the mantissa) + + +![](i/double-precision-number.png) + +(Source: [Double-precision floating-point format @ Wikipedia](https://en.wikipedia.org/wiki/Double-precision_floating-point_format)) + + + +Max (biggest) integers safely to represent between `-(2^53 – 1)` and `2^53 – 1` + + +``` js +Number.MAX_SAFE_INTEGER +//=> 9007199254740991 + +2**53-1 +//=> 9007199254740991 +``` + + + +## Money, Money, Money + + +Best Practice - Use Integers Only (For Calculations) + +Euro 5.99 change to 599 cents + +1 Euro == 100 Cents (10^2) + + + +Triva Quiz + +Bitcoin 5.99 change to ___ sat(oshis) + +Ether 5.99 change to __ wei + +- 1 Bitcoin == ____ Sat(oshis) (10^ __ ) +- 1 Ether == ____ Wei (10^ __ ) + +
+Answer + 5990000000000000000n +``` + +
+ + + + +## Before BigInt + +``` js +10**18 +//=> 1000000000000000000 + +(10**18)+1 // or (10**18)+2 ... +//=> 1000000000000000000 - FAIL!! +``` + +Notice the suffix n (for BigInt) + +``` js +(10n**18n)+1n +//=> 1000000000000000001n - SUCCESS!! +``` + +Note: You CANNOT mix & match numbers and bigint in calculations - bigint calculations only work with bigints. +e.g. `(10n**18)+1` +Otherwise you get: + +> Error: Cannot mix BigInt and other types, use explicit conversions + + +However, you CAN compare numbers and bigints as usual: + +``` js +1n < 2; // true +2n > 1; // true +2 > 2; // false +2n > 2; // false +2n >= 2; // true +``` + +Beware - about strictly vs loosly equal number and bigints: + +``` js +0n === 0; // false +1n === 1; // false + +0n == 0; // true +1n == 1; // true +``` + + +Bigint "Convenience" Helper Functions - works with Number, String, Hex, Octal & Bin + + +``` js +const hugeNum = BigInt(9007199254740991); +//=> 9007199254740991n +``` +Note: Number - remember - only up-to Number.MAX_INTEGER! that is 9007199254740991 (2^53-1) + + +``` js +const hugeString = BigInt("9007199254740991"); +//=> 9007199254740991n + +const hugeHex = BigInt("0x1fffffffffffff"); +//=> 9007199254740991n + +const hugeOctal = BigInt("0o377777777777777777"); +//=> 9007199254740991n + +const hugeBin = BigInt("0b11111111111111111111111111111111111111111111111111111"); +//=> 9007199254740991n +``` + +or use literals + +``` js +const hugeHex = 0x1fffffffffffffn; +//=> 9007199254740991n + +const hugeOctal = 0o377777777777777777n; +//=> 9007199254740991n + +const hugeBin = 0b11111111111111111111111111111111111111111111111111111n; +//=> 9007199254740991n +``` + + + +## BigInt - Can I Use? + +BigInt added in ES2020 (ES11) + +![](i/bigint-compat.png) + + +Or see + + + +## The "Magic" of Private/Public Key Cryptography is Big Integer Numbers + +How Big (in Bits) Is Safe & Secure For Elliptic Curve Cryptography (ECC)? + + +Triva Quiz - Private Keys (in Bitcoin, Ethereum, etc.) Are Big Integer Numbers - Q: How Big? + +- (A) 128-Bit +- (B) 256-Bit +- (C) 512-Bit +- (D) 1024-Bit +- __ Other, Please Tell + + + +``` js +2n**256n-1n +//=> 115792089237316195423570985008687907853269984665640564039457584007913129639935n + +// as hexstring (64 chars) +0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffn // or +BigInt( "0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff" ) +//=> 115792089237316195423570985008687907853269984665640564039457584007913129639935n +``` + + +If you ask - How big (or how safe) is a (random) 256-bit / 32 byte integer number? + +- How many sand grains on the beach? +- How many sand grains on earth? +- How many atoms in the universe? + +Yes, 256-bit is that big - there aren't enough atoms in the universe (squared). + + + +Aside - Elliptic What? + +> Elliptic-curve cryptography (ECC) is an approach to public-key cryptography +> based on the algebraic structure of elliptic curves over finite fields. +> +> (Source: [Elliptic-curve cryptography @ Wikipedia](https://en.wikipedia.org/wiki/Elliptic-curve_cryptography)) + + +Why not "classic" and "military-grade" RSA (Rivest–Shamir–Adleman) public-key cryptography? +How big (in bits) is safe? + +> RSA keys are typically 1024 to 4096 bits long. +> In 2003, RSA Security estimated that 1024-bit keys were likely to become crackable by 2010. +> As of 2020, it is not known whether such keys can be cracked, +> but minimum recommendations have moved to at least 2048 bits. +> It is generally presumed that RSA is secure if n is sufficiently large, +> outside of quantum computing. +> +> (Source: [RSA cryptosystem @ Wikipedia](https://en.wikipedia.org/wiki/RSA_(cryptosystem))) + + + + +## ethers.js Uses Noble Crypto(graphy) JS Libraries by Paul Milller + +Article - Learning fast elliptic-curve cryptography (ECC) [in JavaScript/TypeScript with BigInts] +see + +Live Demo - Elliptic curve (point) calculator +see + + +--- + + + + +## Getting Started w/ ethers.js + + + + +## History - Programming Ethereum (or is it Web 3.0?) with JavaScript API + + +web3.js - First (and original) library - still available (and in use) - see + +ethers.js - New (cool) kid in town by [Richard Moore](https://github.com/ricmoo) (Toronto, Canada) - "One-Man Show" + + + + + +## ethers.js - The official project summary / readme blurb + + +> A complete, compact and simple library for Ethereum and ilk, written in TypeScript. +> +> **Features** +> +> - Keep your private keys in your client, **safe** and sound +> - Import and export **JSON wallets** +> - Import and export BIP 39 **mnemonic phrases** (12 word backup phrases) and **HD Wallets** (English as well as Czech, French, Italian, Japanese, Korean, Simplified Chinese, Spanish, Traditional Chinese) +> - Meta-classes create JavaScript objects from any contract ABI, including **ABIv2** and **Human-Readable ABI** +> - Connect to Ethereum nodes over [JSON-RPC](https://github.com/ethereum/wiki/wiki/JSON-RPC), [INFURA](https://infura.io), [Etherscan](https://etherscan.io), [Alchemy](https://alchemyapi.io), [Ankr](https://ankr.com) or [MetaMask](https://metamask.io) +> - **ENS names** are first-class citizens; they can be used anywhere an Ethereum addresses can be used +> - **Tiny** (~120kb compressed; 400kb uncompressed) +> - **Tree-shaking** focused; include only what you need during bundling +> - **Complete** functionality for all your Ethereum desires +> - Extensive [documentation](https://docs.ethers.org/v6/) +> - Large collection of **test cases** which are maintained and added to +> - Fully written in **TypeScript**, with strict types for security +> - **MIT License** (including ALL dependencies); completely open source to do with as you please +> +> (Source: [ethers-io/ethers.js @ GitHub](https://github.com/ethers-io/ethers.js)) + + + +## ethers.js - Getting Started w/ Node.js + +``` +$ npm install ethers +$ npm ls --all + +`-- ethers@6.3.0 + +-- @adraffy/ens-normalize@1.9.0 + +-- @noble/hashes@1.1.2 + +-- @noble/secp256k1@1.7.1 + +-- aes-js@4.0.0-beta.3 + +-- tslib@2.4.0 + `-- ws@8.5.0 + +-- UNMET OPTIONAL DEPENDENCY bufferutil@^4.0.1 + `-- UNMET OPTIONAL DEPENDENCY utf-8-validate@^5.0.2 +``` + + + + +## Query for Token Contract Basics + +- name +- symbol +- totalSupply + +using + + +``` +function name() view returns (string) +function symbol() view returns (string) +function totalSupply() view returns (uint256) +``` + + + + +## Query for Token Contract Basics (Cont.) + +No ethereum accounts (or ether) needed for read-only (query) contract access. + +All data is public (incl. data declared "private" in code). + +All contract functions / methods are always strongly-typed. + +AND require / follow an application binary interface +(for data encoding/decoding - big endian vs little endian etc.). + + + + +## Token Basics - Via JSON-RPC Using ethers.js + + +``` js +import { ethers } from "ethers"; // Import everything + +console.log( `Hello, ethers.js ${ethers.version}!` ); +//=> Hello, ethers.js 6.3.0! + +const provider = new ethers.JsonRpcProvider( "https://mainnet.infura.io/v3/" ); +``` + +**Blockchain JSON-RPC Provider Options** + +Option 1) +You can run your own local (ethereum) blockchain node (e.g. geth). + +Option 2) +Easier to get started with third-party provider +e.g. Infura, Alchemy, QuickNode, and many more. + +Requires (free) sign-up for API key. + + + + +## Contract №1 - Token Basics - Via JSON-RPC Using ethers.js (Cont.) + + +``` js +const abi = [ + "function name() view returns (string)", + "function symbol() view returns (string)", + "function totalSupply() view returns (uint256)", +]; + +const addr = '0x06012c8cf97bead5deae237070f9587f8e7a266d'; + +// Create a contract +const contract = new ethers.Contract( addr, abi, provider); + +const name = await contract.name(); +//=> CryptoKitties +const sym = await contract.symbol(); +//=> CK +const total = await contract.totalSupply(); +//=> 2022592n +``` + + + +**Q: What about (cryptokitties) token metadata (& image)?** + +A: It's still early ;-). SOON! +In theory, yes. KittBase contract incl. `function tokenMetadata(uint256 tokenId) view returns (string)` +In practice, the metadata contract (reference) is set to null address (0x0000000000000000000000000000000000000000). + +"Social" consensus ;-). Use: +- . +- +- ... +- + +resulting in: + +``` json +{"id":1, + "name":"Genesis", + "generation":0, + "genes":"626837621154801616088980922659877168609154386318304496692374110716999053", + "created_at":"2017-11-23T06:19:59.000Z", + "birthday":"2017-11-23T00:00:00.000Z", + "image_url":"https://img.cryptokitties.co/0x06012c8cf97bead5deae237070f9587f8e7a266d/1.png", + "image_url_cdn":"https://img.cn.cryptokitties.co/0x06012c8cf97bead5deae237070f9587f8e7a266d/1.png", + ... +} +``` + +![](i/kitty1.png) + + + +A classic crypto fraud - "own your kitties 100% forever!" - yeah, sure + + +reality - you do NOT own the kitty/cat image +and the metadata (& image) is "off-chain" and hosted on a classic "central" company web server. +What you "own" is the token (and the "on-chain" genes/dna - a 256-bit integer) +that you can sell to greater fools for (fun &) profit! + +Read the (hidden) fineprint - from the CryptoKitties License F.A.Q: + +> Dapper Labs, Inc. created [and owns] the art of your cryptokitty, +> and it's a big part of our brand. +> At the end of the day, businesses also need to have the right to make the big decisions [and the big $$$] about how the art gets used in a commercial setting. +> +> We reserve to ourselves the right to make bigger [and bigger] deals +> to help our business grow [and rake in all the $$$ for ourselves - of course]. +> +> [...] +> +> Q: What am I allowed to do with the art: +> +> - Use the Kitty art for your own personal, non-commercial use. +> +> Q: What am I NOT allowed to do with the art: +> +> - Modifying the art; +> - Using the art to market or sell products; +> - Trying to trademark your art, or otherwise acquire intellectual property rights in it. + + +=> "own your kitties 100% forever!" - the blockchain guarantees and says so ;-). + +Dapper Labs Inc. (Vancouver, Canada) - A Billion $$ Unicorn with "Blue-Chip" Venture Capital Investors & More + + + + + +## Contract №2 - "Off-Chain" Token Basics - Via JSON-RPC Using ethers.js + +Let's try another... add to abi ... + +- `function tokenURI(uint256 tokenId) view returns (string)` + +and let's query... Phree the Phunks ... + + + +``` js +const addr = '0xf07468ead8cf26c752c676e43c814fee9c8cf402'; + +const abi = [ + "function name() view returns (string)", + "function symbol() view returns (string)", + "function totalSupply() view returns (uint256)", + "function tokenURI(uint256 tokenId) view returns (string)", +]; + + +// Create a contract +const contract = new ethers.Contract( addr, abi, provider); + +const name = await contract.name(); +//=> CryptoPhunksV2 +const sym = await contract.symbol(); +//=> PHUNK +const total = await contract.totalSupply(); +//=> 10000n +``` + +**Q: What about token metadata (& image)?** + +Let's try... + + +``` js +const token0 = await contract.tokenURI( 0 ); +//=> ipfs://QmcfS3bYBErM2zo3dSRLbFzr2bvitAVJCMh5vmDf3N3B9X/0 + +const token1 = await contract.tokenURI( 1 ); +//=> ipfs://QmcfS3bYBErM2zo3dSRLbFzr2bvitAVJCMh5vmDf3N3B9X/1 + +... + +const token9999 = await contract.tokenURI( 9999 ); +//=> ipfs://QmcfS3bYBErM2zo3dSRLbFzr2bvitAVJCMh5vmDf3N3B9X/9999 +``` + +resulting in "off-chain" ipfs (InterPlanetary File System) links. + +Tip: Try an ipfs http gateway e.g. + +- +- +- ... +- + +resulting in: + +``` json +{"description":"Phunk #0", + "name":"Phunk #0", + "attributes":[{"trait_type":"Eyes","value":"Green Eye Shadow"}, + {"trait_type":"Ears","value":"Earring"}, + {"trait_type":"Hair","value":"Blonde Bob"}, + {"trait_type":"Sex","value":"Female"}], + "image_url":"https://gateway.pinata.cloud/ipfs/Qmazio5AkcBwNJByXHtbBk1hgnw4g1ADsYK369TSPLMqar/phunk0000.png"} +``` + + +![](i/phunk0.png) + + + + + +## (Blockchain) Contract Services - Strongly-Typed ABIs Available As JSON + +In theory you can write your blockchain contracts in any language. +In practice Solidity (JavaScript-like) is mostly used +and the definite (contract) ABI spec is + + + + +**From Solidity To (Contract) ABI JSON** + +The solc (solidity ompiler) generates / compiles the contract source(s) +into a binary [blob] AND the ABI in JSON e.g. + +``` json +{"type": "function", + "name": "name", + "constant": true, + "payable": false, + "stateMutability": "view", + "inputs": [], + "outputs":[{"name":"","type":"string"}] +}, +{"type": "function", + "name": "symbol", + "constant": true, + "payable": false, + "stateMutability": "view", + "inputs": [], + "outputs":[{"name":"","type":"string"}] +}, +{"type":"function", + "name":"totalSupply", + "constant":true, + "payable":false, + "stateMutability":"view", + "inputs":[], + "outputs":[{"name":"","type":"uint256"}] +}, +... +``` + +Great idea. Easy to read/parse (for computers) BUT gets big and unreadable very fast for humans. + +Tip: See [ABI-To-Sol](https://gnidan.github.io/abi-to-sol/) +to convert JSON ABIs back to "human" readable +"Solidity-like" interface headers. + + + + +## The "Human-Reabable" ABI Format + +Yes, introduced first in ethers.js +(and invented by Richard Moore back in 2018 - +see [ethers.js: Human-Readable Contract ABIs](https://blog.ricmoo.com/human-readable-contract-abis-in-ethers-js-141902f4d917)). + +Human-readable, really? At least computer programmer-readable ;-). + + + +``` js +const abi = [ + "function name() view returns (string)", + "function symbol() view returns (string)", + "function totalSupply() view returns (uint256)", + "function tokenURI(uint256 tokenId) view returns (string)", + "function traitDetails(uint256 layerIndex, uint256 traitIndex) view returns (string name, string mimetype, bool hide)", + "function traitData(uint256 layerIndex, uint256 traitIndex) view returns (string)", +]; +``` + + + + +## Contract №3 - "On-Chain" Token Basics - Via JSON-RPC Using ethers.js + +Let's try another... Seize the memes of production... + +``` js +const addr = '0xe9b91d537c3aa5a3fa87275fbd2e4feaaed69bd0'; + +const abi = [ + "function name() view returns (string)", + "function symbol() view returns (string)", + "function totalSupply() view returns (uint256)", + "function tokenURI(uint256 tokenId) view returns (string)", + "function traitDetails(uint256 layerIndex, uint256 traitIndex) view returns (string name, string mimetype, bool hide)", + "function traitData(uint256 layerIndex, uint256 traitIndex) view returns (string)", +]; + + + +// Create a contract +const contract = new ethers.Contract( addr, abi, provider); + +const name = await contract.name(); +//=> Crypto Marcs +const sym = await contract.symbol(); +//=> MARCS +const total = await contract.totalSupply(); +//=> 5000n +``` + +**Q: What about token metadata (& image)?** + +Let's try... + +``` js +const token0 = await contract.tokenURI( 0 ); +``` + + +resulting in: + +``` +data:application/json;base64, +eyJuYW1lIjoiQ3J5cHRvIE1hcmNzICMwIiwiZGVzY3JpcHRpb24iOiJBIGNvbGxlY3Rpb24gb2YgNWs +gQ3J5cHRvTWFyY3MgZnVsbHkgT24tQ2hhaW4gLSBTZWl6aW5nIHRoZSBtZW1lcyBvZiBwcm9kdWN0aW +9uIiwic3ZnX2ltYWdlX2RhdGEiOiJkYXRhOmltYWdlL3N2Zyt4bWw7YmFzZTY0LFBITjJaeUIzYVdSM +GFEMGlNVEl3TUNJZ2FHVnBaMmgwUFNJeE1qQXdJaUIyYVdWM1FtOTRQU0l3SURBZ01USXdNQ0F4TWpB +d0lpQjJaWEp6YVc5dVBTSXhMaklpSUhodGJHNXpQU0pvZEhSd09pOHZkM2QzTG5jekxtOXlaeTh5TUR +Bd0wzTjJaeUlnYzNSNWJHVTlJbUpoWTJ0bmNtOTFibVF0WTI5c2IzSTZkSEpoYm5Od1lYSmxiblE3WW +1GamEyZHliM1Z1WkMxcGJXRm5aVHAxY213b1pHRjBZVHBwYldGblpTOXdibWM3WW1GelpUWTBMR2xXU +Ws5U2R6QkxSMmR2UVVGQlFVNVRWV2hGVldkQlFVRkNaMEZCUVVGWlEwRlpRVUZCUkdka2VqTTBRVUZC +UVVOWVFrbFhXRTFCUVVGelZFRkJRVXhGZDBWQmJYQjNXVUZCUVVGS2EyeEZVVlpTU1dsbE0wNU5VVVZ +CUVVGcVJFMU5ReTgxTWtWRGRteFNRVEF3Ym5Gek0yMDVRWGRCUVVGQlFVRkJTbmt4UXpkdlJFeGtaSG +[...] +dmiOiJTcG90cyJ9LHsidHJhaXRfdHlwZSI6Ik1hcmMgVHlwZSIsInZhbHVlIjoiTWFyYyA0In1dfQ== +``` + + +let's base64 decode - resulting in: + +``` json +{"name":"Crypto Marcs #0", + "description":"A collection of 5k CryptoMarcs fully On-Chain - Seizing the memes of production", + "svg_image_data":"...", + "image_data":"...", + "attributes":[{"trait_type":"1/1","value":"Original"}, + {"trait_type":"Mouth","value":"Marc"}, + {"trait_type":"Eyes","value":"Marc"}, + {"trait_type":"Lips","value":"Marc"}, + {"trait_type":"Facial Hair","value":"Marc"}, + {"trait_type":"Head","value":"Bandana"}, + {"trait_type":"Neck","value":"Grey Shirt"}, + {"trait_type":"Nose","value":"Marc"}, + {"trait_type":"Ear","value":"Marc"}, + {"trait_type":"Emotion","value":"Marc"}, + {"trait_type":"Face","value":"Spots"}, + {"trait_type":"Marc Type","value":"Marc 4"}]} +``` + +and let's base64 decode the svg_image_data ;-) - resulting in: + +``` xml + + +``` + + + +![](i/marc0.svg) + + + + +## Contract №3 - Let's seize the memes of production ;-). + + +Let's get (query for) all generative art (image) blocks and names... +If the contract uses / supports: + +- `function traitDetails(uint256 layerIndex, uint256 traitIndex) view returns (string name, string mimetype, bool hide)` and +- `function traitData(uint256 layerIndex, uint256 traitIndex) view returns (string)` + +than you can "auto-magically" download all "on-chain" layers, +that is, all metadata triplets by repeatedly calling `traitDetails` starting +with index `0/0`, `0/1`, ..., `1/0`, `1/1`, ... and so on e.g. + +- `traitDetails( 0, 0 )` => `["Zombie", "image/png", false]` +- `traitDetails( 0, 1 )` => `["Cline", "image/png", false]` +- ... +- `traitDetails( 1, 0 )` => `["Bubble Gum", "image/png", false]` +- `traitDetails( 2, 1 )` => `["Medical Mask", "image/png", false]` +- ... + +resulting in 171 Attributes (incl. Nones) in 11 Categories (plus 1/1s): + +``` +id, category, name +0, 1/1, Zombie +1, 1/1, Cline +2, 1/1, Pauly Devil +3, 1/1, Deal With It Devil +4, 1/1, Marc +5, 1/1, Gold +6, 1/1, Marcdonalds +7, 1/1, Marc (2) +8, 1/1, Devil +9, 1/1, Marc (3) +10, 1/1, Madlad Marc +11, 1/1, Chad +12, 1/1, Ape +13, 1/1, Claudia Bot +14, 1/1, Marc (4) +15, 1/1, Bot +16, 1/1, Marc (5) +17, 1/1, Marc (6) +18, 1/1, Alien +19, 1/1, Claudia Gold +20, 1/1, Marc (7) +21, 1/1, Original +22, Mouth, Bubble Gum +23, Mouth, Medical Mask +24, Mouth, Hookah +25, Mouth, Pipe +26, Mouth, Cigar +27, Mouth, Vape +28, Mouth, Cigarette +29, Mouth, None +30, Eyes, Tears +31, Eyes, Monocle +32, Eyes, Lasers +33, Eyes, Pink Shades +34, Eyes, Aviators +35, Eyes, Polarized White +36, Eyes, VR Headset +37, Eyes, Gold Glasses +38, Eyes, 3D Glasses +... +``` + + +and all images (as binary blobs) by calling `traitData` e.g. + +- `traitData( 0, 0 )` => `"\x89PNG..."` +- `traitData( 0, 1 )` => `"\x89PNG..."` +- ... + +and so on resulting in: + +![](i/marcs-spritesheet-24x24.png) + + + + +For many more real-world examples incl. Mad Camels, Ape Origins, Punkin Spicies, NFL, etc. +see the [**Art Factory Sandbox**](https://github.com/generativeartfactory/artfactory.sandbox). + + + + + +## Questions? Comments? + + +Thanks. + + +**What's ETH Vienna / Wien Meetup / Stammtisch?** + +The idea is to (re)start the Eth(erum) community in Vienna / Wien. + +Eth(ereum) Vienna Meetup(s) - Jour Fixe - Every First Wednesday of the Month. + +- **Wednesday, April 5th, 2023, 6-8pm - (Ethereum) Blockchain & Red Kriek Beer** +- **Wednesday, May 3rd, 2023, 6-8pm** +- **Wednesday, June 7th, 2023, 6-8pm** +- Summer Break + +@ Delirium Café Vienna, Passauer Platz 2, 1. District (Beside the Church - Maria am Gestade) + +Note: Everyone MUST pay for your own drink(s) and optional food. +For the menu & prices, see . For example - A traditional (on tap!) Belgian kriek lambic beer by Brouwerij F. Boon costs 0.15L €2.80 / 0.33L €4.80. + +Join us. See or . + + + + +--- + +## Bonus + +## What's the point of (Contract) ABIs? + +Spec(ification) of strongly-typed function calls (and function call data) +guarantees binary interop(eration). + +It is kind of emerging as a new (open) standard / spec for (yes, strongly-typed) apis +(that you can use in any programming language incl. - of course - javascript). + +Note: Ideally all (blockchain) contract code is open source (and "byte-by-byte" verified) +but in practice NOT all contract source code gets published. + + +Yes, "native" language is Solidity. + +Designed "like-JSON", that is, limited set of data types - works and fits into most programming languages. +See my own [abicoder (yes, v2-compatible) in ruby](https://github.com/rubycocos/blockchain/tree/master/abicoder) ;-). + +ABI v2 (yes, there's an update) incl. tuples (also known as structs) +and arrays of arrays or tuple of tuples or array of tuples and so on. + + + +## ABI Types + +The following elementary types are supported: + +- `uint`: unsigned integer type of `M` bits, `0 < M <= 256`, `M % 8 == 0`. e.g. `uint32`, `uint8`, `uint256`. +- `int`: two's complement signed integer type of `M` bits, `0 < M <= 256`, `M % 8 == 0`. +- `address`: equivalent to `uint160`, except for the assumed interpretation and language typing. + For computing the function selector, `address` is used. +- `bool`: equivalent to `uint8` restricted to the values 0 and 1. For computing the function selector, `bool` is used. +- `bytes`: binary type of `M` bytes, `0 < M <= 32`. + + +The following (fixed-size) array types are supported: + +- `[M]`: a fixed-length array of `M` elements, `M >= 0`, of the given type. + + +The following non-fixed-size types are supported: + +- `bytes`: dynamic sized byte sequence. +- `string`: dynamic sized unicode string assumed to be UTF-8 encoded. +- `[]`: a variable-length array of elements of the given type. + +Types can be combined to a tuple by enclosing them inside parentheses, separated by commas: + +- `(T1,T2,...,Tn)`: tuple consisting of the types `T1`, ..., `Tn`, `n >= 0` + +It is possible to form tuples of tuples, arrays of tuples and so on. + + + +## What's abigen? + +Using the abigen command-line tool +you can generate type-safe "wrapper" code for contracts from abis (in json) +for your language. + +Started with Go Lang (a statically compiled programming language) +but works practically with any language. +See my own [little abigen in ruby, that is, abi2ruby](https://github.com/rubycocos/blockchain/tree/master/abi2ruby) ;-) - +a python-like dynamic programming language. + + +Also used in JS for auto-documentation "in the real-world" +or - of course - for type-safe contracts in ... TypeScript - +see [ABI Type - Strict TypeScript types for Contract ABIs.](https://abitype.dev) +and many more. + + diff --git a/goreleaser.md b/goreleaser.md new file mode 100644 index 0000000..5715238 --- /dev/null +++ b/goreleaser.md @@ -0,0 +1,237 @@ +# GoReleaser Talk Notes + +- Vienna Go (Lang) Meetup March 2023 @ fiskaly + + + +## How-To Cross-Compile Go Programs for Window, Mac OS, and Linux + +Cross-Compile == Build Go Programs / Applications for Different Operation Systems (`GOOS`) and +(Processor) Architectures (`GOARCH`) e.g. build Mac OS on Windows or Windows on Linux etc. + + +Q: Cross-Compile!? + +> Programs written in Go can easily be compiled for a wide variety of target operating systems +> such as Windows, Mac OS, and Linux +> by using the `GOOS` and `GOARCH` environmental variables. + + +Q: What is GOOS and GOARCH? + +> `GOOS` refers to the operating system (Linux, Windows, BSD, etc.), +> while `GOARCH` refers to the (processor) architecture (386, amd64, arm64, etc.) to build for. + + +Q: How-to find out your GOOS and GOARCH values? + + $ go env GOOS + windows + $ go env GOARCH + amd64 + $ go env GOOS GOARCH + windows + amd64 + +or + + $ go env + +resulting in (sorted a-z): + + .. + set GOARCH=amd64 + ... + set GOOS=windows + ... + + or + + $ go version + go version go1.18 windows/amd64 + + +Q: What values for GOOS and GOARCH possible? + + $ go tool dist list + +resulting in: + +``` +aix/ppc64 +android/386 +android/amd64 +android/arm +android/arm64 +darwin/amd64 +darwin/arm64 +dragonfly/amd64 +freebsd/386 +freebsd/amd64 +freebsd/arm +freebsd/arm64 +illumos/amd64 +ios/amd64 +ios/arm64 +js/wasm +linux/386 +linux/amd64 +linux/arm +linux/arm64 +linux/mips +linux/mips64 +linux/mips64le +linux/mipsle +linux/ppc64 +linux/ppc64le +linux/riscv64 +linux/s390x +netbsd/386 +netbsd/amd64 +netbsd/arm +netbsd/arm64 +openbsd/386 +openbsd/amd64 +openbsd/arm +openbsd/arm64 +openbsd/mips64 +plan9/386 +plan9/amd64 +plan9/arm +solaris/amd64 +windows/386 +windows/amd64 +windows/arm +windows/arm64 +``` + + + +Coding Example - hello.go: + +``` go +package main + +import( + "fmt" + "runtime" +) + +func main() { + fmt.Printf( "OS: %s\nArchitecture: %s\n", + runtime.GOOS, + runtime.GOARCH) +} +``` + +build (64-bit binary) + + $ go build hello.go + +run + + $ hello + OS: windows + Architecture: amd64 + +build (32-bit binary) + + $ set GOOS=windows + $ set GOARCH=386 + $ go build hello.go + +run + + $ hello + OS: windows + Architecture: 386 + +build (linux binary on windows) + + $ set GOOS=linux + $ set GOARCH=386 + $ go build hello.go + +run + + $ hello + + > This version of hello is not compatible with the version of Windows you're running. + > Check your computer's system information and then contact the software publisher. + + +Note: You CAN run the the binary / executable +only on the target platform (e.g. on Window, Linux, Mac OS, etc.) - +out the other end only runs on OS X, and cannot be run on + + +Cross-compile in unix shell: + + $ GOOS=linux GOARCH=386 go build hello.go + + $ GOOS=darwin GOARCH=arm64 go build hello.go + .. + + +## Artbase Server Binary Case Study + +see + + +Download Releases (Binaries) On Github + +see + +Example: + +- `artbase_1.0.0_linux_64bit.tar.gz` - 2.84 MB +- `artbase_1.0.0_linux_armv6.tar.gz` - 2.66 MB +- `artbase_1.0.0_macos_64bit.tar.gz` - 2.93 MB +- `artbase_1.0.0_macos_arm64.tar.gz` - 2.82 MB +- `artbase_1.0.0_windows_64bit.zip` - 2.82 MB + + + +Automate, Automate, Automate + +via GitHub Actions & GoReleaser + +GoReleaser (Freemium with Pro version) - +Release Go projects as fast and easily as possible! + +see + + +How-To Use + +Step 1: .gorealser.yml Configuration + +see + + + +Step 2: .github/workflows/release_build.yml (Git Action / Workflow Configuration) + +see + + +Step 3: git tag (triggers goreleaser) + +see + + $ git tag v0.0.5 + $ git tag v1.0.0 + +only "local" - to trigger goreleaser push tags to github (upstream) + + $ git push origin --tags + or + $ git push origin v0.0.5 + $ git push origin v1.0.0 + + + +That's it. + +## Questions? Comments? + diff --git a/i/bigint-compat.png b/i/bigint-compat.png new file mode 100644 index 0000000..4f453c2 Binary files /dev/null and b/i/bigint-compat.png differ diff --git a/i/double-precision-number.png b/i/double-precision-number.png new file mode 100644 index 0000000..71a01f8 Binary files /dev/null and b/i/double-precision-number.png differ diff --git a/i/kitty1.png b/i/kitty1.png new file mode 100644 index 0000000..f69f16f Binary files /dev/null and b/i/kitty1.png differ diff --git a/i/marc0.svg b/i/marc0.svg new file mode 100644 index 0000000..e37ec99 --- /dev/null +++ b/i/marc0.svg @@ -0,0 +1,22 @@ + + diff --git a/i/marcs-spritesheet-24x24.png b/i/marcs-spritesheet-24x24.png new file mode 100644 index 0000000..e28438e Binary files /dev/null and b/i/marcs-spritesheet-24x24.png differ diff --git a/i/phunk0.png b/i/phunk0.png new file mode 100644 index 0000000..4c5a563 Binary files /dev/null and b/i/phunk0.png differ