Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

draft new ERC for contract working with ts #430

Draft
wants to merge 785 commits into
base: main
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
785 commits
Select commit Hold shift + click to select a range
c0bf838
added redeemed text, compressed images
rosieprom Dec 4, 2019
385d51b
Update README.md
zhangzhongnan928 Dec 5, 2019
e314954
Update README.md
zhangzhongnan928 Dec 5, 2019
a66acd4
Update README.md
zhangzhongnan928 Dec 5, 2019
6030f0c
fixed shared.css to work on Android/iOS
rosieprom Dec 8, 2019
81c7f3d
changed the background image and some height issue fix
rosieprom Dec 9, 2019
0ed4344
Merge pull request #291 from AlphaWallet/UEFA-redeem-item
bitcoinwarrior1 Dec 10, 2019
ea23654
WIP add basic edcon draft TokenScript
bitcoinwarrior1 Nov 27, 2019
48a8c83
Merge pull request #298 from AlphaWallet/edcon
zhangzhongnan928 Dec 10, 2019
a25a702
add base files for alipay
bitcoinwarrior1 Dec 10, 2019
fa6df2c
add location info to edcon
bitcoinwarrior1 Dec 10, 2019
2157ef9
add pickup to alipay
bitcoinwarrior1 Dec 10, 2019
9876fde
populate with sample contracts and info
bitcoinwarrior1 Dec 10, 2019
e78db85
Merge pull request #299 from AlphaWallet/alipay
bitcoinwarrior1 Dec 13, 2019
6b71301
rename AliEuro TokenScripts
bitcoinwarrior1 Dec 13, 2019
93f542c
fix up names
bitcoinwarrior1 Dec 16, 2019
12ef7fb
AliEuro TokenScripts with layouts
bitcoinwarrior1 Dec 13, 2019
7ffa49c
Merge pull request #301 from AlphaWallet/airport-dropoff
bitcoinwarrior1 Dec 17, 2019
7c7f5d1
alipay amended css
rosieprom Dec 17, 2019
7ed41f5
fixed alipay styled css
rosieprom Dec 18, 2019
f48d84e
Merge pull request #302 from AlphaWallet/alipay-style-fixing
bitcoinwarrior1 Dec 18, 2019
3760319
made the edcon ts ticket layout
rosieprom Dec 18, 2019
bbc4dd1
changed background images to new design
rosieprom Dec 19, 2019
e857b61
Merge pull request #303 from AlphaWallet/edcon-layout
bitcoinwarrior1 Dec 19, 2019
c181b7e
added new background image
rosieprom Dec 19, 2019
094fc8e
Merge pull request #306 from AlphaWallet/edcon-layout-fix
bitcoinwarrior1 Dec 19, 2019
5330f2c
blank ticket template done for tokenscript
rosieprom Dec 19, 2019
11693a0
Merge pull request #305 from AlphaWallet/blank-template-example
bitcoinwarrior1 Dec 19, 2019
84bca45
add Chinese to UEFA
bitcoinwarrior1 Dec 28, 2019
e2d8697
allowing multiple views in <action> or <token-card>.
Dec 29, 2019
c3a434e
Merge pull request #308 from AlphaWallet/translate-uefa-to-chinese
bitcoinwarrior1 Dec 31, 2019
9d4ae62
this is the 1st part of a 3-part serial
Jan 2, 2020
4c82e73
Replace logo and title used in UEFA ticket
hboon Jan 7, 2020
aeb70fc
Merge pull request #315 from AlphaWallet/replace-logo-and-title-used-…
bitcoinwarrior1 Jan 8, 2020
a8b4b17
change Makefile in UEFA to have name AlphaWallet
bitcoinwarrior1 Jan 8, 2020
fab82fa
Create The tech stack for tokenising tickets on public blockchain
zhangzhongnan928 Jan 9, 2020
b45e753
Update The tech stack for tokenising tickets on public blockchain
zhangzhongnan928 Jan 9, 2020
7a2de64
Delete The tech stack for tokenising tickets on public blockchain
zhangzhongnan928 Jan 9, 2020
dbfa630
Add files via upload
zhangzhongnan928 Jan 9, 2020
dd312c1
change Makefile to use Shankai name
bitcoinwarrior1 Jan 10, 2020
9d5bdfd
Merge branch 'master' of https://github.com/AlphaWallet/TokenScript
bitcoinwarrior1 Jan 10, 2020
a8d241c
add starwars sports tickets
bitcoinwarrior1 Jan 17, 2020
27d4e28
adjust fonts
bitcoinwarrior1 Jan 17, 2020
6eb8873
rename star wars sports
bitcoinwarrior1 Jan 18, 2020
6036512
rename legacy DAI to SAI
bitcoinwarrior1 Jan 20, 2020
8241ed8
add cDAI TokenScript
bitcoinwarrior1 Jan 20, 2020
43146fb
change bridge to use DAI rather than SAI
bitcoinwarrior1 Jan 20, 2020
a5ae9ff
add SAI Migration TokenScript to replace bridge
bitcoinwarrior1 Jan 20, 2020
f7a3527
update images of DAI
bitcoinwarrior1 Jan 21, 2020
8d7a1fa
remove examples, resources and tutorial while changing the readme to …
bitcoinwarrior1 Jan 22, 2020
2bf1c44
Merge pull request #324 from AlphaWallet/adapt-for-examples-repo
bitcoinwarrior1 Jan 22, 2020
6954bbb
add why XML section
bitcoinwarrior1 Jan 30, 2020
6216a04
Merge pull request #327 from AlphaWallet/add-why-xml
bitcoinwarrior1 Feb 1, 2020
0e2414a
adding a few paragraphs to explain the difference between signing a t…
Feb 2, 2020
99d9217
allowing event card in <cards>
Feb 3, 2020
8937839
rename <token-card> to <token>
Feb 3, 2020
188a33d
adding asnx schema and changing view to include only javascript and s…
Feb 13, 2020
7ef248b
adding xhtml:body to support html (abeit with namespace, meaning norm…
Feb 17, 2020
4dba0d6
changing view-iconified to item-view because
Feb 17, 2020
f1eafb6
reading for being published as 2020-03 schema
Feb 17, 2020
ab16fd6
reversing a seemly mistaken change. I never intended sub-elements und…
Feb 17, 2020
d666d74
turn aciton from an element with local definition to an element from …
Feb 17, 2020
4b807dc
Update JavaScript doc with API for TokenScript view container access.…
hboon Feb 19, 2020
2a4b5f1
change action back to a global element so it can be uesd as root element
Feb 21, 2020
b5e322e
Update design_paper.md
zhangzhongnan928 Mar 13, 2020
daac10d
Change licence to MIT
bitcoinwarrior1 Mar 14, 2020
fb75e7b
Merge pull request #334 from AlphaWallet/zhangzhongnan928-patch-1
bitcoinwarrior1 Mar 14, 2020
f006805
Merge pull request #335 from AlphaWallet/change-to-mit
zhangzhongnan928 Mar 14, 2020
905630c
Update README.md
zhangzhongnan928 Mar 16, 2020
e0eec08
a minimalist asnx schema for urn:ietf:params:xml:ns:asnx namespace, j…
Mar 23, 2020
696f96d
adding comments
Mar 23, 2020
17e8a06
adding ethereum namespace for ethereum-only attributes
Mar 23, 2020
9da9964
forgot this spot (adding indexed attribute) in the last commit
Mar 31, 2020
72ebaeb
now allowing actions to have two attributes: exclude and available-to…
Apr 9, 2020
86bec1a
using xml.xsd we hosted instead of w3c's which sometimes becomes unav…
Apr 9, 2020
458ad81
remove the <selections> elements which we no longer use
Apr 9, 2020
6dd7429
finish removing <attribute-types> and <selections>
Apr 10, 2020
11958b2
Update tutorial link
jzaki Apr 10, 2020
3f69cd4
Fix typo
jzaki Apr 10, 2020
dbc31aa
Create We need a better framework for applications using blockchain 中文
zhangzhongnan928 Apr 16, 2020
23cf27a
add local-ref
bitcoinwarrior1 May 4, 2020
a5389a0
correct address element to variable
bitcoinwarrior1 May 4, 2020
d2edad2
move the definition of "as" attribute and "mapping" element to data w…
May 10, 2020
184c663
clarification in express-of-trust
May 10, 2020
169c6d4
upping namespace to 2020/06 for quite a few schema-breaking changes i…
May 10, 2020
4c8c830
moving etheruem calls to its own namespace
May 10, 2020
72b0c15
renaming name to label
May 11, 2020
4f976b6
for attribute-types, changing attribute id into name
May 11, 2020
6d49229
changing <token> and <action> cards into <card type="…". detail https…
May 13, 2020
bb68d7a
fixing the sequence of the elements inside cards - we can always rela…
May 13, 2020
18f2352
add e6 which replaces #350
bitcoinwarrior1 May 13, 2020
ff5cc21
Merge pull request #348 from AlphaWallet/rename-names
May 13, 2020
aaad8c4
Merge pull request #332 from AlphaWallet/schema/2020/03
bitcoinwarrior1 May 15, 2020
8e85f5a
Merge pull request #345 from AlphaWallet/schema/2020/06
bitcoinwarrior1 May 15, 2020
740be6d
introducing <ethereum:transaction> based on <ethereum:call>
May 15, 2020
67d54e0
Merge pull request #353 from AlphaWallet/rename-names
bitcoinwarrior1 May 16, 2020
0225d2b
add in local-ref to ethereum:value (#354)
bitcoinwarrior1 May 19, 2020
f630edf
reformat - wanted to do this for a long time but schema has always be…
May 20, 2020
7748505
Merge pull request #356 from AlphaWallet/reformat-schema-files
bitcoinwarrior1 May 20, 2020
c0cffe2
moving attributes' type definition into its own element
May 24, 2020
62f1d2f
Merge pull request #358 from AlphaWallet/type-in-attribute
bitcoinwarrior1 May 24, 2020
02e8457
rename id to name for all <selection>
May 31, 2020
6f046d5
using asnx module correctly, as per RFC4912, to include sequence in a…
May 31, 2020
7856914
Merge pull request #359 from AlphaWallet/id-and-asnx-module-correction
bitcoinwarrior1 Jun 1, 2020
ed478c1
add sample activities for ERC20 & ERC721
bitcoinwarrior1 Jun 11, 2020
264e30c
directory structure - the ERCs implemented in TokenScripts are real t…
Jun 12, 2020
c88ab21
adding README
Jun 12, 2020
1c02db0
relax schema rules so that ERCs can be implemented in TokenScript
Jun 12, 2020
92dd2be
updating tokenscript to validate
Jun 12, 2020
a3cde51
Fix: TokenScript file for ERC20 should not have string interpolation …
hboon Jun 22, 2020
6484039
Merge pull request #361 from AlphaWallet/fix-erc20-filter-lhs-no-stri…
bitcoinwarrior1 Jun 22, 2020
b218c77
Fix: TokenScript file for ERC20's ownerApproved filter
hboon Jun 22, 2020
8d22e0c
Merge pull request #362 from AlphaWallet/fix-erc20-filter-ownerApprov…
bitcoinwarrior1 Jun 22, 2020
bf75453
modifies readme for tokenscript
Jun 24, 2020
c506dc1
RFC4912 required a <type> for a named type that defines a type
Jun 25, 2020
5c260b1
apply the same RFC4912 comformation change to the default ERC scripts
Jun 25, 2020
a632653
corrisponding change in ERC72 was left out in the last commit
Jun 25, 2020
b19b8d5
Fix: TokenScript file for ERC20's activity filters not using correct …
hboon Jun 26, 2020
4927e61
link correction
Jun 26, 2020
5422a58
allowing contracts to be absent in ethereum:*
Jun 25, 2020
5337776
format editing
Jun 26, 2020
ed69c84
Remove "Don't we already have a front-end for tokens?"
Jun 26, 2020
ba1d9e6
Merge pull request #363 from AlphaWallet/origin/readme-updates
Jun 26, 2020
8c2cd61
Merge pull request #368 from AlphaWallet/fix-erc20-activity-event-fil…
bitcoinwarrior1 Jun 29, 2020
a517d0d
adding JavaScript xmldsig verification example (#369)
Jun 29, 2020
364ad54
updating the tokenscript schema README to explain the release cycle. …
Jun 30, 2020
745b503
RFC4912 required a <type> for a named type that defines a type
Jun 25, 2020
44ae8ad
apply the same RFC4912 comformation change to the default ERC scripts
Jun 25, 2020
af0b3a3
corrisponding change in ERC72 was left out in the last commit
Jun 25, 2020
9dbe81f
allowing <origins> and allowing empty <asnx:element>
Jul 5, 2020
eb0aadc
making ERC721 compatible with the <origins> style too
Jul 5, 2020
c5d3a76
retro-rename the 3rd element in ERC20 transfer/approve events to amou…
Jul 5, 2020
746e7b5
Add the link to basic tutorial
zhangzhongnan928 Jul 8, 2020
d076ff6
Merge pull request #365 from AlphaWallet/correct-violation-of-rfc4912
Jul 13, 2020
b1df515
Update JavaScript doc with API to separate token and card attribute d…
hboon Jul 13, 2020
98064be
revert a change in the previous version which forced asnx:element to …
Jul 14, 2020
a5d310b
forgot a few patches in the previous comment that replaces card attri…
Jul 15, 2020
3f74249
ah still wrong, correcting LHS field name
Jul 15, 2020
9d8061e
Merge branch 'master' into correct-violation-of-rfc4912+add-origins-i…
Jul 15, 2020
72afaba
adding the keyref constraints on the newly added card/origins's events
Jul 20, 2020
ea565c9
requiring contract in Ethereum Event as Sangalli would need
Jul 20, 2020
2bc5140
Merge pull request #373 from AlphaWallet/correct-violation-of-rfc4912…
Jul 20, 2020
543008b
adding use="required" to the attributes that needs it
Jul 21, 2020
6676cc4
make function required when calling, optional when making a transaction
Jul 22, 2020
a24e1e2
refactor type to allow token/activity/action cards to have different …
Jul 25, 2020
e16561a
taking <cards> out to a global element so that it can be used as root…
Jul 25, 2020
660967c
refactor view as we only need them in cards
Jul 26, 2020
ebb8f9f
allowing guide-view
Jul 26, 2020
ef180f3
requiring name for cards, reasons explained https://community.tokensc…
Jul 25, 2020
6c1dbd7
attempt to make the keyref enforcement work on ethereum:call's type a…
Jul 22, 2020
9361fcd
Resolved issue - The XPath expression //ts:origins/ethereum:event|//t…
darakhbharat Jul 27, 2020
0b02703
introducing distinct as per previous ts meeting
Aug 7, 2020
5e5c5a2
introducing distinct as per previous ts meeting
Aug 7, 2020
5ac912d
unify token as top level element & as reference, both allow name
Aug 7, 2020
7c17ce5
Fix: TokenScript file for ERC721's activity filters not using correct…
hboon Sep 3, 2020
3cf25b6
Merge pull request #385 from AlphaWallet/fix-erc721-activity-event-fi…
bitcoinwarrior1 Sep 3, 2020
f3e88c2
Fix: TokenScript view files for ERC721's activity for reference to `t…
hboon Sep 3, 2020
c4ca79f
distinct attribute is not allowed for attributes in <card>, only if i…
darakhbharat Sep 6, 2020
879faf0
Merge pull request #386 from AlphaWallet/fix-erc721-activity-views-re…
bitcoinwarrior1 Sep 8, 2020
73020c6
Completed: 1. all attribute element under the token can have only one…
darakhbharat Sep 17, 2020
aae2315
Merge branch 'master' into distinct
darakhbharat Sep 19, 2020
1faec47
formatting changes
darakhbharat Sep 19, 2020
29cf1f6
XSLT is not needed for xml.xsd
Oct 11, 2020
68d20ad
Merge branch 'master' of github.com:AlphaWallet/TokenScript
Oct 11, 2020
40cab86
update web3 data changed callback
bitcoinwarrior1 Oct 10, 2020
656935f
Merge pull request #394 from AlphaWallet/update-callback-to-token-data
bitcoinwarrior1 Oct 12, 2020
bc0020b
Merge pull request #388 from AlphaWallet/distinct
Oct 20, 2020
1783424
providing a basic frame for using tokenscript on a web page
Aug 19, 2020
62cd231
adding notes on future extensibility
Aug 20, 2020
91dfb67
first version handed to Oleg
Aug 27, 2020
d768428
new version with TokenNegotiation
Aug 27, 2020
a8f6332
realised that doing .then() on the 2nd round of negotiation isn't nec…
Aug 27, 2020
c6bfc94
using meta correctly + using x.509 convention that objectClass be in …
Sep 2, 2020
370970a
added bootstrap.js to parse XML and updated entry-token.html(fixed er…
oleggrib Sep 2, 2020
bde9349
sample JSON to be transformed from module
Sep 4, 2020
bc9b9d3
breaking down the negotiation into active/passive pair
Sep 8, 2020
5a29fac
refactored bootstrap.js , created Negotiator global object to parse X…
oleggrib Sep 10, 2020
c50854b
James Brown provided a new contract address for Rinkby
Sep 14, 2020
e180dc7
JB updated the contract address for token holder 0x0C770da98559DD6806…
Sep 14, 2020
fee6705
adding definition for balanceOf
Sep 14, 2020
767f8d2
most of methods moved to Negotiator. Negotiator do all work to prepar…
oleggrib Sep 18, 2020
edf49d1
updated token ID to use tokenID=... or ownerAddress=0x...
oleggrib Sep 18, 2020
8c2bd3b
adding an 2nd example with activity defined
Sep 21, 2020
8ed17c8
added event parsing code with console output. to run code we have to …
oleggrib Sep 23, 2020
df5e09e
fix : let -> var
oleggrib Sep 23, 2020
658a9dc
added erc-20 activity cards pop-up
oleggrib Sep 28, 2020
1ab95b0
ready to be taken into master soon, renaming directories
Sep 28, 2020
135a5d9
changed message for connect/disconnect network and added button to Co…
oleggrib Sep 29, 2020
6a628bd
convert the error message to a table for better display
Sep 29, 2020
f640ed6
breaking things a bit by assuming passive negotiation and show the fi…
Sep 29, 2020
2e395bf
added upload/download XML and filters
oleggrib Oct 8, 2020
491fe4e
fixed box title
oleggrib Oct 8, 2020
2a5ec76
added tests, some code moved to separate module, active negotiation p…
oleggrib Oct 12, 2020
6fb6c7c
every card use own iframe
oleggrib Oct 16, 2020
a70bc16
added live event update, new event marker, erc20 token props list and…
oleggrib Oct 20, 2020
e7b2887
relaxing contract name rule to allow NCName instead of ID, as contrac…
Oct 22, 2020
448410a
Merge branch 'master' of github.com:AlphaWallet/TokenScript
Oct 22, 2020
d6e7dc1
rolling back part of the change in https://github.com/AlphaWallet/Tok…
Oct 22, 2020
e2a8c9a
token name is required thanks to the previous merge of Oleg's token n…
Oct 25, 2020
4855c96
no longer using IDREF (replaced most with keyref) since many months a…
Oct 26, 2020
0ea2c00
allow contract reference & attribute refer to another
Oct 31, 2020
37c310e
allowing accessing storage
Nov 2, 2020
8054ba4
docs are generated from the document repository
Dec 24, 2020
2076527
Set theme jekyll-theme-minimal
Dec 24, 2020
09ed5c0
Web example: devcon issuer
nicktaras Jan 7, 2021
fce6c9b
switched npm package polyfill for bigint to big-integer, updated Sign…
nicktaras Jan 7, 2021
c81f55f
Merge pull request #411 from TokenScript/web-examples
AW-STJ Jan 7, 2021
733aafd
adding flow chart for authenticator and negotiator
Jan 28, 2021
27cd507
adding the first js xmldsig verifier code that actually works for dem…
Apr 7, 2021
32b9e80
coming up with better README
Apr 7, 2021
ba452f5
using ES module instead of nodejs require (for webpack). Also making …
Apr 8, 2021
0f249d0
updating readme since most of its content is moved to the sub-directo…
Apr 9, 2021
f1a90c7
adding the index.js which was forgotten earlier.
Apr 9, 2021
882c0a6
Update README.md (#421)
zhangzhongnan928 Dec 2, 2021
256f2fc
version obtained from Tore which is based on an earlier version from …
May 9, 2022
c110d6a
Added Hu's suggestions
May 10, 2022
4766ecf
Changed getScriptURI to scriptURI
May 10, 2022
582f80f
wording update and dos2unix endian update
May 16, 2022
594ed57
Updated naming convention
May 17, 2022
9409fb1
half-way attempt to divide the ERC into 2
May 18, 2022
9fd0215
Merge branch 'new_ercs' of github.com:TokenScript/TokenScript into ne…
May 18, 2022
588249f
splitting ERCs into 2
May 18, 2022
66a57a2
amending to add optional contract inteface
May 18, 2022
fa51952
renaming
May 18, 2022
bd56970
Added details to both the split and combined ERCs
May 20, 2022
20e90eb
rename so every file look the same
May 25, 2022
4075999
wording update, mostly
May 25, 2022
99dc909
Refine language
May 25, 2022
58cbb65
wording update, mostly
May 25, 2022
7b0cec0
Refine language
May 25, 2022
35e0bc1
Merge branch 'new_ercs' of https://github.com/TokenScript/TokenScript…
May 25, 2022
89bc557
to make it clear ERC5XX0 doesn't require new key pairs at all
May 25, 2022
f90e119
Changed from struct to string[]
May 25, 2022
a8f92cb
Merge branch 'new_ercs' of https://github.com/TokenScript/TokenScript…
May 25, 2022
f87bebc
Added suggestion of self administration of array of scripturi
May 25, 2022
cc8dd27
Add sample implementations
JamesSmartCell May 30, 2022
f2c4901
trivial text change.
Jun 7, 2022
c7a9bf2
sorry James, I'm removing this large chunk because it belongs to the …
Jun 16, 2022
b09f0e3
Merge branch 'new_ercs' of github.com:TokenScript/TokenScript into ne…
Jun 16, 2022
b27266e
copy-editing, and fixing the first 4 out of 5 problems in feedback:
Jun 16, 2022
989f074
Tried to shorten ERC5xx0 a bit
Jun 16, 2022
ba00c50
Added Henderson's test case
Jun 17, 2022
c807aef
updated to avoid the issues Jason's feedback revealed.
Jun 17, 2022
37446d4
spelling
Jun 17, 2022
45c77b3
Update ERC5XX0 draft.md
Jun 17, 2022
40886c1
Update ERC5XX0 draft.md
Jun 17, 2022
0874e14
use download instead of location to resources
Jun 17, 2022
a9335d6
Tried to shorten and proof read 5xx1
Jun 20, 2022
931de88
Tried to shorten and proof read 5xx1
Jun 20, 2022
5b4e10a
more shortening
Jun 20, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Added Hu's suggestions
Tore Kasper Frederiksen committed May 10, 2022
commit c110d6a6ae86db8859c44e4effcca394a38aee07
14 changes: 7 additions & 7 deletions ERCs/ERC5XXX draft.md
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
### eip: 5???
### title: Executable Script extention for Token Contracts
### title: Executable Script extension for Token Contracts
### description: Add a scriptURI to point to point to an executable script associated with the functionality of the token.
### author: James (@JamesSmartCell), Weiwu (@weiwu-zhang), Tore Frederiksen
### author: James (@JamesSmartCell), Weiwu (@weiwu-zhang), Tore Frederiksen (@jot2re)
### discussions-to:
### status: Draft
### type: Standards Track
### category: ERC
### created: 2022-05-03
### requires:
### Abstract
This standard is an interface that adds a scriptURI for locating executable scripts associated with the token.
This standard is an interface that adds a `scriptURI()` function for locating executable scripts associated with the token.

### Motivation
Often NFT authors want to provide some user functionality to their tokens, e.g. through scripts. This should done in a safe way, without opening the user to potential scams. By packaging a link to official scripts, created by the token minter, within the token itself, users can be sure they are using the correct script.

This ERC proposes adding a scriptURI which is a structure containing an array of URIs to external resources in IPFS, github, a cloud provider, etc.
This ERC proposes adding a scriptURI which is a structure containing an array of URIs to external resources in IPFS, GitHub, a cloud provider, etc.
Each scriptURI semantically contains access information to access a *single* signed script, stored in one or more off-chain locations.
Concretely each element in the array contains a pair of URIs, one to the script itself, and one to a signature of the script.

@@ -111,10 +111,10 @@ interface IERC5XXX {
/// @notice Get the scriptURI for the contract
/// @return The scriptURI
function getScriptURI() external view returns(ScriptURI memory);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

James asked me to read:

Should getScriptURI() be scriptURI() instead? More idiomatic and mentioned in other parts of this doc.

Seems like it would be better to narrow down IERC5XXX to just:

event ScriptUpdate(ScriptURI memory newScriptURI);
function getScriptURI() external view returns(ScriptURI memory);

or even:

function getScriptURI() external view returns(ScriptURI memory);

The rest looks optional and might slow adoption. If we can draw the line somewhere, the rest of the stuff can be in the reference implementation and submitted to OpenZeppelin. Without the parts that covers signature, there's a chance someone could use it in a non-TokenScript way, then the TokenScript engine or the client will need to innspect the contents referred to by the URI returned to see if it's a TokenScript file (or we might need an additional ERC165 check, but seems unnecessary).

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should getScriptURI() be scriptURI() instead? More idiomatic and mentioned in other parts of this doc.

I actually changed it to getScriptURI() since I thought it was more idiomatic 😅 But feel free to change it, if you think scriptURI() is better.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The rest looks optional and might slow adoption. If we can draw the line somewhere, the rest of the stuff can be in the reference implementation and submitted to OpenZeppelin. Without the parts that covers signature, there's a chance someone could use it in a non-TokenScript way, then the TokenScript engine or the client will need to innspect the contents referred to by the URI returned to see if it's a TokenScript file (or we might need an additional ERC165 check, but seems unnecessary).

It is a good point that it might be too broad! However, I do think that the issue we are trying to handle as a minimum requires a possibility to update the script. When it comes, to the script signing key, it could be sufficient to just use the smart contract signing key, but from the discussion with @weiwu-zhang I got the understanding that something smart was required for this ERC.
@weiwu-zhang what do you think? Should we make the script signing key optional?

In any case, it might be an idea to write a partial class instead of simply an interface, such that it can simply be copy-pasted into the base of any contract.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should getScriptURI() be scriptURI() instead? More idiomatic and mentioned in other parts of this doc.
I actually changed it to getScriptURI() since I thought it was more idiomatic 😅 But feel free to change it, if you think scriptURI() is better.

It's more idiomatic because of the similarity to ERC721.

There is this snippet in that page:

interface ERC721Metadata /* is ERC721 */ {
    /// @notice A descriptive name for a collection of NFTs in this contract
    function name() external view returns (string _name);

    /// @notice An abbreviated name for NFTs in this contract
    function symbol() external view returns (string _symbol);

    /// @notice A distinct Uniform Resource Identifier (URI) for a given asset.
    /// @dev Throws if `_tokenId` is not a valid NFT. URIs are defined in RFC
    ///  3986. The URI may point to a JSON file that conforms to the "ERC721
    ///  Metadata JSON Schema".
    function tokenURI(uint256 _tokenId) external view returns (string);
}

tokenURI(uint256) (and also name() and symbol()).

Also how it specifies a getter and not a setter in the specs. The OpenZeppelin contracts do contain the setter though.

I suggest to post a draft early to https://ethereum-magicians.org and request for comments. To a certain extent, as long as they like it, it's going to get more acceptance :)

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I have changed it.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should getScriptURI() be scriptURI() instead? More idiomatic and mentioned in other parts of this doc.

I actually changed it to getScriptURI() since I thought it was more idiomatic 😅 But feel free to change it, if you think scriptURI() is better.

scriptURI() is more coherent with existing ERC standards.

EG:

name()
symbol()
balanceOf()
contractURI()
tokenURI()

Let's keep it consistent.

/// @notice Get the scriptURI for the contract
/// @return The scriptURI
function getVerificationKey) external view returns(address memory);
function getVerificationKey() external view returns(address memory);


/// @notice Update the scriptURI
@@ -146,7 +146,7 @@ The interface MUST be implemented under the following constraints:


### Rationale
Using this method avoids the need for building secure and certified centralised hosting and allow scripts to be hosted anywhere: IPFS, github or cloud storage.
Using this method avoids the need for building secure and certified centralised hosting and allow scripts to be hosted anywhere: IPFS, GitHub or cloud storage.

### Backwards Compatibility
This standard is compatible with all Token standards (ERC20, 721, 777, 1155 etc).