Merge pull request #18 from Ayush272002/add-event-end-time

Add event end time to contract
This commit is contained in:
Ayush Acharjya
2024-10-26 16:39:57 +01:00
committed by GitHub
2 changed files with 14 additions and 10 deletions

View File

@@ -27,7 +27,8 @@ contract EventManager {
uint256 capacity; uint256 capacity;
uint256 ticketsSold; uint256 ticketsSold;
uint256 ticketPrice; // in USD cents uint256 ticketPrice; // in USD cents
uint256 eventDate; uint256 eventStartDate;
uint256 eventEndDate;
string[] images; // array of image URLs string[] images; // array of image URLs
uint256[] tickets; uint256[] tickets;
address payable eventHost; address payable eventHost;
@@ -39,7 +40,7 @@ contract EventManager {
uint256 eventId; uint256 eventId;
} }
event EventCreated(uint256 eventId, string name, uint256 eventDate); event EventCreated(uint256 eventId, string name, uint256 eventStartDate);
event TicketPurchased(uint256 ticketId, uint256 eventId, address buyer, uint256 price); event TicketPurchased(uint256 ticketId, uint256 eventId, address buyer, uint256 price);
event TicketTransferred(uint256 ticketId, address from, address to); event TicketTransferred(uint256 ticketId, address from, address to);
event TicketTransferApproved(uint256 ticketId, address owner, address trustee); event TicketTransferApproved(uint256 ticketId, address owner, address trustee);
@@ -91,10 +92,10 @@ contract EventManager {
return centsToFlare(events[_eventId].ticketPrice); return centsToFlare(events[_eventId].ticketPrice);
} }
function createEvent(string memory _name, string memory _description, string memory _location, uint256 _capacity, uint256 _ticketPrice, uint256 _eventDate, string[] memory _images) public returns (uint256 _eventId) { function createEvent(string memory _name, string memory _description, string memory _location, uint256 _capacity, uint256 _ticketPrice, uint256 _eventStartDate, uint256 _eventEndDate, string[] memory _images) public returns (uint256 _eventId) {
events[eventCounter] = Event(_name, _description, _location, _capacity, 0, _ticketPrice, _eventDate, _images, new uint256[](0), payable(msg.sender)); events[eventCounter] = Event(_name, _description, _location, _capacity, 0, _ticketPrice, _eventStartDate, _eventEndDate, _images, new uint256[](0), payable(msg.sender));
eventCounter++; eventCounter++;
emit EventCreated(eventCounter - 1, _name, _eventDate); emit EventCreated(eventCounter - 1, _name, _eventStartDate);
return eventCounter - 1; return eventCounter - 1;
} }
@@ -110,7 +111,7 @@ contract EventManager {
function buyTicket(uint256 _eventId) public payable returns (uint256 _ticketId) { function buyTicket(uint256 _eventId) public payable returns (uint256 _ticketId) {
require(_eventId < eventCounter, "Invalid event ID"); require(_eventId < eventCounter, "Invalid event ID");
require(events[_eventId].eventDate > block.timestamp, "Event has already passed"); require(events[_eventId].eventStartDate > block.timestamp, "Event has already passed");
require(events[_eventId].tickets.length < events[_eventId].capacity, "Event is full"); require(events[_eventId].tickets.length < events[_eventId].capacity, "Event is full");
uint256 ticketCost = getEventPriceFlare(_eventId); // Get ticket price in FLR uint256 ticketCost = getEventPriceFlare(_eventId); // Get ticket price in FLR
@@ -143,7 +144,7 @@ contract EventManager {
function transferTicketForce(uint256 _ticketId, address _to) private { function transferTicketForce(uint256 _ticketId, address _to) private {
require(_ticketId < ticketCounter, "Invalid ticket ID"); require(_ticketId < ticketCounter, "Invalid ticket ID");
require(events[tickets[_ticketId].eventId].eventDate > block.timestamp, "Event has already passed"); require(events[tickets[_ticketId].eventId].eventStartDate > block.timestamp, "Event has already passed");
address prevHolder = tickets[_ticketId].holder; address prevHolder = tickets[_ticketId].holder;

View File

@@ -14,7 +14,8 @@ describe('EventManager', function () {
const EVENT_LOCATION = 'London, UK'; const EVENT_LOCATION = 'London, UK';
const EVENT_CAPACITY = 100; const EVENT_CAPACITY = 100;
const EVENT_TICKET_PRICE = 1000; // 10 USD in cents const EVENT_TICKET_PRICE = 1000; // 10 USD in cents
const EVENT_DATE = Math.floor(Date.now() / 1000) + 86400; // 1 day from now const EVENT_START_DATE = Math.floor(Date.now() / 1000) + 86400; // 1 day from now
const EVENT_END_DATE = Math.floor(Date.now() / 1000) + 172800; // 2 days from now
const EVENT_IMAGES = ['image1.jpg', 'image2.jpg']; const EVENT_IMAGES = ['image1.jpg', 'image2.jpg'];
beforeEach(async function () { beforeEach(async function () {
@@ -32,7 +33,8 @@ describe('EventManager', function () {
EVENT_LOCATION, EVENT_LOCATION,
EVENT_CAPACITY, EVENT_CAPACITY,
EVENT_TICKET_PRICE, EVENT_TICKET_PRICE,
EVENT_DATE, EVENT_START_DATE,
EVENT_END_DATE,
EVENT_IMAGES EVENT_IMAGES
); );
} }
@@ -47,7 +49,8 @@ describe('EventManager', function () {
expect(event.location).to.equal(EVENT_LOCATION); expect(event.location).to.equal(EVENT_LOCATION);
expect(event.capacity).to.equal(EVENT_CAPACITY); expect(event.capacity).to.equal(EVENT_CAPACITY);
expect(event.ticketPrice).to.equal(EVENT_TICKET_PRICE); expect(event.ticketPrice).to.equal(EVENT_TICKET_PRICE);
expect(event.eventDate).to.equal(EVENT_DATE); expect(event.eventStartDate).to.equal(EVENT_START_DATE);
expect(event.eventEndDate).to.equal(EVENT_END_DATE);
expect(event.eventHost).to.equal(owner.address); expect(event.eventHost).to.equal(owner.address);
}); });