Releases: PolymeshAssociation/Polymesh
Releases · PolymeshAssociation/Polymesh
Polymesh v5.1.3
Fix portfolio move bug (See #1374)
Polymesh v5.1.2
Removes ITN Rewards
- removes corresponding storage
- makes reward extrinsics uncallable
Polymesh v5.1.1
new features
- New CLI flag
--db-max-total-wal-size
to limit the size of RocksDB WAL files. (See PolymeshAssociation/substrate#29)
modified logic
- When deploying Smart Contracts make sure that the contract's address is linked to the identity before transferring the initial storage fee. (See PolymeshAssociation/substrate@9c28705)
Polymesh v5.1.0
changelog
modified logic
- MultiSig pays protocol fees. (#1307)
- modified MultiSigSigners map (#1282)
- check instruction leg amount and returns error if zero (#1284)
- removed state from pip.Proposals (#1287)
- modified renaming portfolio function to insert new name in nameToNumber map (#1285)
- added redeem_from_portfolio function (#1292)
- modified base_redeem to correctly check referenced portfolio (#1338)
modified api
- created update_venue_signers function and VenueSignersUpdated Event (#1273)
- adds
CustomClaimTypeAdded
event to record custom claim (#1266) - adds
CustomClaimTypeDoesNotExist
error if claim type doesn't exist (#1266) - adds
CustomClaims
,CustomClaimsInverse
,CustomClaimIdSequence
storage to record custom claim details (#1266) - adds
register_custom_claim_type
extrinsic to register new custom claim types (#1266) - add a few new fields to
AssetCreated
event (#1272) - added optional memo field to Instructions (#1280)
new features
- adds the ability to register and then add custom claims (
Claim::Custom
) (#1266) - Add storage version check script to pipeline and fix genesis config for Portfolio & Statistics pallets.
- Add missing rpc endpoints and signedExtensions. #1329
- Re-use the develop runtime code and add support for building just a special ci runtime.
- Updates benchmarks for new 5.1 extrinsics
- Bump
spec_version
to 5_001_002 (5.1.0-rc2)
Polymesh 5.0.4
changelog
new features
- Allows relayer functionality for the
Balances
module
modified logic
- Extrinsic
Portfolio.movePortfolioFunds
will throw errorInvalidGranularity
if trying to move a fraction of a non-divisible token. - Settlement affirms calls will also check granularity of token transfer when trying to lock the tokens. Will throw a
FailedToLockTokens
error. - Fixes on-chain election issues following offline offenses
Polymesh 5.0.3
Changes relative to 5.0.2
- Updates extrinsic weights for batched functions
- Adds health check and key rotation utilities to Docker images
- Adds aarch64 binaries to release artefacts
- Multisig protocol fees paid correctly by associated identities primary key
Polymesh 5.0.2
changelog
modified logic
- We have moved from substrate 3.0.0 to substrate's monthly-2021-11 tag instead. Allowing us to implement smart contracts. (#1188)
- Update to Substrate monthly 2022-05. (#1241)
- Add permission complexity to the weights of extrinsics:
identity.add_authorization
,identity.set_permission_to_signer
,identity.legacy_set_permission_to_signer
, andidentity.add_secondary_keys_with_authorization
(#1192) - More restrict limits on secondary keys and their permissions. (#1189)
- Add missing check to
relayer.accept_paying_key
. (#1209) - Add missing weight to
change_bridge_exempted
. (#1209) - Use a cost function for
Condition
type for more accurate call weights. (#1204) - Change
multisig.create_create_proposal_as_key
andmultisig.create_proposal_as_identity
to not use themultsig::ProposalIds
map. (#1225) - Adding secondary key and permissions length checks to
cdd_register_did
(#1221) capitalDistribution.distribute()
will throw errorDistributionAmountIsZero
whenamount
is zero and throwDistributionPerShareIsZero
whenper_share
is zero. (#1236)- adding tests for checking multisig errors and secondary key & permission limits (#1227)
- Fixed the balance check for MultiSig primary/secondary keys. (#1224)
- MultiSig balance limit changed from zero to
1.0 POLYX
. (#1224) - Remove dead code
unlink_multisig_signers_from_did()
, since the signers for a multisig are never linked to the identity. (#1224) - minor change and removed test case (#1235)
- Created more specific error types for improving singer already linked type errors (#1226)
Treasury::disbursement()
now checks if the beneficiaries exist and have a primary key. (#1233)- If the treasury disbursement transfer fails (treasury balance locked, beneficiary missing CDD), then event
Treasury::TreasuryDisbursementFailed
. (#1233) Identity.remove_secondary_keys()
now checks if the keys to remove are secondary keys. (#1220)
new features
- Add generated error types to
errors_schema.json
for improved error decoding. (#1167) - Add support for custom asset metadata (key/value pairs). (#1218)
- Asset metadata keys can be either ticker-local or global names, with either on/off chain specifications (value type/format/encoding). (#1218)
- Asset metadata can be permanently locked, or locked for a limited amount of time (1 month, 1 year, etc...). (#1218)
- An optional expire date can be set for the metadata value. This is informational only, the chain doesn't remove the value after the expire date. (#1218)
- On-chain metadata type specification can be used to generate encode/decode code for UIs/Smart Contracts. (#1218)
- Add new asset identifier
AssetIdentifier::FIGI
. (#1234) - Bump transaction version to 3. (#1236)
- Added
Asset::create_asset_with_custom_type
(#1222) - Added
CorporateAction::initiate_corporate_action_and_distribute
(#1222) - Added
ExternalAgent::create_group_and_add_auth
(#1222) - Added
ExternalAgent::create_and_change_custom_group
(#1222) - Adds the smart contracts pallet; see the code for documentation regarding extrinsics and storage items. (#1217)
- Unlimited number of secondary keys. (#1220)
Identity.KeyRecords
maps key toKeyRecord
type. Can be used to see if the key is a primary key, secondary key or multisig signer. Also has the identity/multisig account that the key is linked to. (#1220)- Add
Claim
based asset statistics and transfer rules. (Jurisdiction, Affiliated, Accredited) (#1159)
modified api
- Used
InvalidCDDId
error event inadd_investor_uniqueness_claim
function (#1214) - Add
Asset::set_asset_metadata(Ticker, AssetMetadataKey, AssetMetadataValue, Option<AssetMetadataValueDetails>)
- Set asset metadata value. (#1218) - Add
Asset::set_asset_metadata_details
- Set asset metadata value details (expire, lock status). (#1218) - Add
Asset::register_and_set_local_asset_metadata
- Register and set local asset metadata. (#1218) - Add
Asset::register_asset_metadata_local_type
- Register asset metadata local type. (#1218) - Add
Asset::register_asset_metadata_global_type
- Register asset metadata global type. Only callable by root. (#1218) - Add
storage_deposit_limit
parameter toPolymeshContracts::call
,PolymeshContracts::instantiate_with_code
,PolymeshContracts::instantiate
,PolymeshContracts::instantiate_with_code_perms
,PolymeshContracts::instantiate_with_hash_perms
. (#1241) - Added
upload_code
andremove_code
extrinsics to contracts pallet. (#1241) - Rename
multisig.make_multisig_signer
->multisig.make_multisig_secondary
. The old name was confusing to users, since it adds the multisig as a secondary key to the identity that created the multisig. (#1224) - Deprecated extrinsics that use
Signatory<AccountId>
for secondary keys. (#1237) - Rename deprecated
Identity.remove_secondary_keys
->Identity.remove_secondary_keys_old
. (#1237) - Rename deprecated
Identity.add_secondary_keys_with_authorization
->Identity.add_secondary_keys_with_authorization_old
. (#1237) - Deprecate
Identity.set_permission_to_signer
. (#1237) - Add placeholder for
Identity.legacy_set_permission_to_signer
. (#1237) - Add new extrinsics to replace deprecated extrinsics:
Identity.add_secondary_keys_with_authorization
,Identity.set_secondary_key_permissions
,Identity.remove_secondary_keys
. (#1237) - Contracts
instantiate
APIs now use empty permissions by default. (#1239) - Enable RPC for contracts. (#1239)
- Added error
Treasury::InvalidIdentity
returned fromTreasury::disbursement
if one of the beneficiaries doesn't exist or doesn't have a primary key. (#1233) - Added the primary key to event
Treasury::TreasuryDisbursement
. (#1233) - Added event
Treasury::TreasuryDisbursementFailed
event for disbursements that fail. (#1233) - Removed unused events
Identity.OffChainAuthorizationRevoked
andIdentity.MockInvestorUIDCreated
. (#1220) - Removed extrinsic
Identity.legacy_set_permission_to_signer()
and typeLegacyPermissions
. (#1220) - Replace use of
Signatory<AccountId>
type withAccountId
in identity events:SecondaryKeysRemoved
andSignerLeft
. (#1220) - Use
AccountId
instead ofSecondaryKey<AccountId>
in eventSecondaryKeyPermissionsUpdated
. (to dedup the permissions) (#1220) - Rename extrinsic
Identity.set_permission_to_signer()
toIdentity.set_secondary_key_permissions()
. (#1220) - Replace use of
Signatory<AccountId>
withAccountId
in extrinsics:remove_secondary_keys
,set_secondary_key_permissions
(#1220) - Moved secondary key permissions from
Identity.DidRecords
toIdentity.KeyRecords
. (https://github.com/PolymeshAssociation/P...
Polymesh v4.1.2
Updates to later Substrate branch, pulling in PRs:
paritytech/substrate#8260
paritytech/substrate#8325
paritytech/substrate#11084
This helps to ensure good peer connections.
There is no on-chain logic change related to this change.
Polymesh v4.1.1
Polymesh 4.1.1 Release Notes
changelog
Bump version v4.1.1 and spec: 3010
Update telemetry to use polymesh.network
modified logic
- Add missing check to
relayer.accept_paying_key
. - Add missing weight to
change_bridge_exempted
. - Use a cost function for
Condition
type for more accurate call weights.
Polymesh v4.1.0
Polymesh 4.1.0 Release Notes
Release notes are with respect to changes from Polymesh 4.0.0.
Pending audit & benchmarks
changelog
modified api
- Renamed
IdSeqOverflow
toCounterOverflow
. (#1137) - Removed
CheckpointOverflow
,ScheduleOverflow
,CustomAssetTypeIdOverflow
,LocalCAIdOverflow
, andNumFullAgentsOverflow
in favor ofCounterOverflow
. (#1137) - Added newtypes
FundraiserId
,InstructionId
,LegId
, andVenueId
. No storage changes but shows up in schema. (#1135) - New event
asset.InvestorUniquenessClaimNotAllowed
- This is thrown if an issuer tries to add an investor uniqueness claim for a ticker that has uniqueness disabled. (#1162) identity.add_investor_uniqueness_claim
andidentity.add_investor_uniqueness_claim_v2
will throw errorInvestorUniquenessClaimNotAllowed
if the ticker has IU disabled. (#1162)- Added new extrinsic
rotate_primary_key_to_secondary
. (#1163) - Added new Item to enum
AuthorizationData::RotatePrimaryKeyToSecondary(Permissions)
. (#1163) - Added new Item to enum
AuthorizationType::RotatePrimaryKeyToSecondary
. (#1163)
modified logic
PipId
andSnapshotId
advancement points will now error withpallet_base::Error::IdSeqOverflow
on overflow. (#1127)make_multisig_signer
andjoin_identity
now check that the maximum amount of secondary keys is not exceeded. (#1160)asset.issue
- Now correctly updates the scope balance. (#1162)- An
InvestorUniqueness
claim (both v1 and v2) is not allowed for tickers with Investor Uniqueness disabled. (#1162) make_multisig_signer
- Use empty permissions when adding a multisig as a secondary key. (#1164)create_or_approve_proposal_as_identity
,create_proposal_as_identity
,approve_as_identity
,reject_as_identity
,accept_multisig_signer_as_identity
- Add call permissions checks to make sure that secondary keys for the identity have the right permissions. (#1164)asset.create_asset
- Now checks ifAssetType::Custom
is valid. Will throw errorInvalidCustomAssetTypeId
if a custom asset hasn't been registered for that type id. (#1165)- Fixed behavior of
ActivePipCount
when rescheduling. (#1154) Staking.{bond_extra, rebond}
check that the new active amount >= theminimum_balance
. (#1156)Staking.withdraw_unbonded
is also updated to useminimum_balance
instead of zero. (#1156)Staking.reap_stash
now considersminimum_balance
also. (#1156)Staking.validate
can now throw errorsStashIdentityDoesNotExist
andStashIdentityNotPermissioned
. (#1156)Staking.nominate
now throwsTooManyTargets
ontargets.len() <= MAX_NOMINATIONS
. It also considers blocked validators. (#1156)accept_primary_key
now accepts secondary keys as the new primary key. (#1163)- On
Asset.createAsset
, the eventAgentAdded
is now emitted. - More restrict limits on secondary keys and their permissions.