Creating a smart contract with Vyper

Now let's create a smart contract with Vyper. First, we will create a file with the .vy extension and name it hello.vy, as follows:

name: public(bytes[24])

@public
def __init__():
self.name = "Satoshi Nakamoto"

@public
def change_name(new_name: bytes[24]):
self.name = new_name

@public
def say_hello() -> bytes[32]:
return concat("Hello, ", self.name)

If you come from a Solidity or Python background, you will notice a peculiarity: there is no class (as in the Python programming language) and there is no contract (as in the Solidity programming language) in a smart contract written with the Vyper programming language. However, there is an initializer function. The name of the initializer function is the same as it is in the Python programming language, which is __init__.

While using Python, you can create as many classes as you want in one file. In Vyper, the rule is one smart contract per one file. There is also no class or contract here; the file itself is a class.

This is how you compile this vyper file:

(vyper-venv) $ vyper hello.vy

From this, you will get the following output:

This is the bytecode of the smart contract. Keep in mind that to deploy a smart contract, you need bytecode, but to access a smart contract, you need abi. So how do you get abi? You can do this by running the following command:

(vyper-venv) $ vyper -f json hello.vy

From this, you will get the following output:

If you want to get both abi and bytecode together in a single compilation process, you could combine both flags in the compilation process as follows:

(vyper-venv) $ vyper -f json,bytecode hello.vy

This will give you the following output: