mirror of
https://github.com/0xShay/ticketchain.git
synced 2026-01-11 21:23:24 +00:00
Merge pull request #18 from Ayush272002/add-event-end-time
Add event end time to contract
This commit is contained in:
@@ -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;
|
||||||
|
|
||||||
|
|||||||
@@ -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);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user