Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
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
26 changes: 8 additions & 18 deletions .github/workflows/all.publish.yml
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
name: Publishing


on:
release:
types:
- published
types: [published]


permissions:
contents: read
Expand All @@ -12,6 +13,8 @@ jobs:
publish:
name: Publish NPM Packages
runs-on: ubuntu-latest
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}

steps:
- name: Harden Runner
Expand All @@ -27,32 +30,19 @@ jobs:
with:
node-version: 20.x

- name: Create file .npmrc
run: |
touch .npmrc
echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" >> .npmrc
cp .npmrc ./packages/ats/contracts/.npmrc
cp .npmrc ./packages/ats/sdk/.npmrc

- name: Install dependencies
run: npm ci

# --- ATS publishing ---
- name: Publish ats/contracts
if: contains(github.ref_name, 'ats')
run: npm run ats:contracts:publish --access=public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: npm run ats:contracts:publish

- name: Publish ats/sdk
if: contains(github.ref_name, 'ats')
run: npm run ats:sdk:publish --access=public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: npm run ats:sdk:publish

# --- Mass Payout publishing ---
- name: Publish mass-payout
if: contains(github.ref_name, 'mp')
run: npm run mass-payout:publish --access=public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: npm run mass-payout:publish
2 changes: 1 addition & 1 deletion apps/ats/web/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@hashgraph/asset-tokenization-dapp",
"version": "1.16.0",
"version": "1.16.1",
"license": "Apache-2.0",
"scripts": {
"build": "tsc && vite build",
Expand Down
6 changes: 3 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

53 changes: 27 additions & 26 deletions packages/ats/contracts/Configuration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -227,46 +227,47 @@ export const CONTRACT_NAMES = [
'Factory',
'BusinessLogicResolver',
'AccessControlFacet',
'Cap',
'ControlList',
'CapFacet',
'ControlListFacet',
'PauseFacet',
'ERC20',
'ERC20Permit',
'ERC20Votes',
'ERC20Facet',
'ERC20PermitFacet',
'ERC1410ScheduledTasksFacet',
'ERC20Votes', //TODO
'ERC1410ReadFacet',
'ERC1410ManagementFacet',
'ERC1410TokenHolderFacet',
'ERC1594',
'ERC1643',
'ERC1644',
'ERC1594Facet',
'ERC1643Facet',
'ERC1644Facet',
'DiamondFacet',
'EquityUSA',
'BondUSA',
'BondUSARead',
'ScheduledSnapshots',
'ScheduledBalanceAdjustments',
'ScheduledTasks',
'Snapshots',
'CorporateActions',
'TransferAndLock',
'Lock',
'AdjustBalances',
'ProtectedPartitions',
'EquityUSAFacet',
'BondUSAFacet',
'BondUSARead', //TODO
'ScheduledSnapshotsFacet',
'ScheduledBalanceAdjustmentsFacet',
'ScheduledTasksFacet',
'SnapshotsFacet',
'CorporateActionsFacet',
'TransferAndLockFacet',
'LockFacet',
'AdjustBalancesFacet',
'ProtectedPartitionsFacet',
'HoldReadFacet',
'HoldTokenHolderFacet',
'HoldManagementFacet',
'TimeTravel',
'Kyc',
'SsiManagement',
'KycFacet',
'SsiManagementFacet',
'ClearingHoldCreationFacet',
'ClearingRedeemFacet',
'ClearingTransferFacet',
'ClearingReadFacet',
'ClearingActionsFacet',
'ExternalPauseManagement',
'ExternalControlListManagement',
'ExternalKycListManagement',
'ERC3643',
'ExternalPauseManagementFacet',
'ExternalControlListManagementFacet',
'ExternalKycListManagementFacet',
'ERC3643Facet',
'FreezeFacet',
'ERC3643ManagementFacet',
'ERC3643ReadFacet',
Expand Down
6 changes: 3 additions & 3 deletions packages/ats/contracts/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -271,9 +271,9 @@ The Asset Tokenization Studio uses a modular diamond pattern architecture where
- `ERC1410ManagementFacet`: Token partition management and administrative functions
- `ERC1410ReadFacet`: Read-only token state queries
- `ERC1410TokenHolderFacet`: Token holder operations (transfers, approvals)
- `ERC20`: Basic ERC20 compatibility layer
- `ERC1594`: Security token issuance and redemption
- `ERC1644`: Controller operations for forced transfers
- `ERC20Facet`: Basic ERC20 compatibility layer
- `ERC1594Facet`: Security token issuance and redemption
- `ERC1644Facet`: Controller operations for forced transfers

**ERC3643 (T-REX) Compliance Facets:**

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -206,17 +206,12 @@
// SPDX-License-Identifier: MIT
pragma solidity 0.8.18;

import {
IStaticFunctionSelectors
} from '../../../interfaces/resolver/resolverProxy/IStaticFunctionSelectors.sol';
import {_ERC1594_RESOLVER_KEY} from '../../constants/resolverKeys.sol';
import {_ISSUER_ROLE, _AGENT_ROLE} from '../../constants/roles.sol';
import {IERC1594} from '../../interfaces/ERC1400/IERC1594.sol';
import {Common} from '../../common/Common.sol';
import {_DEFAULT_PARTITION} from '../../../layer_0/constants/values.sol';
import {Common} from '../../common/Common.sol';

contract ERC1594 is IERC1594, IStaticFunctionSelectors, Common {
abstract contract ERC1594 is IERC1594, Common {
// solhint-disable-next-line func-name-mixedcase
function initialize_ERC1594()
external
Expand Down Expand Up @@ -447,51 +442,4 @@ contract ERC1594 is IERC1594, IStaticFunctionSelectors, Common {
);
return (status, statusCode, reason);
}

function getStaticResolverKey()
external
pure
override
returns (bytes32 staticResolverKey_)
{
staticResolverKey_ = _ERC1594_RESOLVER_KEY;
}

function getStaticFunctionSelectors()
external
pure
override
returns (bytes4[] memory staticFunctionSelectors_)
{
staticFunctionSelectors_ = new bytes4[](9);
uint256 selectorsIndex;
staticFunctionSelectors_[selectorsIndex++] = this
.initialize_ERC1594
.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.transferWithData
.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.transferFromWithData
.selector;
staticFunctionSelectors_[selectorsIndex++] = this.isIssuable.selector;
staticFunctionSelectors_[selectorsIndex++] = this.issue.selector;
staticFunctionSelectors_[selectorsIndex++] = this.redeem.selector;
staticFunctionSelectors_[selectorsIndex++] = this.redeemFrom.selector;
staticFunctionSelectors_[selectorsIndex++] = this.canTransfer.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.canTransferFrom
.selector;
}

function getStaticInterfaceIds()
external
pure
override
returns (bytes4[] memory staticInterfaceIds_)
{
staticInterfaceIds_ = new bytes4[](1);
uint256 selectorsIndex;
staticInterfaceIds_[selectorsIndex++] = type(IERC1594).interfaceId;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -206,21 +206,21 @@
// SPDX-License-Identifier: MIT
pragma solidity 0.8.18;

import {_ERC3643_MANAGEMENT_RESOLVER_KEY} from '../constants/resolverKeys.sol';
import {IERC3643Management} from '../interfaces/ERC3643/IERC3643Management.sol';
import {
IStaticFunctionSelectors
} from '../../interfaces/resolver/resolverProxy/IStaticFunctionSelectors.sol';
import {ERC3643Management} from './ERC3643Management.sol';
} from '../../../interfaces/resolver/resolverProxy/IStaticFunctionSelectors.sol';
import {_ERC1594_RESOLVER_KEY} from '../../constants/resolverKeys.sol';
import {IERC1594} from '../../interfaces/ERC1400/IERC1594.sol';
import {ERC1594} from './ERC1594.sol';

contract ERC3643ManagementFacet is IStaticFunctionSelectors, ERC3643Management {
contract ERC1594Facet is ERC1594, IStaticFunctionSelectors {
function getStaticResolverKey()
external
pure
override
returns (bytes32 staticResolverKey_)
{
staticResolverKey_ = _ERC3643_MANAGEMENT_RESOLVER_KEY;
staticResolverKey_ = _ERC1594_RESOLVER_KEY;
}

function getStaticFunctionSelectors()
Expand All @@ -232,21 +232,21 @@ contract ERC3643ManagementFacet is IStaticFunctionSelectors, ERC3643Management {
staticFunctionSelectors_ = new bytes4[](9);
uint256 selectorsIndex;
staticFunctionSelectors_[selectorsIndex++] = this
.initialize_ERC3643
.initialize_ERC1594
.selector;
staticFunctionSelectors_[selectorsIndex++] = this.setName.selector;
staticFunctionSelectors_[selectorsIndex++] = this.setSymbol.selector;
staticFunctionSelectors_[selectorsIndex++] = this.setOnchainID.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.setIdentityRegistry
.transferWithData
.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.setCompliance
.transferFromWithData
.selector;
staticFunctionSelectors_[selectorsIndex++] = this.addAgent.selector;
staticFunctionSelectors_[selectorsIndex++] = this.removeAgent.selector;
staticFunctionSelectors_[selectorsIndex++] = this.isIssuable.selector;
staticFunctionSelectors_[selectorsIndex++] = this.issue.selector;
staticFunctionSelectors_[selectorsIndex++] = this.redeem.selector;
staticFunctionSelectors_[selectorsIndex++] = this.redeemFrom.selector;
staticFunctionSelectors_[selectorsIndex++] = this.canTransfer.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.recoveryAddress
.canTransferFrom
.selector;
}

Expand All @@ -258,7 +258,6 @@ contract ERC3643ManagementFacet is IStaticFunctionSelectors, ERC3643Management {
{
staticInterfaceIds_ = new bytes4[](1);
uint256 selectorsIndex;
staticInterfaceIds_[selectorsIndex++] = type(IERC3643Management)
.interfaceId;
staticInterfaceIds_[selectorsIndex++] = type(IERC1594).interfaceId;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -210,12 +210,8 @@ import {IERC1643} from '../../interfaces/ERC1400/IERC1643.sol';
import {_DOCUMENTER_ROLE} from '../../constants/roles.sol';
import {_ERC1643_STORAGE_POSITION} from '../../constants/storagePositions.sol';
import {Common} from '../../common/Common.sol';
import {
IStaticFunctionSelectors
} from '../../../interfaces/resolver/resolverProxy/IStaticFunctionSelectors.sol';
import {_ERC1643_RESOLVER_KEY} from '../../constants/resolverKeys.sol';

contract ERC1643 is IERC1643, IStaticFunctionSelectors, Common {
abstract contract ERC1643 is IERC1643, Common {
struct Document {
bytes32 docHash; // Hash of the document
uint256 lastModified; // Timestamp at which document details was last modified
Expand Down Expand Up @@ -326,44 +322,6 @@ contract ERC1643 is IERC1643, IStaticFunctionSelectors, Common {
return _erc1643Storage().docNames;
}

function getStaticResolverKey()
external
pure
override
returns (bytes32 staticResolverKey_)
{
staticResolverKey_ = _ERC1643_RESOLVER_KEY;
}

function getStaticFunctionSelectors()
external
pure
override
returns (bytes4[] memory staticFunctionSelectors_)
{
staticFunctionSelectors_ = new bytes4[](4);
uint256 selectorsIndex;
staticFunctionSelectors_[selectorsIndex++] = this.getDocument.selector;
staticFunctionSelectors_[selectorsIndex++] = this.setDocument.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.removeDocument
.selector;
staticFunctionSelectors_[selectorsIndex++] = this
.getAllDocuments
.selector;
}

function getStaticInterfaceIds()
external
pure
override
returns (bytes4[] memory staticInterfaceIds_)
{
staticInterfaceIds_ = new bytes4[](1);
uint256 selectorsIndex;
staticInterfaceIds_[selectorsIndex++] = type(IERC1643).interfaceId;
}

function _erc1643Storage()
internal
pure
Expand Down
Loading