Skip to content

chore: staging ledger and minter init args#147

Open
maciejdfinity wants to merge 2 commits intomainfrom
maciej-args
Open

chore: staging ledger and minter init args#147
maciejdfinity wants to merge 2 commits intomainfrom
maciej-args

Conversation

@maciejdfinity
Copy link
Copy Markdown
Contributor

@maciejdfinity maciejdfinity commented Apr 17, 2026

Accounts

  • minting_account: Principal ljyxk-riaaa-aaaar-qb5mq-cai (the minter) with no subaccount. Transfers to this account burn tokens; transfers from it mint them.
  • fee_collector_account: Same minter principal but with subaccount 0x…0fee. Collected transfer_fee amounts accumulate here instead of being destroyed.

Supply & token metadata

  • initial_balances = vec {}: no pre-minted balances at genesis.
  • transfer_fee = 50: fee in smallest units (lamports) charged per ICRC-1 transfer.
  • decimals = opt 9: 9 decimals, matching SOL (1 SOL = 1e9 lamports).
  • token_name / token_symbol = "ckDevnetSOL": display name and ticker.
  • metadata: a single icrc1:logo entry with the ckDevnetSOL SVG embedded as a base64 data URI.

Archive

  • trigger_threshold = u64::MAX: effectively disables automatic archive spawning for staging.
  • num_blocks_to_archive = 10_000: if triggered, move 10k blocks per archive op.
  • node_max_memory_size_bytes = 3 GiB: per-archive-node memory cap.
  • controller_id = r7inp-6aaaa-aaaaa-aaabq-cai (NNS root): controller set on archive canisters.
  • cycles_for_archive_creation = 100 T: cycles attached when spawning a new archive.
  • max_message_size_bytes, more_controller_ids, max_transactions_per_response: left defaulted.

Feature flags

  • max_memo_length = opt 80: allow ICRC-1 memos up to 80 bytes.
  • feature_flags = { icrc2 = true }: enables ICRC-2 (approve/transfer_from).
  • index_principal = null: no paired index canister configured yet.

Net effect: a 9-decimal ICRC-1/2 ledger named ckDevnetSOL, minted/burned by the staging minter, fees collected into a dedicated subaccount, archiving effectively disabled by a max-u64
threshold.

Copilot AI review requested due to automatic review settings April 17, 2026 13:04
@maciejdfinity maciejdfinity marked this pull request as ready for review April 17, 2026 13:05
@maciejdfinity maciejdfinity requested a review from a team as a code owner April 17, 2026 13:05
@maciejdfinity maciejdfinity changed the title chore: staging ledger and minter args chore: staging ledger and minter init args Apr 17, 2026
Copy link
Copy Markdown
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

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

Pull request overview

Adds explicit initialization arguments for the staging deployment of the ckSOL minter and ICRC-1 ledger canisters.

Changes:

  • Define init_args for cksol_minter in staging (RPC/ledger principals, key name, Solana network, and fee/threshold parameters).
  • Define init_args for cksol_ledger in staging (minting/fee-collector accounts, token metadata/logo, and archive options).

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread icp.yaml
num_blocks_to_archive = 10_000 : nat64;
node_max_memory_size_bytes = opt (3_221_225_472 : nat64);
max_message_size_bytes = null;
controller_id = principal "r7inp-6aaaa-aaaaa-aaabq-cai";
Copy link

Copilot AI Apr 17, 2026

Choose a reason for hiding this comment

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

archive_options.controller_id is set to principal "r7inp-6aaaa-aaaaa-aaabq-cai" (a well-known system/NNS canister principal). This would make newly created archive canisters controlled by that principal rather than by your staging deployment controllers, which typically prevents you from upgrading/managing archives. Set controller_id (and/or more_controller_ids) to principals that should actually control the archive canisters in staging.

Suggested change
controller_id = principal "r7inp-6aaaa-aaaaa-aaabq-cai";
controller_id = principal "ljyxk-riaaa-aaaar-qb5mq-cai";

Copilot uses AI. Check for mistakes.
Comment thread icp.yaml Outdated
record { "icrc1:logo"; variant { Text = "data:image/svg+xml;base64,<svg width="146" height="146" viewBox="0 0 146 146" fill="none" xmlns="http://www.w3.org/2000/svg">
<g clip-path="url(#clip0_1024_33)">
<path d="M73 0C113.312 0 146 32.6878 146 73C146 113.312 113.312 146 73 146C32.6878 146 0 113.312 0 73C0 32.6878 32.6878 0 73 0Z" fill="white"/>
<path d="M73 0.5C113.036 0.5 145.5 32.9639 145.5 73C145.5 113.036 113.036 145.5 73 145.5C32.9639 145.5 0.5 113.036 0.5 73C0.5 32.9639 32.9639 0.5 73 0.5Z" stroke="black" stroke-opacity="0.05"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M16.3844 77.2188C18.4122 105.202 40.7989 127.589 68.7822 129.617V135.943C37.3111 133.834 12.1666 108.69 10.0577 77.2188H16.3844Z" fill="url(#paint0_linear_1024_33)"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M68.7822 16.3848C40.7989 18.4126 18.4122 40.7992 16.3844 68.7825H10.0577C12.0855 37.3114 37.3111 12.0859 68.7822 10.0581V16.3848Z" fill="#29ABE2"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M129.616 68.7017C127.588 40.7184 105.201 18.3317 77.2177 16.304V9.97729C108.689 12.0862 133.914 37.2306 135.942 68.7017H129.616Z" fill="url(#paint1_linear_1024_33)"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M77.2178 129.617C105.201 127.589 127.588 105.202 129.616 77.2188H135.942C133.914 108.69 108.689 133.834 77.2178 135.943V129.617Z" fill="#29ABE2"/>
<g clip-path="url(#clip1_1024_33)">
<path d="M107.509 85.3057L96.141 97.1828C95.8939 97.4408 95.5949 97.6465 95.2626 97.7871C94.9304 97.9277 94.5719 98.0002 94.2098 98H40.3197C40.0626 98 39.8111 97.9268 39.596 97.7895C39.381 97.6521 39.2119 97.4565 39.1094 97.2267C39.0069 96.997 38.9755 96.7431 39.0191 96.4963C39.0627 96.2494 39.1794 96.0203 39.3548 95.8371L50.7314 83.96C50.9779 83.7027 51.2759 83.4974 51.6071 83.3569C51.9383 83.2163 52.2956 83.1435 52.6569 83.1428H106.544C106.801 83.1428 107.053 83.2161 107.268 83.3534C107.483 83.4908 107.652 83.6864 107.755 83.9161C107.857 84.1459 107.888 84.3997 107.845 84.6466C107.801 84.8935 107.684 85.1226 107.509 85.3057ZM96.141 61.3885C95.8939 61.1305 95.5949 60.9248 95.2626 60.7843C94.9304 60.6437 94.5719 60.5713 94.2098 60.5715H40.3197C40.0626 60.5715 39.8111 60.6446 39.596 60.782C39.381 60.9194 39.2119 61.1149 39.1094 61.3446C39.0069 61.5744 38.9755 61.8283 39.0191 62.0752C39.0627 62.322 39.1794 62.5511 39.3548 62.7343L50.7314 74.6115C50.9779 74.8688 51.2759 75.074 51.6071 75.2146C51.9383 75.3551 52.2956 75.428 52.6569 75.4285H106.544C106.801 75.4285 107.053 75.3554 107.268 75.218C107.483 75.0806 107.652 74.8851 107.755 74.6554C107.857 74.4256 107.888 74.1717 107.845 73.9248C107.801 73.678 107.684 73.4489 107.509 73.2657L96.141 61.3885ZM40.3197 52.8572H94.2098C94.5719 52.8573 94.9304 52.7849 95.2626 52.6443C95.5949 52.5037 95.8939 52.298 96.141 52.04L107.509 40.1629C107.684 39.9797 107.801 39.7506 107.845 39.5037C107.888 39.2569 107.857 39.003 107.755 38.7732C107.652 38.5435 107.483 38.3479 107.268 38.2106C107.053 38.0732 106.801 38 106.544 38H52.6569C52.2956 38.0006 51.9383 38.0734 51.6071 38.214C51.2759 38.3545 50.9779 38.5598 50.7314 38.8171L39.3578 50.6943C39.1825 50.8772 39.0659 51.1061 39.0222 51.3527C38.9785 51.5993 39.0096 51.853 39.1117 52.0826C39.2139 52.3122 39.3826 52.5078 39.5971 52.6454C39.8117 52.783 40.0629 52.8565 40.3197 52.8572Z" fill="url(#paint2_linear_1024_33)"/>
</g>
<path d="M21.5 112C21.5 102.209 29.4368 94.2727 39.2273 94.2727H107.773C117.563 94.2727 125.5 102.209 125.5 112C125.5 121.79 117.563 129.727 107.773 129.727H39.2273C29.4368 129.727 21.5 121.79 21.5 112Z" fill="white"/>
<path d="M39.2275 94.7727H107.772C117.287 94.7727 125 102.486 125 112C125 121.514 117.287 129.227 107.772 129.227H39.2275C29.7133 129.227 22.0001 121.514 22 112C22 102.486 29.7132 94.7727 39.2275 94.7727Z" stroke="black" stroke-opacity="0.05"/>
<path d="M54.4721 106.682C53.0847 106.682 51.5723 107.399 49.9738 108.811C49.2154 109.48 48.5605 110.197 48.0694 110.77C48.0694 110.77 48.0694 110.77 48.0737 110.775V110.77C48.0737 110.77 48.8492 111.622 49.7066 112.534C50.1677 111.983 50.8313 111.231 51.5939 110.553C53.0158 109.297 53.9421 109.032 54.4721 109.032C56.4672 109.032 58.0872 110.627 58.0872 112.587C58.0872 114.533 56.4628 116.128 54.4721 116.141C54.3816 116.141 54.2653 116.128 54.1188 116.097C54.7005 116.349 55.3253 116.532 55.9199 116.532C59.5737 116.532 60.289 114.129 60.3364 113.955C60.4441 113.516 60.5001 113.056 60.5001 112.582C60.5001 109.332 57.7942 106.682 54.4721 106.682Z" fill="url(#paint3_linear_1024_33)"/>
<path d="M41.7102 118.5C43.0976 118.5 44.61 117.783 46.2085 116.371C46.9669 115.702 47.6218 114.985 48.113 114.411C48.113 114.411 48.113 114.411 48.1086 114.407V114.411C48.1086 114.411 47.3331 113.56 46.4757 112.647C46.0146 113.199 45.3511 113.951 44.5884 114.629C43.1665 115.884 42.2401 116.149 41.7102 116.149C39.7152 116.145 38.0951 114.551 38.0951 112.591C38.0951 110.644 39.7195 109.05 41.7102 109.037C41.8007 109.037 41.917 109.05 42.0635 109.08C41.4818 108.828 40.857 108.646 40.2624 108.646C36.6086 108.646 35.8976 111.049 35.8459 111.218C35.7382 111.661 35.6822 112.117 35.6822 112.591C35.6822 115.85 38.3881 118.5 41.7102 118.5Z" fill="url(#paint4_linear_1024_33)"/>
<path d="M55.9115 116.48C54.0414 116.432 52.0982 114.946 51.7018 114.576C50.6763 113.621 48.3107 111.035 48.1255 110.831C46.3934 108.872 44.0451 106.682 41.7097 106.682H41.7054H41.7011C38.8659 106.695 36.4832 108.633 35.8455 111.218C35.8929 111.048 36.8279 108.598 40.2577 108.685C42.1277 108.733 44.0796 110.24 44.4803 110.61C45.5058 111.565 47.8713 114.151 48.0566 114.355C49.7887 116.31 52.137 118.5 54.4723 118.5H54.4766H54.4809C57.3161 118.487 59.7031 116.549 60.3365 113.964C60.2848 114.133 59.3455 116.562 55.9115 116.48Z" fill="#29ABE2"/>
<path d="M80.343 109.028H76.6369V118.591H74.337V109.028H70.6309V106.86H80.343V109.028ZM89.6605 118.591H82.3143V106.86H89.6605V109.011H84.5976V111.691H89.1806V113.727H84.5976V116.44H89.6605V118.591ZM100.135 109.656L98.0838 110.285C97.968 109.64 97.4385 108.631 95.9494 108.631C94.8409 108.631 94.1129 109.342 94.1129 110.12C94.1129 110.765 94.5265 111.278 95.3869 111.443L97.0249 111.758C99.1592 112.171 100.301 113.561 100.301 115.216C100.301 117.019 98.7952 118.839 96.0652 118.839C92.9547 118.839 91.5814 116.837 91.3994 115.166L93.5172 114.603C93.6165 115.762 94.4272 116.804 96.0818 116.804C97.3061 116.804 97.9845 116.192 97.9845 115.365C97.9845 114.686 97.4716 114.157 96.5616 113.975L94.9236 113.644C93.054 113.263 91.8461 112.055 91.8461 110.285C91.8461 108.2 93.7158 106.612 95.9329 106.612C98.7787 106.612 99.8707 108.333 100.135 109.656ZM111.276 109.028H107.57V118.591H105.27V109.028H101.564V106.86H111.276V109.028Z" fill="#7A64EB"/>
</g>
<defs>
<linearGradient id="paint0_linear_1024_33" x1="53.0142" y1="123.339" x2="13.578" y2="90.1235" gradientUnits="userSpaceOnUse">
<stop offset="0.21" stop-color="#ED1E79"/>
<stop offset="1" stop-color="#522785"/>
</linearGradient>
<linearGradient id="paint1_linear_1024_33" x1="125.446" y1="49.9083" x2="86.0102" y2="16.6933" gradientUnits="userSpaceOnUse">
<stop offset="0.21" stop-color="#F15A24"/>
<stop offset="0.68" stop-color="#FBB03B"/>
</linearGradient>
<linearGradient id="paint2_linear_1024_33" x1="44.8129" y1="99.43" x2="99.6772" y2="35.9435" gradientUnits="userSpaceOnUse">
<stop offset="0.08" stop-color="#9945FF"/>
<stop offset="0.3" stop-color="#8752F3"/>
<stop offset="0.5" stop-color="#5497D5"/>
<stop offset="0.6" stop-color="#43B4CA"/>
<stop offset="0.72" stop-color="#28E0B9"/>
<stop offset="0.97" stop-color="#19FB9B"/>
</linearGradient>
<linearGradient id="paint3_linear_1024_33" x1="51.3342" y1="107.461" x2="59.6007" y2="115.95" gradientUnits="userSpaceOnUse">
<stop offset="0.21" stop-color="#F15A24"/>
<stop offset="0.6841" stop-color="#FBB03B"/>
</linearGradient>
<linearGradient id="paint4_linear_1024_33" x1="44.8481" y1="117.721" x2="36.5815" y2="109.232" gradientUnits="userSpaceOnUse">
<stop offset="0.21" stop-color="#ED1E79"/>
<stop offset="0.8929" stop-color="#522785"/>
</linearGradient>
<clipPath id="clip0_1024_33">
<rect width="146" height="146" fill="white"/>
</clipPath>
<clipPath id="clip1_1024_33">
<rect width="68.8636" height="60" fill="white" transform="translate(39 38)"/>
</clipPath>
</defs>
</svg>
" } };
};
archive_options = record {
trigger_threshold = 18_446_744_073_709_551_615 : nat64;
Copy link

Copilot AI Apr 17, 2026

Choose a reason for hiding this comment

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

archive_options.trigger_threshold is set to the maximum nat64 value, which effectively disables archiving. That can lead to unbounded ledger growth and eventual memory/performance issues if staging sees sustained traffic. Consider setting a realistic threshold (and optionally tune num_blocks_to_archive) or document explicitly that archiving is intentionally disabled for staging.

Suggested change
trigger_threshold = 18_446_744_073_709_551_615 : nat64;
trigger_threshold = 20_000 : nat64;

Copilot uses AI. Check for mistakes.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants