> ## Documentation Index
> Fetch the complete documentation index at: https://docs.hedera.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Create a token

<Info>
  Check out the "Getting Started with the Hedera Token Service" video tutorial in JavaScript [here](https://youtu.be/lp3mwdYEZEk).
</Info>

Create a new fungible or non-fungible token (NFT) on the Hedera network. After you submit the transaction to the Hedera network, you can obtain the new token ID by requesting the receipt.

You can also create, access, or transfer HTS tokens using smart contracts - see [Hedera Service Solidity Libraries](https://docs.hedera.com/guides/docs/sdks/smart-contracts/hedera-service-solidity-libraries) and [Supported ERC Token Standards](https://docs.hedera.com/guides/core-concepts/smart-contracts/supported-erc-token-standards).

<Warning>
  **Token Keys**

  * If any of the token key types (KYC key, Wipe key, Metadata key, etc) are not set during the creation of the token, you will not be able to update the token and add them in the future
  * If any of the token key types (KYC key, Wipe key, Metadata key, etc) are set during the creation of the token, you will not be able to remove them in the future
</Warning>

#### **NFTs**

For non-fungible tokens, the token ID represents an NFT class. Once the token is created, you must mint each NFT using the [token mint](/native/tokens/mint) operation.

<Warning>
  **Note**: The initial supply for an NFT is required to be set to 0.
</Warning>

#### **Token Properties**

<Card title="Token Properties" href="/learn/core-concepts/tokens/properties" />

**Transaction Signing Requirements**

* Treasury key is required to sign
* Admin key, if specified
* Transaction fee payer key

**Transaction Fees**

* For fungible tokens, a [`CryptoTransfer`](/learn/networks/mainnet/fees) fee is added to transfer the newly created token to the treasury account
* Please see the transaction and query [fees](/learn/networks/mainnet/fees#transaction-and-query-fees) table for the base transaction fee
* Please use the [Hedera fee estimator](https://hedera.com/fees) to estimate your transaction fee cost

## Constructor

| **Constructor**                | **Description**                               |
| ------------------------------ | --------------------------------------------- |
| `new TokenCreateTransaction()` | Initializes the TokenCreateTransaction object |

## Transaction Properties

| **Method**                                    | ****Type****     | **Requirement** |
| --------------------------------------------- | ---------------- | --------------- |
| `setTokenName(<name>)`                        | String           | Required        |
| `setTokenSymbol(<symbol>)`                    | String           | Required        |
| `setDecimals(<decimals>)`                     | int              | Optional        |
| `setInitialSupply(<initialSupply>)`           | long             | Optional        |
| `setTreasuryAccountId(<treasuryAccountId>)`   | AccountId        | Required        |
| `setAdminKey(<key>)`                          | Key              | Optional        |
| `setKycKey(<key>)`                            | Key              | Optional        |
| `setFreezeKey(<key>)`                         | Key              | Optional        |
| `setWipeKey(<key>)`                           | Key              | Optional        |
| `setSupplyKey(<key>)`                         | Key              | Optional        |
| `setPauseKey(<key>)`                          | Key              | Optional        |
| `setFeeScheduleKey(<key>)`                    | Key              | Optional        |
| `setMetadataKey(<key>)`                       | Key              | Optional        |
| `setFreezeDefault(<freezeDefault>)`           | boolean          | Optional        |
| `setExpirationTime(<expirationTime>)`         | Instant          | Optional        |
| `setAutoRenewAccountId(<autoRenewAccountId>)` | AccountId        | Optional        |
| `setAutoRenewPeriod(<autoRenewPeriod>)`       | Duration         | Optional        |
| `setTokenMemo(<memo>)`                        | String           | Optional        |
| `setTokenType(<tokenType>)`                   | TokenType        | Optional        |
| `setSupplyType(<supplyType>)`                 | TokenSupplyType  | Optional        |
| `setMaxSupply(<maxSupply>)`                   | long             | Optional        |
| `setCustomFees(<customFees>)`                 | List\<CustomFee> | Optional        |
| `setMetadata(<metadata>)`                     | byte\[]          | Optional        |
| `setHighVolume(<highVolume>)`                 | boolean          | Optional        |

## Get Transaction Values

| **Method**               | ****Type****    | **Description**                                                                                                                               |
| ------------------------ | --------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |
| `getTokenName()`         | String          | Returns the name of the token                                                                                                                 |
| `getTokenSymbol()`       | String          | Returns the symbol of the token                                                                                                               |
| `getDecimals()`          | int             | Returns the number of decimals                                                                                                                |
| `getInitialSupply()`     | long            | Returns the initial supply of tokens                                                                                                          |
| `getTreasuryAccountId()` | AccountId       | Returns the treasury account ID                                                                                                               |
| `getAdminKey()`          | Key             | Returns the admin key                                                                                                                         |
| `getKycKey()`            | Key             | Returns the KYC key                                                                                                                           |
| `getFreezeKey()`         | Key             | Returns the freeze key                                                                                                                        |
| `getWipeKey()`           | Key             | Returns the wipe key                                                                                                                          |
| `getSupplyKey()`         | Key             | Returns the supply key                                                                                                                        |
| `getPauseKey()`          | Key             | Returns the pause key                                                                                                                         |
| `getFeeScheduleKey()`    | Key             | Returns the fee schedule key                                                                                                                  |
| `getMetadataKey()`       | Key             | Returns the metadata key                                                                                                                      |
| `getFreezeDefault()`     | boolean         | Returns the freeze default value                                                                                                              |
| `getTokenType()`         | TokenType       | Returns the token type                                                                                                                        |
| `getSupplyType()`        | TokenSupplyType | Returns the supply type                                                                                                                       |
| `getMaxSupply()`         | long            | Returns the max supply                                                                                                                        |
| `getHighVolume()`        | boolean         | Returns whether this transaction uses [high-volume throttles](/learn/core-concepts/high-volume-entity-creation#high-volume-throttle-capacity) |

<Info>
  This transaction supports [high-volume entity creation](/learn/core-concepts/high-volume-entity-creation)
  (HIP-1313). Setting `setHighVolume(true)` routes the transaction through dedicated
  high-volume throttle capacity with variable-rate pricing. Always pair this with
  `setMaxTransactionFee()` to cap your costs.
</Info>

<CodeGroup>
  ```java Java theme={null}
  //Create the transaction
  TokenCreateTransaction transaction = new TokenCreateTransaction()
      .setTokenName("Your Token Name")
      .setTokenSymbol("F")
      .setTreasuryAccountId(treasuryAccountId)
      .setInitialSupply(5000)
      .setAdminKey(adminKey.getPublicKey())
      .setMetadataKey(metadataKey)
      .setMetadata(metadata)
      .setMaxTransactionFee(new Hbar(30)); //Change the default max transaction fee

  //Build the unsigned transaction, sign with admin private key of the token, sign with the token treasury private key, submit the transaction to a Hedera network
  TransactionResponse txResponse = transaction.freezeWith(client).sign(adminKey).sign(treasuryKey).execute(client);

  //Request the receipt of the transaction
  TransactionReceipt receipt = txResponse.getReceipt(client);

  //Get the token ID from the receipt
  TokenId tokenId = receipt.tokenId;

  System.out.println("The new token ID is " + tokenId);
  //v2.0.1
  ```

  ```javascript JavaScript theme={null}
  //Create the transaction and freeze for manual signing
  const transaction = await new TokenCreateTransaction()
      .setTokenName("Your Token Name")
      .setTokenSymbol("F")
      .setTreasuryAccountId(treasuryAccountId)
      .setInitialSupply(5000)
      .setAdminKey(adminKey.publicKey)
      .setMetadataKey(metadataKey)
      .setMetadata(metadata)
      .setMaxTransactionFee(new Hbar(30)) //Change the default max transaction fee
      .freezeWith(client);

  //Sign the transaction with the token adminKey and the token treasury account private key
  const signTx = await (await transaction.sign(adminKey)).sign(treasuryKey);

  //Sign the transaction with the client operator private key and submit to a Hedera network
  const txResponse = await signTx.execute(client);

  //Get the receipt of the transaction
  const receipt = await txResponse.getReceipt(client);

  //Get the token ID from the receipt
  const tokenId = receipt.tokenId;

  console.log("The new token ID is " + tokenId);
  //v2.0.28
  ```

  ```go Go theme={null}
  //Create the transaction and freeze the unsigned transaction
  tokenCreateTransaction, err := hedera.NewTokenCreateTransaction().
      SetTokenName("Your Token Name").
      SetTokenSymbol("F").
      SetTreasuryAccountId(treasuryAccountId).
      SetInitialSupply(5000).
      SetAdminKey(adminKey.PublicKey()).
      SetMetadataKey(metadataKey).
      SetTokenMetadata(metadata).
      SetMaxTransactionFee(hedera.HbarFrom(30, hedera.HbarUnits.Hbar)).
      FreezeWith(client)

  if err != nil {
      panic(err)
  }

  //Sign with the admin private key of the token, sign with the token treasury private key, sign with the client operator private key and submit the transaction to a Hedera network
  txResponse, err := tokenCreateTransaction.Sign(adminKey).Sign(treasuryKey).Execute(client)

  if err != nil {
      panic(err)
  }

  //Request the receipt of the transaction
  receipt, err := txResponse.GetReceipt(client)

  if err != nil {
      panic(err)
  }

  //Get the token ID from the receipt
  tokenId := receipt.TokenID

  fmt.Printf("The new token ID is %v\n", tokenId)
  //v2.1.0
  ```

  ```rust Rust theme={null}
  // Create the transaction
  let transaction = TokenCreateTransaction::new()
      .name("Your Token Name")
      .symbol("F")
      .treasury_account_id(treasury_account_id)
      .initial_supply(5000)
      .admin_key(admin_key.public_key())
      .metadata_key(metadata_key)
      .metadata(metadata)
      .max_transaction_fee(Hbar::from(30)); // Change the default max transaction fee

  // Build the unsigned transaction, sign with admin private key of the token, sign with the token treasury private key
  let tx_response = transaction
      .freeze_with(&client)?
      .sign(admin_key)
      .sign(treasury_key)
      .execute(&client).await?;

  // Request the receipt of the transaction
  let receipt = tx_response.get_receipt(&client).await?;

  // Get the token ID from the receipt
  let token_id = receipt.token_id.unwrap();

  println!("The new token ID is {:?}", token_id);

  // v0.34.0
  ```
</CodeGroup>
