亚洲十八**毛片_亚洲综合影院_五月天精品一区二区三区_久久久噜噜噜久久中文字幕色伊伊 _欧美岛国在线观看_久久国产精品毛片_欧美va在线观看_成人黄网大全在线观看_日韩精品一区二区三区中文_亚洲一二三四区不卡

COMP26020代做、代寫Lab 5 - Solidity

時間:2024-05-03  來源:  作者: 我要糾錯



COMP26020: Programming Languages and Paradigms
Lab 5 - Solidity
Joseph Razavi and Richard Banach
1 Introduction
This lab exercise is about learning a programming language with unusual aspects from its documentation.
We focus on the Solidity programming language, in particular Solidity version 6, which you can read about
here:
https://docs.soliditylang.org/en/v0.6.0/
Solidity is a language designed to write so-called “smart contracts”. These are pieces of code which are
supposed to run on a public “blockchain” – a system which keeps a log of every event which happens, and
where no user can single-handedly affect what happens. That means that once your code is deployed, you
can no longer influence it, unless you have programmed mechanisms to do so. And if you find a bug, the
bug is there forever!
In addition, the blockchain is designed to support payments of various kinds – for instance a smart
contract has a balance of currency (called ‘wei’ for the Etherium blockchain on which Solidity contracts run)
which it must use to pay for its own computing resources. Contracts can charge each other and pay each
other for services.
Whether or not any of this is a sensible technical or social project is perhaps debatable, but it certainly
creates interesting design challenges for a programming language – and where weird programming languages
lead, let us follow!
Read about Solidity’s notion of a contract, and its execution model (the ‘Ethereum Virtual Machine’) here:
https://docs.soliditylang.org/en/v0.6.0/introduction-to-smart-contracts.html
Refer to the Solidity documentation to complete the exercises below. Aside from the above these sections
are particularly useful:
• https://docs.soliditylang.org/en/v0.6.0/solidity-by-example.html
• https://docs.soliditylang.org/en/v0.6.0/solidity-in-depth.html
If you prefer videos, I have made available on Blackboard some videos designed to help you get started.
Note these videos belong to the lab and are not part of the content of any week. Solidity will be used only
for the lab, and is not examinable.
In this lab exercise, rather than deploying our code on the real public blockchain (and having to pay
to run it!) we will use a simulated version of the Etherium Virtual Machine which is used for developing
code and testing it before deploying it for real. You must use the version provided on Blackboard; see next
section.
1
2 Setup
Make sure you have downloaded Remix from Blackboard:
https://online.manchester.ac.uk/bbcswebdav/courses/I3132-COMP-26020-1231-1YR-040494/remix-d624303.zip
(If the link above does not work, check the Lab 5 folder on Blackboard for information.)
and that you can compile and run programs. To do this, you might need to click on the ‘plug’ icon on the
left hand menu, and made sure ‘Solidity compiler’ and ‘deploy and run transactions’ are enabled. This will
let you compile and run Solidity programs in Remix as seen in the videos. Remix is a browser based editor,
and has been tested for this course on Google Chrome on Linux and Windows. With other browsers you
may get strange behaviour. It is better to edit in a separate text editor and paste into Remix for testing, as
it can have problems with saving files and allowing text to be copied out of it in some browsers. Make sure
you always have a copy of your code in another editor so that you don’t lose your work. Clone the gitlab
repository
26020-lab5-S-Solidity_
where is replaced by your username. This contains the files you will need for the exercise.
3 Background
The exercises concern three contracts which should interact with each other, alongside other contracts which
we assume exist (but do not implement or worry about the implementation of). The first contract we consider is a ‘paylock’. The idea is that a supplier does some work, which can then be collected by a customer.
If the customer collects early, they get a discount, and how much discount they get depends on how early:
there are two deadlines. If they miss the second deadline they forfeit their discount altogether.
Done_2 Forfeit
Done_1 Delay
 Working Completed
Start
Signal
Collect_1_Y Collect_1_N
Collect_2_Y Collect_2_N
The blobs indicate possible states of the paylock, and the arrows represent function calls. The ‘Start’
arrow represents the constructor. The idea is that the functions should only succeed if the paylock is in
the state at the beginning of the arrow, and then the resulting state should be the one at the end. Of
course, there are other conditions: collect_1_Y should only succeed if called before the first deadline,
and collect_1_N should only succeed if called once the first deadline has passed; similar considerations
apply to the other two collect functions. Look in the file paylock.sol to see a partially finished implementation of the paylock. The first two exercises (see next section) concern only the logic of the paylock.
They are about adding features to the implementation, though we never complete a realistic implementation.
The subsequent exercises are about implementing a supplier which has to interact with both the paylock
contract and a rental contract which it needs to use to complete its work. As above, we will only model
2
certain aspects of these contracts. On the one hand this makes the exercises manageable, but on the other
hand it can be confusing if not pointed out: you would naturally wonder when we would add the rest of the
necessary features!
4 Exercises
The implementation of the paylock which you are given does not model the passage of time. To do this, we
will add a tick function, representing the passage of one unit of time. We shall assume for the moment that
the tick function is going to be called by a neutral third party, who we trust to call it at a regular interval.
For now we also trust all other contracts in the universe not to call this function. (And assume that the
blockchain updates quickly enough that this is a reasonable model of time! This is not how one would deal
with time in a real smart contract system.)
EXERCISE 1: (2 marks)
Add an int variable clock and a tick function which models the passage of time. Modify the various
collect functions to adhere to the deadlines, where we consider the first deadline to happen if the clock
has reached 4 units of time or more, and the second deadline to be when the clock has increased by
4 units of time or more from when collect_1_N was called.
We now need to make sure this tick function can only be called by the agreed third party.
EXERCISE 2: (2 marks)
Add an address variable timeAdd to the contract. Add an argument to the constructor and set the
value of timeAdd to that argument. Now modify tick so that it can only be called by someone from
the address timeAdd .
Tip: when testing your code, copy one of the addresses from the ‘Account’ dropdown menu and paste
it into the constructor argument. That should make it easier to experiment.
Look in the file supplier.txt and paste its contents at the end of paylock.sol . Note how the Supplier
contract interacts with the paylock, indicating to the paylock when it has finished its task. In the next
exercise, we will make it interact with the Rental contract too. The idea is that in order to finish its job,
the Supplier must rent a resource, then return it, before calling finish will succeed.
EXERCISE 3: (2 marks)
Add functions aquire_resource and return_resource which must be called in that order to the
Supplier contract. To do this you will need to add new local variables. Add a local variable
representing an instance of the Rental contract, and allow the address of an instance of Rental to
be passed as an argument to the constructor. Modify the aquire_resource and return_resource
functions so that they call the appropriate functions of the Rental contract.
Tip: Since the constructor of Supplier requires the addresses of a Paylock and a Rental, make sure
you deploy instances of those first when testing.
We will now make our model of the Rental contract somewhat more realistic, by requiring the payment
of a deposit which is returned once the rented resource is re- turned. For the purposes of the lab we assume
that the deposit is 1 wei.
Since the Rental contract is not supposed to assume that it is being called be a Supplier, it should
assume that the contract it is connected to implements a receive function; you can read about this in the
Solidity language documentation:
https://docs.soliditylang.org/en/v0.6.0/contracts.html#receive-ether-function.
3
Since we are not allowed to assume the calling contract is a Supplier, it is also useful to look at the
functions which can be applied to any address:
https://docs.soliditylang.org/en/v0.6.0/types.html#members-of-addresses .
In fact, our intention is to make as few assumptions about the other contract as possible, so we will use
the low-level .call() function. Find out how to make this work and attach a value to it.
EXERCISE 4: (2 marks)
Modify the Rental contract in the following way. First find the commented line
//CHECK FOR PAYMENT HERE
and replace it with something which prevents the function from succeeding unless proper payment is
made. You will also have to make the functions payable. Then find the commented line
//RETURN DEPOSIT HERE
and replace it with a single use of the .call function which returns the deposit. Modify the Supplier
contract so that it has a receive function, and make sure that Rental does not assume that the
contract which calls its functions is an instance of Supplier. Modify the external function calls made
by Supplier to Rental so that they transfer the deposit as appropriate.
At this point you should copy the file paylock.sol to supplier2.sol and work in supplier2.sol .
The rental contract as implemented has a security flaw (which is described in the ‘Reentrancy’ section of
chapter 9 of Antonopoulos’s book Mastering Etherium (available online from the library, and also at
https://github.com/ethereumbook/ethereumbook/blob/develop/09smart-contracts-security.asciidoc
EXERCISE 5: (1 mark)
Modify the Supplier contract to take advantage of this security flaw to take more Ether belonging
to the Rental contract than it has sent to the contract, if more ehter is available. Make sure this
work is saved in the file supplier2.sol
At this point you should copy the file supplier2.sol to suppler3.sol and work in supplier3.sol .
EXERCISE 6: (1 mark)
Re-order the lines of the retrieve_resource function of the Rental contract so that the vulnerability
above is fixed. Make sure this work is saved in the file supplier2.sol
Note: You need only prevent the attack described here while preserving correct functionality; you do
not need to solve any other security flaws.
5 Submission
Submission is by gitlab, following the same procedure as the other labs for this unit. Ensure that you have
pushed a commit containing your submission (i.e. make sure you have added all files to the repository),
tagged with the tag lab5-submission , by 6pm on 03/05.
Check SPOT to make sure your submission has been received correctly, and contact me (Joe) if you
notice any strange behaviour from SPOT.
請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp





 

標簽:

掃一掃在手機打開當前頁
  • 上一篇:代寫program、代做c/c++,Python語言編程
  • 下一篇:EBU4201代做、代寫Java設計編程
  • 無相關信息
    昆明生活資訊

    昆明圖文信息
    蝴蝶泉(4A)-大理旅游
    蝴蝶泉(4A)-大理旅游
    油炸竹蟲
    油炸竹蟲
    酸筍煮魚(雞)
    酸筍煮魚(雞)
    竹筒飯
    竹筒飯
    香茅草烤魚
    香茅草烤魚
    檸檬烤魚
    檸檬烤魚
    昆明西山國家級風景名勝區
    昆明西山國家級風景名勝區
    昆明旅游索道攻略
    昆明旅游索道攻略
  • 短信驗證碼平臺 理財 WPS下載

    關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 kmw.cc Inc. All Rights Reserved. 昆明網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    一级毛片在线视频| 国产老妇另类xxxxx| 欧美激情综合| 99国产精品99久久久久久粉嫩| 雨宫琴音一区二区在线| 美女精品在线| 久久69国产一区二区蜜臀| 粉嫩蜜臀av国产精品网站| 91亚洲午夜精品久久久久久| 亚洲欧美中日韩| 韩曰欧美视频免费观看| 欧美另类videos死尸| 成人黄色电影网址| 欧洲综合视频| caoporn视频在线| 国产原创一区| 竹菊久久久久久久| 亚洲精品美女| 岛国一区二区三区| 亚洲女人****多毛耸耸8| 欧美性极品xxxx做受| 高清毛片在线看| 精品美女在线观看视频在线观看| sm国产在线调教视频| 精品3atv在线视频| 黄页网站免费在线观看| 免费观看在线色综合| aⅴ色国产欧美| 能看av的网址| 成人福利资源| 七七成人影院| 国产精品一区2区3区| 模特精品在线| 韩国毛片一区二区三区| 欧美顶级大胆免费视频| 神马香蕉久久| 久久精选视频| 国产成人av一区二区三区在线观看| 99视频精品在线| 先锋影音国产一区| 亚洲欧美色图| 少妇高潮一区二区三区| 成人国产精品免费网站| 欧美成人bangbros| 免费在线观看麻豆视频 | 欧美日韩国产限制| 日韩精品一区第一页| 伊人春色之综合网| 91视频观看视频| 欧美一区二区视频免费观看| 成人一区视频| 久久久久久久精| 欧美激情视频在线播放| 看电视剧不卡顿的网站| 91精品欧美一区二区三区综合在| ririsao久久精品一区| 国产在线播放精品| 成人一区二区三区在线观看| 99re6这里只有精品视频在线观看| 成人黄色777网| 日本精品视频一区二区| 免费一级毛片在线观看| 欧美在线一级| av资源网在线播放| 免费观看亚洲视频大全| 欧美挤奶吃奶水xxxxx| 亚洲欧美电影院| 成人免费一区二区三区牛牛| 久久天堂影院| 韩日成人av| 精品久久中文字幕| 国家队第一季免费高清在线观看| 五月婷婷久久综合| 99riav视频在线观看| 日本不卡高清视频| 亚洲激情文学| 国产精品一区二区三区四区在线观看 | 久久久久久久综合色一本| 国产精品五月天| 国产对白在线| 免费在线观看精品| 一级免费视频| 日日夜夜天天综合| 美女脱光内衣内裤视频久久网站| 欧美三级视频在线播放| 午夜视频一区二区三区| 97dyy97影院理论片在线| 国产精品一区二区三区www| 不卡电影免费在线播放一区| 在线看国产视频| 99视频一区二区| 噜噜噜天天躁狠狠躁夜夜精品| 91精品国产综合久久香蕉麻豆 | 久久久久国产精品一区二区| 激情久久av一区av二区av三区| 欧美成人官网二区| 第九色区aⅴ天堂久久香| 亚洲一区在线观看网站| 影音先锋可以看的网站| 国产精品欧美三级在线观看| 青青青伊人色综合久久| 欧美日韩亚洲视频一区| 久久国产精品高清一区二区三区| 久久机这里只有精品| 欧美成人三区| 狠狠色狠狠色综合| 欧美尤物美女在线| 2欧美一区二区三区在线观看视频| 精品va天堂亚洲国产| 日韩精品一区二区三区四区视频| 欧美日韩你懂得| 欧美特黄不卡| 亚洲妇女屁股眼交7| 国产日韩亚洲| 日本在线成人| 男女视频在线观看免费| 欧美日韩黄色一区二区| 思思99re6国产在线播放| 91丨九色porny丨蝌蚪| 国产精品成人3p一区二区三区| 亚洲成人av一区二区三区| 宅男噜噜噜66国产精品免费| 国产99精品国产| 伊人久久av| 日本精品在线观看| 欧美日韩在线另类| 日本久久综合| 一区二区三区中文字幕电影 | 一区二区精品伦理...| 男女男精品视频| 激情综合婷婷| 欧美孕妇孕交xxⅹ孕妇交| 国产一区二区精品在线观看| sm国产在线调教视频| 亚洲大型综合色站| 欧美一区影院| 亚洲综合图片| 日韩一区二区在线| 尤物视频免费在线观看| 岛国精品一区二区| 免费精品一区二区三区在线观看| 久久经典视频| 精品久久久久av影院| 午夜电影一区二区三区| 蜜桃视频一区二区三区| 影音先锋在线一区| 日韩一区精品| 夜级特黄日本大片_在线| 懂色av中文一区二区三区天美| jizz性欧美23| 欧美久久婷婷综合色| 人人精品人人爱| 日韩三级电影视频| 亚洲成av人片在线| 亚洲成人高清| 欧美mv日韩mv国产网站| 日本一区二区高清| 老汉av免费一区二区三区| 麻豆国产在线| 亚洲丝袜美腿综合| 欧美精品tushy高清| 99这里都是精品| 欧美激情15p| 欧美美女直播网站| 国产最新精品| 国产精品xx| 午夜成在线www| 在线亚洲高清视频| 校花撩起jk露出白色内裤国产精品| 亚洲aⅴ网站| 欧洲午夜精品| 国产精品毛片aⅴ一区二区三区| 外国电影一区二区| 影音先锋中文在线视频| 18免费在线视频| 日韩欧美在线第一页| 国产精品丝袜久久久久久app| 成人一区二区三区视频在线观看 | 天天色av.com| 国产精品一区二区黑丝| julia中文字幕一区二区99在线| 欧美激情视频在线播放| 欧美一区二区三区啪啪| 91色综合久久久久婷婷| 国产精品久久久久久久| 天天做夜夜做人人爱精品| 亚洲视频一区| 午夜亚洲影视| av影片在线| 久草在线免费福利资源| 1024在线视频| 精品成人私密视频| 欧美色视频日本版| 日韩有码一区| 国产黄在线观看| 亚洲尤物在线视频| 天堂中文字幕在线| 在线播放你懂得| 色视频www在线播放| 国产剧情演绎av|