-
Posts
1,546 -
Joined
-
Last visited
Everything posted by Dimos7
-
already did on admin <group name="Admin"> <acl name="Moderator"></acl> <acl name="SuperModerator"></acl> <acl name="Admin"></acl> <acl name="RPC"></acl> <object name="resource.admin"></object> <object name="resource.webadmin"></object> <object name="resource.loginpanel"></object> local GUIEditor = { window = { }, label = { }, edit = { }, button= { } } function createPasswordWindow() GUIEditor.window[1] = guiCreateWindow(693, 268, 303, 307, "Change Password", false) guiWindowSetMovable(GUIEditor.window[1], false) guiWindowSetSizable(GUIEditor.window[1], false) GUIEditor.label[1] = guiCreateLabel(7, 75, 289, 24, " New Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[1], "top") guiLabelSetHorizontalAlign(GUIEditor.label[1], "left") guiSetFont(GUIEditor.label[1], "clear-normal") GUIEditor.edit[1] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[1], true) GUIEditor.label[2] = guiCreateLabel(7, 140, 289, 24, " Repeat Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[2], "top") guiLabelSetHorizontalAlign(GUIEditor.label[2], "left") guiSetFont(GUIEditor.label[2], "clear-normal") GUIEditor.edit[2] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[2], true) GUIEditor.button[1] = guiCreateButton(9, 254, 143, 53, "Change", false, GUIEditor.window[1]) GUIEditor.button[2] = guiCreateButton(153, 254, 143, 53, "Cancel", false, GUIEditor.window[1]) guiSetVisible(GUIEditor.window[1], false) addEventHandler("onClientGUIClick", GUIEditor.button[1], clientSubmitChangepw, false) addEventHandler("onClientGUIClick", GUIEditor.button[2], hidePasswordWindow, false) end function createLoginWindow() GUIEditor.window[2] = guiCreateWindow(693, 268, 303, 307, "login Panel", false) guiWindowSetMovable(GUIEditor.window[2], false) guiWindowSetSizable(GUIEditor.window[2], false) GUIEditor.label[3] = guiCreateLabel(7, 75, 289, 24, " Username:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[3], "top") guiLabelSetHorizontalAlign(GUIEditor.label[3], "left") guiSetFont(GUIEditor.label[3], "clear-normal") GUIEditor.edit[3] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[2]) GUIEditor.label[4] = guiCreateLabel(7, 140, 289, 24, " Password:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[4], "top") guiLabelSetHorizontalAlign(GUIEditor.label[4], "left") guiSetFont(GUIEditor.label[4], "clear-normal") GUIEditor.edit[4] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[2]) guiEditSetMasked(GUIEditor.edit[4], true) GUIEditor.button[3] = guiCreateButton(9, 254, 143, 53, "Login", false, GUIEditor.window[2]) GUIEditor.button[4] = guiCreateButton(153, 254, 143, 53, "Register", false, GUIEditor.window[2]) addEventHandler("onClientGUIClick", GUIEditor.button[3], clientSubmitLogin, false) addEventHandler("onClientGUIClick", GUIEditor.button[4], clientSubmitRegister, false) end function resourceStart() createLoginWindow() if (GUIEditor.window[2] ~= nil) then guiSetVisible(GUIEditor.window[2], true) else outputChatBox("An error has occupied.") end showCursor(true) guiSetInputEnabled(true) end function changepw() createPasswordWindow() guiSetVisible(GUIEditor.window[1], true) showCursor(true) guiSetInputEnabled(true) end function clientSubmitLogin(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor.edit[3]) local password = guiGetText(GUIEditor.edit[4]) if username ~= "" and password ~= "" then triggerServerEvent("submitLogin", localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitRegister(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor.edit[3]) local password = guiGetText(GUIEditor.edit[4]) if username ~= "" and password ~= "" then triggerServerEvent("submitRegister", localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitChangepw(button, state) if button == "left" and state == "down" then local password = guiGetText(GUIEditor.edit[1]) local rpassword = guiGetText(GUIEditor.edit[2]) if password ~= "" and rpassword ~= "" then triggerServerEvent("submitChangepw", localPlayer, password, rpassword) else outputChatBox("Enter new password and repeat it", 255, 0, 0) end end end function hideLoginWindow() guiSetVisible(GUIEditor.window[2], false) showCursor(false) guiSetInputEnabled(false) end function hidePasswordWindow() guiSetVisible(GUIEditor.window[1], false) showCursor(false) guiSetInputEnabled(false) end addEvent("hideLoginWindow", true) addEvent("hidePasswordWindow", true) addEventHandler("hideLoginWindow", root, hideLoginWindow) addEventHandler("hidePasswordWindow", root, hidePasswordWindow) addEventHandler("onClientResourceStart", resourceRoot, resourceStart) addCommandHandler("changepw", changepw) function passwordHandler(thePlayer, password, rpassword) local account = getPlayerAccount(thePlayer) if account then if isGuestAccount(account) then outputChatBox("You must be logged in to change password!", thePlayer, 255, 0, 0) return end if password == rpassword then if string.len(password) >= 5 then setAccountPassword(account, password) triggerClientEvent(thePlayer, "hidePasswordWindow", root) else outputChatBox("Your new password must be at least 5 characters long!", thePlayer, 255, 0, 0) end else outputChatBox("Your passwords aren't the same!", thePlayer, 255, 0, 0) end end end function loginHandler(thePlayer, username, password) local account = getAccount(username, password) if account ~= false then if (logIn(thePlayer, account, password) == true) then outputChatBox("You succefuly logged in!", thePlayer, 0, 255, 0) triggerClientEvent(thePlayer, "hideLoginWindow", root) else outputChatBox("An error please report it to forum!", thePlayer, 255, 0, 0) end else outputChatBox("Username or password are incorrect!", thePlayer, 255, 0, 0) end end function registerHandler(thePlayer, username, password) local account = getAccount(username, password) if account ~= false then outputChatBox("This username is already exist!", thePlayer, 255, 0, 0) else account = addAccount(username, password) outputChatBox("You succefuly registered!", thePlayer, 0, 255, 0) if (logIn(thePlayer, account, password) == true) then outputChatBox("You succefuly logged in!", thePlayer, 0, 255, 0) triggerClientEvent(thePlayer, "hideLoginWindow", root) else outputChatBox("An error please report it to forum!", thePlayer, 255, 0, 0) end end end addEvent("submitChangepw", true) addEvent("submitLogin", true) addEvent("submitRegister", true) addEventHandler("submitChangepw", root, passwordHandler) addEventHandler("submitLogin", root, loginHandler) addEventHandler("submitRegister", root, registerHandler) nothing the server function is fine the client side is the problem
-
nothing in debugscript 3 not working at all the buttons of loginpanel not even the error given if are empty the edits local GUIEditor = { window = { }, label = { }, edit = { }, button= { } } function createPasswordWindow() GUIEditor.window[1] = guiCreateWindow(693, 268, 303, 307, "Change Password", false) guiWindowSetMovable(GUIEditor.window[1], false) guiWindowSetSizable(GUIEditor.window[1], false) GUIEditor.label[1] = guiCreateLabel(7, 75, 289, 24, " New Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[1], "top") guiLabelSetHorizontalAlign(GUIEditor.label[1], "left") guiSetFont(GUIEditor.label[1], "clear-normal") GUIEditor.edit[1] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[1], true) GUIEditor.label[2] = guiCreateLabel(7, 140, 289, 24, " Repeat Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[2], "top") guiLabelSetHorizontalAlign(GUIEditor.label[2], "left") guiSetFont(GUIEditor.label[2], "clear-normal") GUIEditor.edit[2] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[2], true) GUIEditor.button[1] = guiCreateButton(9, 254, 143, 53, "Change", false, GUIEditor.window[1]) GUIEditor.button[2] = guiCreateButton(153, 254, 143, 53, "Cancel", false, GUIEditor.window[1]) guiSetVisible(GUIEditor.window[1], false) addEventHandler("onClientGUIClick", GUIEditor.button[1], clientSubmitChangepw) addEventHandler("onClientGUIClick", GUIEditor.button[2], hidePasswordWindow) end function createLoginWindow() GUIEditor.window[2] = guiCreateWindow(693, 268, 303, 307, "login Panel", false) guiWindowSetMovable(GUIEditor.window[2], false) guiWindowSetSizable(GUIEditor.window[2], false) GUIEditor.label[3] = guiCreateLabel(7, 75, 289, 24, " Username:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[3], "top") guiLabelSetHorizontalAlign(GUIEditor.label[3], "left") guiSetFont(GUIEditor.label[3], "clear-normal") GUIEditor.edit[3] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[2]) GUIEditor.label[4] = guiCreateLabel(7, 140, 289, 24, " Password:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[4], "top") guiLabelSetHorizontalAlign(GUIEditor.label[4], "left") guiSetFont(GUIEditor.label[4], "clear-normal") GUIEditor.edit[4] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[2]) guiEditSetMasked(GUIEditor.edit[4], true) GUIEditor.button[3] = guiCreateButton(9, 254, 143, 53, "Login", false, GUIEditor.window[2]) GUIEditor.button[4] = guiCreateButton(153, 254, 143, 53, "Register", false, GUIEditor.window[2]) addEventHandler("onClientGUIClick", GUIEditor.button[3], clientSubmitLogin) addEventHandler("onClientGUIClick", GUIEditor.button[4], clientSubmitRegister) end function resourceStart() createLoginWindow() if (GUIEditor.window[2] ~= nil) then guiSetVisible(GUIEditor.window[2], true) else outputChatBox("An error has occupied.") end showCursor(true) guiSetInputEnabled(true) end function changepw() createPasswordWindow() guiSetVisible(GUIEditor.window[1], true) showCursor(true) guiSetInputEnabled(true) end function clientSubmitLogin(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor.edit[3]) local password = guiGetText(GUIEditor.edit[4]) if username ~= "" and password ~= "" then triggerServerEvent("submitLogin", root, localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitRegister(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor[3]) local password = guiGetText(GUIEditor[4]) if username ~= "" and password ~= "" then triggerServerEvent("submitRegister", root, localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitChangepw(button, state) if button == "left" and state == "down" then local password = guiGetText(GUIEditor.edit[1]) local rpassword = guiGetText(GUIEditor.edit[2]) if password ~= "" and rpassword ~= "" then triggerServerEvent("submitChangepw", root, localPlayer, password, rpassword) else outputChatBox("Enter new password and repeat it", 255, 0, 0) end end end function hideLoginWindow() guiSetVisible(GUIEditor.window[2], false) showCursor(false) guiSetInputEnabled(false) end function hidePasswordWindow() guiSetVisible(GUIEditor.window[1], false) showCursor(false) guiSetInputEnabled(false) end addEvent("hideLoginWindow", true) addEvent("hidePasswordWindow", true) addEventHandler("hideLoginWindow", root, hideLoginWindow) addEventHandler("hidePasswordWindow", root, hidePasswordWindow) addEventHandler("onClientResourceStart", resourceRoot, resourceStart) addCommandHandler("changepw", changepw)
-
thanks but still not working
-
local GUIEditor = { window = { }, label = { }, edit = { }, button= { } } function createPasswordWindow() GUIEditor.window[1] = guiCreateWindow(693, 268, 303, 307, "Change Password", false) guiWindowSetMovable(GUIEditor.window[1], false) guiWindowSetSizable(GUIEditor.window[1], false) GUIEditor.label[1] = guiCreateLabel(7, 75, 289, 24, " New Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[1], "top") guiLabelSetHorizontalAlign(GUIEditor.label[1], "left") guiSetFont(GUIEditor.label[1], "clear-normal") GUIEditor.edit[1] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[1], true) GUIEditor.label[2] = guiCreateLabel(7, 140, 289, 24, " Repeat Password:", false, GUIEditor.window[1]) guiLabelSetVerticalAlign(GUIEditor.label[2], "top") guiLabelSetHorizontalAlign(GUIEditor.label[2], "left") guiSetFont(GUIEditor.label[2], "clear-normal") GUIEditor.edit[2] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[1]) guiEditSetMasked(GUIEditor.edit[2], true) GUIEditor.button[1] = guiCreateButton(9, 254, 143, 53, "Change", false, GUIEditor.window[1]) GUIEditor.button[2] = guiCreateButton(153, 254, 143, 53, "Cancel", false, GUIEditor.window[1]) guiSstVisible(GUIEditor.window[1], false) addEventHandler("onClientGUIClick", GUIEditor.button[1], clientSubmitChangepw, false) addEventHandler("onClientGUIClick", GUIEditor.button[2], hidePasswordWindow, false) end function createLoginWindow() GUIEditor.window[2] = guiCreateWindow(693, 268, 303, 307, "login Panel", false) guiWindowSetMovable(GUIEditor.window[2], false) guiWindowSetSizable(GUIEditor.window[2], false) GUIEditor.label[3] = guiCreateLabel(7, 75, 289, 24, " Username:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[3], "top") guiLabelSetHorizontalAlign(GUIEditor.label[3], "left") guiSetFont(GUIEditor.label[3], "clear-normal") GUIEditor.edit[3] = guiCreateEdit(9, 100, 285, 25, "", false, GUIEditor.window[2]) GUIEditor.label[4] = guiCreateLabel(7, 140, 289, 24, " Password:", false, GUIEditor.window[2]) guiLabelSetVerticalAlign(GUIEditor.label[4], "top") guiLabelSetHorizontalAlign(GUIEditor.label[4], "left") guiSetFont(GUIEditor.label[4], "clear-normal") GUIEditor.edit[4] = guiCreateEdit(9, 168, 285, 25, "", false, GUIEditor.window[2]) guiEditSetMasked(GUIEditor.edit[4], true) GUIEditor.button[3] = guiCreateButton(9, 254, 143, 53, "Login", false, GUIEditor.window[2]) GUIEditor.button[4] = guiCreateButton(153, 254, 143, 53, "Register", false, GUIEditor.window[2]) addEventHandler("onClientGUIClick", GUIEditor.button[3], clientSubmitLogin, false) addEventHandler("onClientGUIClick", GUIEditor.button[4], clientSubmitRegister, false) end function resourceStart() createLoginWindow() if (GUIEditor.window[2] ~= nil) then guiSetVisible(GUIEditor.window[2], true) else outputChatBox("An error has occupied.") end showCursor(true) guiSetInputEnabled(true) end function changepw() createPasswordWindow() guiSetVisible(GUIEditor.window[1], true) showCursor(true) guiSetInputEnabled(true) end function clientSubmitLogin(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor.edit[3]) local password = guiGetText(GUIEditor.edit[4]) if username ~= "" and password ~= "" then triggerSeverEvent("submitLogin", root, localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitRegister(button, state) if button == "left" and state == "down" then local username = guiGetText(GUIEditor[3]) local password = guiGetText(GUIEditor[4]) if username ~= "" and password ~= "" then triggerSeverEvent("submitRegister", root, localPlayer, username, password) else outputChatBox("Enter username and password.", 255, 0, 0) end end end function clientSubmitChangepw(button, state) if button == "left" and state == "down" then local password = guiGetText(GUIEditor.edit[1]) local rpassword = guiGetText(GUIEditor.edit[2]) if password ~= "" and rpassword ~= "" then triggerSeverEvent("submitChangepw", root, localPlayer, password, rpassword) else outputChatBox("Enter new password and repeat it", 255, 0, 0) end end end function hideLoginWindow() guiSetVisible(GUIEditor.window[2], false) showCursor(false) guiSetInputEnabled(false) end function hidePasswordWindow() guiSetVisible(GUIEditor.window[1], false) showCursor(false) guiSetInputEnabled(false) end addEvent("hideLoginWindow", true) addEvent("hidePasswordWindow", true) addEventHandler("hideLoginWindow", root, hideLoginWindow) addEventHandler("hidePasswordWindow", root, hidePasswordWindow) addEventHandler("onClientResourceStart", resourceRoot, resourceStart) addCommandHandler("changepw", changepw) function passwordHandler(thePlayer, password, rpassword) local account = getPlayerAccount(thePlayer) if account then if isGuestAccount(account) then outputChatBox("You must be logged in to change password!", thePlayer, 255, 0, 0) return end if password == rpassword then if string.len(password) >= 5 then setAccountPassword(account, password) triggerClientEvent(thePlayer, "hidePasswordWindow", root) else outputChatBox("Your new password must be at least 5 characters long!", thePlayer, 255, 0, 0) end else outputChatBox("Your passwords aren't the same!", thePlayer, 255, 0, 0) end end end function loginHandler(thePlayer, username, password) local account = getAccount(username, password) if account ~= false then if (logIn(thePlayer, account, password) == true) then outputChatBox("You succefuly logged in!", thePlayer, 0, 255, 0) triggerClientEvent(thePlayer, "hideLoginWindow", root) else outputChatBox("An error please report it to forum!", thePlayer, 255, 0, 0) end else outputChatBox("Username or password are incorrect!", thePlayer, 255, 0, 0) end end function registerHandler(thePlayer, username, password) local account = getAccount(username, password) if account ~= false then outputChatBox("This username is already exist!", thePlayer, 255, 0, 0) else account = addAccount(username, password) outputChatBox("You succefuly registered!", thePlayer, 0, 255, 0) if (logIn(thePlayer, account, password) == true) then outputChatBox("You succefuly logged in!", thePlayer, 0, 255, 0) triggerClientEvent(thePlayer, "hideLoginWindow", root) else outputChatBox("An error please report it to forum!", thePlayer, 255, 0, 0) end end end addEvent("submitChangepw", true) addEvent("submitLogin", true) addEvent("submitRegister", true) addEventHandler("submitChangepw", root, passwordHandler) addEventHandler("submitLogin", root, loginHandler) addEventHandler("submitRegister", root, registerHandler) When i press button for login nothing happend event if is empty same with register
-
I want everytime a map start if someone has do /rainbow still has it till exist or do it again the command for remove it
-
function rainbowColor(thePlayer) if isPedInVehicle(thePlayer) then if getPedOccupiedVehicleSeat(thePlayer, 0) then local theVehicle = getPedOccupiedVehicle(thePlayer) local rainbowTimer = getElementData(theVehicle, "rainbowTimer") if isTimer(rainbowTimer) then killTimer(rainbowTimer) return end local money = getPlayerMoney(thePlayer) if money >= 10000 then takePlayerMoney(thePlayer, 10000) local rainbowTimer = setTimer(function (veh) local r, g, b = math.random(0, 255), math.random(0, 255), math.random(0, 255) setVehicleColor(veh, r, g, b) end, 500, 0, theVehicle) setElementData(theVehicle, "rainbowTimer", rainbowTimer, false) else outputChatBox("You do not have enough money for this ! ($10000 required)", thePlayer, 255, 0, 0) end else outputChatBox("You must be at driver seat for turn on/off!", thePlayer, 255, 0 ,0) end else outputChatBox("You have to be in a vehicle to do that !", thePlayer, 255, 0, 0) end end addCommandHandler("rainbow", rainbowColor) addEventHandler("onResourceStart", resourceRoot, function(map, theVehicle) local rainbowTimer = getElementData(theVehicle, "rainbowTimer") if map and isTimer(rainbowTimer) then setTimer(rainbowTimer) end end) function destoryRain(theVehicle) local rainbowTimer = getElementData(theVehicle, "rainbowTimer") if isTimer(rainbowTimer) then killTimer(rainbowTimer) end end addEventHandler("onPlayerQuit", root, destoryRain) you mean something like that?
-
Yes error at fileexist expect string argument take resource data
-
function rainbowColor(thePlayer) if isPedInVehicle(thePlayer) then if getPedOccupiedVehicleSeat(thePlayer, 0) then local theVehicle = getPedOccupiedVehicle(thePlayer) local rainbowTimer = getElementData(theVehicle, "rainbowTimer") if isTimer(rainbowTimer) then killTimer(rainbowTimer) return end local money = getPlayerMoney(thePlayer) if money >= 10000 then takePlayerMoney(thePlayer, 10000) local rainbowTimer = setTimer(function (veh) local r, g, b = math.random(0, 255), math.random(0, 255), math.random(0, 255) setVehicleColor(veh, r, g, b) end, 500, 0, theVehicle) setElementData(theVehicle, "rainbowTimer", rainbowTimer, false) else outputChatBox("You do not have enough money for this ! ($10000 required)", thePlayer, 255, 0, 0) end else outputChatBox("You must be at driver seat for turn on/off!", thePlayer, 255, 0 ,0) end else outputChatBox("You have to be in a vehicle to do that !", thePlayer, 255, 0, 0) end end addCommandHandler("rainbow", rainbowColor) addEventHandler("onResourceStart", resourceRoot, function(map) if fileExists(map) and isTimer(rainbowTimer) then setTimer(rainbowTimer) end end) function destoryRain() if isTimer(rainbowTimer) then killTimer(rainbowTimer) end end addEventHandler("onPlayerQuit", root, destoryRain) I try it make it like this but seems not work
-
Could somebody help me with a weapon selector and dx functions?
Dimos7 replied to Dzsozi (h03)'s topic in Scripting
Well i change the name of function not put faction name same as event or command -
Could somebody help me with a weapon selector and dx functions?
Dimos7 replied to Dzsozi (h03)'s topic in Scripting
local screenWidth, screenHeight = guiGetScreenSize() local currentWidth, currentHeight = 250, 125 local currentOutline = 4 local gapBetween = 32 local left = (screenWidth/2) - (currentWidth/2) local top = (screenHeight/2) - (currentHeight/2) local controls = { "aim_weapon","radio_next","radio_previous", "fire", "vehicle_fire", "vehicle_secondary_fire" } local kepszam = 0 local weaponUpper = 0 local weaponLower = 0 local mutat = false local weaponslot = 0 local nextAmmo = nil local currentAmmo = nil local previousAmmo = nil function getPreviousWeapon() local tempSlot = {} local curSlot = getPedWeaponSlot(localPlayer) if (curSlot == 0) and (getPedWeapon(localPlayer) == 0 or getPedWeapon(localPlayer) == 1) then curSlot = 13 end tempSlot["ID"] = 13 repeat tempSlot["ID"] = tempSlot["ID"]-1 until (tempSlot["ID"] < curSlot) and not (tempSlot["ID"] ~= 0 and getPedWeapon(localPlayer, tempSlot["ID"]) == 0) return getPedWeapon(localPlayer, tempSlot["ID"]) end function getNextWeapon() local tempSlot = {} local curSlot = getPedWeaponSlot(localPlayer) if (curSlot == 12) then curSlot = - 1 end tempSlot["ID"] = - 1 repeat tempSlot["ID"] = tempSlot["ID"] + 1 if tempSlot["ID"] == 13 then tempSlot["ID"] = -1 curSlot = -1 end until (tempSlot["ID"] > curSlot) and not (tempSlot["ID"] ~= 0 and getPedWeapon(localPlayer, tempSlot["ID"]) == 0) return getPedWeapon(localPlayer, tempSlot["ID"]) end function selectWeapon() if mutat then local previousWeapon = getPreviousWeapon() local currentWeapon = getPedWeapon(getLocalPlayer(), getPedWeaponSlot(getLocalPlayer())) local nextWeapon = getNextWeapon() local textx = left + (currentWidth / 2) local texty = (top + (currentHeight / 2)) dxDrawText( "Fegyvereid",textx, texty - 215, textx, texty - 215, tocolor(200,0,100,255), 2, "default", "center", "center", false,false,true) if weaponslot == getPedWeaponSlot(getLocalPlayer()) then dxDrawRectangle ( left - currentOutline, top - currentOutline, currentWidth + currentOutline*2, currentHeight + currentOutline*2, tocolor ( 200, 0, 100, 180 ) ) end dxDrawRectangle ( left, top, currentWidth, currentHeight, tocolor ( 0, 0, 0, 180 ) ) dxDrawRectangle ( left + 26, top + 48 - currentHeight - gapBetween, currentWidth - 52, currentHeight - 32, tocolor ( 0, 0, 0, 180 ) ) dxDrawRectangle ( left + 26, top - 16 + currentHeight + gapBetween, currentWidth - 52, currentHeight - 32, tocolor ( 0, 0, 0, 180 ) ) dxDrawImage(left + 26, top - currentHeight + gapBetween, 256-128, 128-64, "weap/".. nextWeapon ..".png", 0, 0, 0, tocolor(255, 255, 255, 100), true) nextAmmo = getPedTotalAmmo(getLocalPlayer(), getSlotFromWeapon(nextWeapon)) - getPedAmmoInClip(getLocalPlayer(), getSlotFromWeapon(nextWeapon)) .. " #FFFFFF/ " .. getPedAmmoInClip(getLocalPlayer(), getSlotFromWeapon(nextWeapon)) if nextAmmo then --and weaponslot > 0 then dxDrawText( "".. nextAmmo .."",textx, texty - 156, textx, texty - 156, tocolor(200,0,100,100), 1, "default", "center", "center", false,false,true,true) end dxDrawImage(left, top, 256, 128, "weap/".. currentWeapon ..".png", 0, 0, 0, tocolor(255, 255, 255, 255), true) currentAmmo = getPedTotalAmmo ( getLocalPlayer(), weaponslot ) - getPedAmmoInClip(getLocalPlayer(), weaponslot) .. " #FFFFFF/ " .. getPedAmmoInClip(getLocalPlayer(), weaponslot) if currentAmmo then --and weaponslot > 0 then dxDrawText( "".. currentAmmo .."",textx, texty + 48, textx, texty + 48, tocolor(200,0,100,255), 1.5, "default", "center", "center", false,false,true,true) end dxDrawImage(left + 26, top + currentHeight + gapBetween, 256-128, 128-64, "weap/".. previousWeapon ..".png", 0, 0, 0, tocolor(255, 255, 255, 100), true) previousAmmo = getPedTotalAmmo(getLocalPlayer(), getSlotFromWeapon(previousWeapon)) - getPedAmmoInClip(getLocalPlayer(), getSlotFromWeapon(previousWeapon)) .. " #FFFFFF/ " .. getPedAmmoInClip(getLocalPlayer(), getSlotFromWeapon(previousWeapon)) if previousAmmo then --and weaponslot > 0 then dxDrawText( "".. previousAmmo .."",textx, texty + 156, textx, texty + 156, tocolor(200,0,100,100), 1, "default", "center", "center", false,false,true,true) end if kepszam == 0 then weaponslot = 0 elseif kepszam == 1 and getPedWeapon(getLocalPlayer(), 1) > 0 then weaponslot = 1 elseif kepszam == 2 and getPedWeapon(getLocalPlayer(), 2) > 0 then weaponslot = 2 elseif kepszam == 3 and getPedWeapon(getLocalPlayer(), 3) > 0 then weaponslot = 3 elseif kepszam == 4 and getPedWeapon(getLocalPlayer(), 4) > 0 then weaponslot = 4 elseif kepszam == 5 and getPedWeapon(getLocalPlayer(), 5) > 0 then weaponslot = 5 elseif kepszam == 6 and getPedWeapon(getLocalPlayer(), 6) > 0 then weaponslot = 6 elseif kepszam == 7 and getPedWeapon(getLocalPlayer(), 7) > 0 then weaponslot = 7 elseif kepszam == 8 and getPedWeapon(getLocalPlayer(), 8) > 0 then weaponslot = 8 elseif kepszam == 9 and getPedWeapon(getLocalPlayer(), 9) > 0 then weaponslot = 9 elseif kepszam == 10 and getPedWeapon(getLocalPlayer(), 10) > 0 then weaponslot = 10 elseif kepszam == 11 and getPedWeapon(getLocalPlayer(), 11) > 0 then weaponslot = 11 elseif kepszam == 12 and getPedWeapon(getLocalPlayer(), 12) > 0 then weaponslot = 12 else weaponslot = 0 nextAmmo = nil currentAmmo = nil previousAmmo = nil end end end addEventHandler("onClientRender", getRootElement(), selectWeapon) addEventHandler( "onClientPedChoke", getRootElement( ), function ( ) cancelEvent( ); end ); addEventHandler( "onClientResourceStart", getRootElement( ), function ( ) toggleControl ( "next_weapon", false ) toggleControl ( "previous_weapon", false ) end ); function playerPressingKey(key, state) if key == "mouse_wheel_up" and mutat then kepszam = kepszam + 1 if kepszam > 12 then kepszam = 0 end elseif key == "mouse_wheel_down" and mutat then kepszam = kepszam - 1 if kepszam < 0 then kepszam = 12 end elseif key == "q" and state then mutat = true for k, control in ipairs ( controls ) do toggleControl ( control, false ) end elseif key == "q" then mutat = false for k, control in ipairs ( controls ) do toggleControl ( control, true ) end elseif key == "mouse1" and state and mutat then for k, control in ipairs ( controls ) do toggleControl ( control, false ) end setPedWeaponSlot ( getLocalPlayer(), weaponslot ) end end addEventHandler("onClientKey", getRootElement(), playerPressingKey) -
Could somebody help me with a weapon selector and dx functions?
Dimos7 replied to Dzsozi (h03)'s topic in Scripting
i was bussy last night i look it right now if i can help i will also i notice you have put q you want change and with q and e? -
Could somebody help me with a weapon selector and dx functions?
Dimos7 replied to Dzsozi (h03)'s topic in Scripting
I see i will look at your script and see what can i do to help you -
Could somebody help me with a weapon selector and dx functions?
Dimos7 replied to Dzsozi (h03)'s topic in Scripting
so you want when you switch weapon appear the images ? -
gTimerTable = {} gMapsTable = {} comcounter = 0 local g_AdminRanks = { [1] = "Xtreme-Players Trial Member", [2] = "Xtreme-Players Member", [3] = "Xtreme-Players Moderator", [4] = "Xtreme-Players Admin", [5] = "Xtreme-Players Team Manager", [6] = "Xtreme-Players Server Owner", } function hasRights(thePlayer,level) if not isElement(thePlayer) then return false -- Error, there's no player! end local adminLevel = tonumber (getElementData(thePlayer,"pAdminlevel")) if adminLevel and adminLevel >= level then local team = getPlayerTeam(thePlayer) if team then if g_AdminRanks[adminLevel] and getTeamName(team) == g_AdminRanks[adminLevel] then return true end end end return false end addEvent("getSerial",true) addEventHandler("getSerial",getRootElement(), function (player) triggerClientEvent("giveBack",getRootElement(),getPlayerSerial(player),getPlayerIP(player)) end) addEventHandler("onPlayerJoin",getRootElement(), function () mysql_close(handler) handler = mysql_connect ( "localhost", "race-db", "KVU6we7XAFTEeE3T", "styla" ) end) addEventHandler("onPlayerQuit",getRootElement(), function ( ) local name = getPlayerName(source) mysql_query( handler, 'DELETE FROM whishlist WHERE name = "'..name..'"') end) addEventHandler("onResourceStart",getResourceRootElement(getThisResource()), function () handler = mysql_connect ( "localhost", "race-db", "KVU6we7XAFTEeE3T", "styla" ) commandlog = xmlLoadFile("commandlog.xml") local i = 1 while i ~= 0 do idnode = xmlFindChild(commandlog, "id"..comcounter, 0) if idnode then comcounter = comcounter + 1 else i = 0 end end end) addEvent("deleteAccount",true) addEventHandler("deleteAccount",root, function(theAccount) if not hasRights(source,5) then return end if theAccount then mysql_query( handler, 'DELETE FROM account WHERE Name = "'..theAccount..'"') --//Refresh. triggerClientEvent(source,"onAccountDeleted",root) outputChatBox("Account "..theAccount.." has been deleted!",source,255,0,0) end end ) addEvent("getBans",true) addEventHandler("getBans",getRootElement(), function (player) if not hasRights(source,5) then return end local query = "SELECT * FROM ban ORDER BY Eintragedatum DESC" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 0) then row = mysql_fetch_assoc(result) while row do local name = row["Name"] local admin = row["Admin"] local reason = row["Grund"] local ip = row["IP"] local serial = row["Serial"] row = mysql_fetch_assoc(result) triggerClientEvent("giveBans",player,name,admin,reason,ip,serial) end end end) addEvent("Kick",true) addEventHandler("Kick",getRootElement(), function (admin,kicked,grund) if client ~= admin then return end if kicked == admin then outputChatBox("Try /disconnect ;)",admin,255,0,0,true) return end if not hasRights(admin, 2) then return end if kicked then outputChatBox("Player "..getPlayerName(kicked).. " was kicked by " ..getPlayerName(admin).. "!",getRootElement(),255,0,0) outputChatBox("Reason: "..grund,getRootElement(),255,255,0,true) kickPlayer(kicked,admin,grund) end end) --Ban function addBanPlayer ( name,player,text) if not hasRights(source, 4) then return end if client ~= getPlayerFromName(name) then return end local name2 = getPlayerName(player) local ip = getPlayerIP(player) local serial = getPlayerSerial(player) local zeit = 0 local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, IP, Serial ) VALUES ( '"..name2.."', '"..name.."', '"..text.."', '"..tonumber(zeit).."', '"..ip.."', '"..serial.."' )" local result = mysql_query( handler, query ) local query2 = "UPDATE account SET Banned = '1' WHERE Name = '"..name2.."'" local result2 = mysql_query( handler, query2 ) kickPlayer(player,"You were banned permanently \Reason: "..text) addBan(ip, serial, getPlayerAccount(player) , getPlayerFromName(name), text, zeit) outputChatBox(name2.." Was permanently banned by " ..name.. ".",getRootElement(),255,0,0,true) outputChatBox("Reason: "..text,getRootElement(),255,255,0,true) if result then mysql_free_result(result) mysql_free_result(result2) return true else return false end end addEvent("Banperm",true) addEventHandler("Banperm",getRootElement(),addBanPlayer) --TBan function addTimeBan ( name,player,text,zeit ) if not hasRights(source, 3) then return end if client ~= getPlayerFromName(name) then return end local name2 = getPlayerName(player) local ip = getPlayerIP(player) local serial = getPlayerSerial(player) time = zeit*3600 local _stamp = getRealTime() _stamp = _stamp.timestamp local stamp = getRealTime( tonumber(_stamp+time) ) stamp = stamp.timestamp local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, IP, Serial ) VALUES ( '"..name2.."', '"..name.."', '"..text.."', '"..stamp.."', '"..ip.."', '"..serial.."' )" local result = mysql_query( handler, query ) kickPlayer(player,"You were banned for "..zeit.." hours /Reason: "..text) addBan(ip, serial, getPlayerAccount(player), getPlayerFromName(name), text, zeit) outputChatBox(name2.." Was banned by " ..name.. " for " ..zeit.. " hour/s",getRootElement(),255,0,0,true) outputChatBox("Grund: "..text,getRootElement(),255,255,0,true) if result then mysql_free_result(result) return true else return false end end addEvent("Tban",true) addEventHandler("Tban",getRootElement(),addTimeBan) --Ban abfrage addEventHandler ( "onPlayerConnect", getRootElement(), function (playerNick, playerIP, playerUsername, playerSerial, playerVersionNumber ) local pname = playerNick local pserial = playerSerial local query = mysql_query( handler, "SELECT Name, Datum FROM ban WHERE Name = '"..pname.."'") local _query = mysql_query( handler, "SELECT Name, Datum FROM ban WHERE Serial = '"..pserial.."'") local rows = mysql_num_rows ( query ) local _rows = mysql_num_rows ( _query ) local _stamp = getRealTime() _stamp = tonumber(_stamp.timestamp) if rows > 0 then local dsatz = mysql_fetch_assoc ( query ) if _stamp > tonumber(dsatz["Datum"]) and tonumber(dsatz["Datum"]) == 0 then cancelEvent( true, "You are permanently banned" ) elseif _stamp > tonumber(dsatz["Datum"]) then mysql_query( handler, "DELETE FROM ban WHERE Name = '"..pname.."'") elseif _stamp < tonumber(dsatz["Datum"]) then cancelEvent( true, "You are still banned" ) end return true elseif _rows > 0 then local dsatz = mysql_fetch_assoc ( _query ) if _stamp > tonumber(dsatz["Datum"]) and tonumber(dsatz["Datum"]) == 0 then cancelEvent( true, "You are permanently banned" ) elseif _stamp > tonumber(dsatz["Datum"]) then mysql_query( handler, "DELETE FROM ban WHERE Serial = '"..pserial.."'") elseif _stamp < tonumber(dsatz["Datum"]) then cancelEvent( true, "You are still banned" ) end return true end end ) --Blow addEvent("Blow",true) addEventHandler("Blow",getRootElement(), function (admin,vehicle,player) if client ~= admin then return end if admin == player then return end if not hasRights(admin, 1) then return end blowVehicle(vehicle,false) outputChatBox("Your vehicle was Blown by "..getPlayerName(admin),player,255,0,0,true) for i, playerid in pairs (getElementsByType("player")) do local player22 = string.gsub(getPlayerName(player),"#%x%x%x%x%x%x", "") outputChatBox(getPlayerName(admin).." has blowed "..player22.."!", playerid, 255, 0, 0) end end ) addEvent("Mute",true) addEventHandler("Mute",getRootElement(), function (admin,player,time) if not hasRights(admin, 2) then return end if client ~= admin then return end local time = time*60000 if isPlayerMuted(player) == true then mutedby = (tonumber(getElementData(player, "mutedby"))) --muteteam = getTeamName(getPlayerTeam(admin)) muteteamnumber = (tonumber(getElementData(admin,"pAdminlevel"))) --[[if muteteam == "Xtreme-Players Server Owner" then muteteamnumber = 6 elseif muteteam == "Xtreme-Players Tean Manager" then muteteamnumber = 5 elseif muteteam == "Xtreme-Players Admins" then muteteamnumber = 4 elseif muteteam == "Xtreme-Players Moderators" then muteteamnumber = 3 elseif muteteam == "Xtreme-Players Member" then muteteamnumber = 2 end--]] if (muteteamnumber <= mutedby-1) then if admin == player then outputChatBox("You dont have the premissions to unmute yourself!", admin, 255, 0, 0) return else outputChatBox("You dont have the premissions to unmute "..getPlayerName(player).."!", admin, 255, 0, 0) return end elseif muteteamnumber >= mutedby then setPlayerMuted(player,false) removeEventHandler("onPlayerQuit",player,quit) if gTimerTable[getPlayerName(player)] then killTimer(gTimerTable[getPlayerName(player)]) end outputChatBox(getPlayerName(player).. " is not longer Muted!",getRootElement(),0,255,0,true) end elseif isPlayerMuted(player) == false then setPlayerMuted(player,true) setElementData(player,"mutedby",tonumber(getElementData(admin,"pAdminlevel"))) outputChatBox(getPlayerName(player).." has been Muted by "..getPlayerName(admin),getRootElement(),255,0,0,true) addEventHandler("onPlayerQuit",player,quit) gTimerTable[getPlayerName(player)] = setTimer(function (player) setPlayerMuted(player,false) outputChatBox(getPlayerName(player).." is not longer Muted!",getRootElement(),0,255,0,true) removeEventHandler("onPlayerQuit",player,quit) end,time,1,player) end end) function quit () if isTimer(gTimerTable[getPlayerName(source)]) then killTimer(gTimerTable[getPlayerName(source)]) removeEventHandler("onPlayerQuit",source,quit) end end --Tab2 --Gravity addEvent("gravity",true) addEventHandler("gravity",getRootElement(), function (player, gravity) if not hasRights(source,5) then return end setGravity(tonumber(gravity)) for id, player in ipairs ( getElementsByType ( "player" ) ) do setPedGravity ( player, getGravity() ) end outputChatBox("You setted the Gravitylevel to "..gravity, player, 255,0,0) end) --Weather addEvent("weather",true) addEventHandler("weather",getRootElement(), function (player, weather) if not hasRights(source,5) then return end if (weather == "Blue Sky, Sunny") then setWeather(0) end if (weather == "Blue Sky, Clouds") then setWeather(2) end if (weather == "Storming") then setWeather(8) end if (weather == "Cloudy and Foggy") then setWeather(9) end if (weather == "Clear Blue Sky") then setWeather(10) end if (weather == "Sunny, Scorching Hot") then setWeather(11) end if (weather == "Very Dull, Colourless, Hazy") then setWeather(12) end if (weather == "Dull, Cloudy, Rainy") then setWeather(16) end if (weather == "Sunny, Scorching Hot") then setWeather(17) end if (weather == "Sandstorm") then setWeather(19) end outputChatBox("You setted the Weather to "..weather, player, 255,0,0) end) --Time addEvent("time",true) addEventHandler("time",getRootElement(), function (player, hour, min) if not hasRights(source,5)then return end setTime(tonumber(hour), tonumber(min)) outputChatBox("You setted the Time to "..hour..":"..min, player, 255,0,0) end) --Waves addEvent("waves",true) addEventHandler("waves",getRootElement(), function (player, waves) if not hasRights(source,5) then return end setWaveHeight(tonumber(waves)) outputChatBox("You setted the Waves to "..waves, player, 255,0,0) end) --Gamespeed addEvent("gamespeed",true) addEventHandler("gamespeed",getRootElement(), function (player, gamespeed) if not hasRights(source,5) then return end setGameSpeed(tonumber(gamespeed)) outputChatBox("You setted the Gamespeed to "..gamespeed, player, 255,0,0) end) --GetCommandList addEvent("get_commands", true) addEventHandler("get_commands", getRootElement(), function (text, lines, resultcounter, fulllist) fulllist = fulllist commandtablelist = {} for index = comcounter - lines + 99, comcounter - lines - 1, -1 do if index >= 0 then peniscounter = 1 tragodie = {} commandlog = xmlLoadFile("commandlog.xml") idnode = xmlFindChild(commandlog, "id"..index, 0) if idnode then attribute = xmlNodeGetAttributes(idnode) for name,value in pairs ( attribute ) do tragodie[tonumber(peniscounter)] = value peniscounter = peniscounter + 1 end if string.find(string.lower(tragodie[1]), text) or string.find(string.lower(tragodie[2]), text) or string.find(string.lower(tragodie[3]), text) or string.find(string.lower(tragodie[4]), text) or string.find(string.lower(tragodie[5]), text) then resultcounter = resultcounter + 1 commandtablelist[resultcounter] = tragodie end end else fulllist = true end end triggerClientEvent("set_commands", getRootElement(), commandtablelist, resultcounter, fulllist) end) --Tab3 addEvent("unbann",true) addEventHandler("unbann",getRootElement(), function (player,ban) if not hasRights(source,5) then return end if client ~= player then return end mysql_query( handler, "DELETE FROM ban WHERE Name = '"..ban.."'") mysql_query( handler, "UPDATE account SET Banned = '0' WHERE Name = '"..ban.."'" ) end) --ADMINCMDS --Muten/Unmuten --[[addCommandHandler("pmute", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) if getElementData(player2,"pAdminlevel") == "4" then outputChatBox(":O You Bitch!", player,255,0,0) return end if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else setPlayerMuted(player2,true) if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then setElementData(player2, "mutedby", 4) elseif getTeamName(getPlayerTeam(admin)) == "Xtreme-Players Team Manager" then setElementData(player2, "mutedby", 3) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" then setElementData(player2, "mutedby", 2) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" then setElementData(player2, "mutedby", 1) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" then setElementData(player2, "mutedby", 0) end outputChatBox("You muted "..getPlayerName(player2).."!",player,255,0,0) outputChatBox("You have been muted by"..getPlayerName(player).."!",player2,255,0,0) if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end) addCommandHandler("punmute", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) mutedby = getElementData(player2, "mutedby") muteteam = getTeamName(getPlayerTeam(player)) muteteamnumber = 0 if muteteam == "Xtreme-Players Server Owner" then muteteamnumber = 4 elseif muteteam == "Xtreme-Players Team Manager" then muteteamnumber = 3 elseif muteteam == "Xtreme-Players Admins" then muteteamnumber = 2 elseif muteteam == "Xtreme-Players Moderators" then muteteamnumber = 1 elseif muteteam == "Xtreme-Players Member" then muteteamnumber = 0 end if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if muteteamnumber <= mutedby-1 then if player == player2 then outputChatBox("You dont have the premissions to unmute yourself!", player, 255, 0, 0) return else outputChatBox("You dont have the premissions to unmute "..player2.."!", player, 255, 0, 0) return end elseif muteteamnumber >= mutedby then setPlayerMuted(player2,false) outputChatBox("You unmuted "..getPlayerName(player2).."!",player,0,255,0) outputChatBox("You have been unmuted by"..getPlayerName(player).."!",player2,0,255,0) end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)--]] --Blow --[[addCommandHandler("pblow", function( player, cmd, target ) if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Trial Member" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderator" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admin" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Team Manager" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then player2 = findPlayerByName(target) if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if(player2 == player) then outputChatBox("You can't blow yourself!", player, 255, 0, 0) return end veh = getPedOccupiedVehicle(player2) blowVehicle(veh) outputChatBox("You have been blowed "..getPlayerName(player2).."'s vehicle!",player,255,0,0) if getPlayerName(player) ~= "[XP]yourdeathcomes" or getPlayerName(player) ~= "HeadSh0T~" then outputChatBox("Your vehicle has been blowed by "..getPlayerName(player).."!",player2,255,0,0) end if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Trial-Member" then for i, playerid in pairs (getElementsByType("player")) do if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderator" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admin" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Team Manager" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then local player22 = string.gsub(getPlayerName(player2),"#%x%x%x%x%x%x", "") outputChatBox("Xtreme-Players Trial-Member "..getPlayerName(player).." has blowed "..player22.."!", playerid, 255, 0, 0) end end end if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)]] --pkick --[[addCommandHandler("pkick", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) --local player2 = string.gsub(player22,"#%x%x%x%x%x%x", "") --local player2 = findPlayerByName( target ) if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if ( getElementData(player2, "state" ) ~= "not ready" ) then outputChatBox ( "You only can kick Players which state is 'not ready'. For camper use '/pblow'!", player, 255, 0, 0 ) return false end if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end blowVehicle(getPedOccupiedVehicle(player2), true) setTimer ( function() kickPlayer(player2, player) end, 1000, 1) end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)--]] --Findplayer function findPlayerByName( Part ) local Player = getPlayerFromName( Part ) if isElement( Player ) then return Player else for i, p in ipairs ( getElementsByType( "player" ) ) do if ( string.find( getPlayerName(p), Part ) ) then return p end end end end --Tab4 addEvent("s_GetMaps",true) addEventHandler("s_GetMaps",getRootElement(), function () tableOutput = {} local gamemodes = {} gamemodes = call(getResourceFromName("mapmanager"), "getGamemodes") for id,gamemode in ipairs (gamemodes) do tableOutput[id] = {} tableOutput[id].name = getResourceInfo(gamemode, "name") or getResourceName(gamemode) tableOutput[id].maps = {} local maps = call(getResourceFromName("mapmanager"), "getMapsCompatibleWithGamemode" , gamemode) for _,map in ipairs (maps) do table.insert(tableOutput[id]["maps"] ,{name = getResourceInfo(map, "name") or getResourceName(map), resname = getResourceName(map)}) end table.sort(tableOutput[id]) end local map = call(getResourceFromName("mapmanager"), "getRunningGamemodeMap") local gamemode = call(getResourceFromName("mapmanager"), "getRunningGamemode") gamemode = gamemode and getResourceName(gamemode) or "N/A" map = map and getResourceName(map) or "N/A" triggerClientEvent(source ,"c_GetMaps", source, tableOutput,gamemode,map) end) addEvent("s_GetWhishes",true) addEventHandler("s_GetWhishes",getRootElement(), function (player) local query = "SELECT * FROM whishlist" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 0) then row = mysql_fetch_assoc(result) while row do local map = row["map"] local name = row["name"] row = mysql_fetch_assoc(result) triggerClientEvent("c_GiveWishes",player,map,name) end end end) local alreadySeted = false addEvent("onServerConfirmNexmtap",true) addEventHandler("onServerConfirmNexmtap",root, function() alreadySeted = true end ) addEvent("setMap",true) addEventHandler("setMap",getRootElement(), function (player,map,name,delvar) if delvar ~= 1 then if not hasRights(source,4) then return end end if alreadySeted then outputChatBox("One map its already setted!",player,255,0,0) return end if delvar == 1 then local mapname1 = mysql_escape_string(handler, map) local name1 = mysql_escape_string(handler, name) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..mapname1..'" AND name = "'..name1..'"') setElementData(player,"isAllowedToSet",true) end executeCommandHandler("nextmap",player,map) end ) addEvent("whishMap",true) addEventHandler("whishMap",getRootElement(), function (player,map) local name = getPlayerName(player) local query = "SELECT * FROM whishlist WHERE name = '"..name.."'" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 1) then return end local query = "SELECT * FROM whishlist WHERE map = '"..map.."'" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) == 1) then outputChatBox("This map was already wished!",player,255,0,0) return end outputChatBox("You wished the map "..map,player,0,255,0) local query = 'INSERT INTO whishlist ( map,name ) VALUES ( "'..map..'", "'..name..'" )' local result = mysql_query( handler, query ) --//Tell xp members. for i, playerid in ipairs (getElementsByType("player")) do if tonumber(getElementData(playerid, "pLogin")) == 1 then local team = getPlayerTeam(playerid) local level = getElementData(playerid,"pAdminlevel") if team then if hasRights(admin, 3) then if player ~= playerid then outputChatBox("[Wishmap] "..name:gsub("#%x%x%x%x%x%x","").." wished the Map "..map..".",playerid,0,255,0) end end end end end end ) addEvent("removeWhish",true) addEventHandler("removeWhish",getRootElement(), function (player,map,name) outputChatBox("Map form wishlist removed!",player,255,0,0) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') end) --RandomWish addCommandHandler("randomwish", function (player) if not hasRights(player, 3) then return end if not alreadySeted then local result = mysql_query( handler, 'SELECT COUNT(*) FROM whishlist' ) if result then local row = mysql_fetch_row(result) if row then local count = math.random(0,row[1]-1) local result = mysql_query( handler, 'SELECT map,name FROM whishlist LIMIT '..count..',1' ) row = mysql_fetch_assoc(result) if row then name = row["name"] map = row["map"] alreadySeted = true mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') setElementData(player, "randomwhish", 1) executeCommandHandler("nextmap",player,map) else outputChatBox("[Wishlist] Can't get final row!",player,255,0,0) end end else outputChatBox("There's no Map in the Wishlist",player,255,0,0) end else outputChatBox("One map its already setted!",player,255,0,0) end end ) addCommandHandler("nextblock", function(player) local team = getPlayerTeam(player) local name = getPlayerName(player) local level = getElementData(player,"pAdminlevel") if team then if hasRights(player, 3)then alreadySeted = not alreadySeted outputChatBox("[Admin] Nextmap block has changed map block to: "..tostring(alreadySeted)..".",root,0,255,0) end end end ) function getXtremeAdmins() local adminList = {} for k,v in ipairs(getElementsByType("player")) do if hasRights(v, 3) then adminList[#adminList+1] = v end end return adminList end function onFinishedCurrentMap() alreadySeted = false outputDebugString("[Wishlist] Map set block updated! (Changed to: "..tostring(alreadySeted)..")",player,255,0,0) end addEvent("onMapStarting",true) addEventHandler("onMapStarting",root,onFinishedCurrentMap) function onAdminChecker() --outputChatBox("[XP]AdminBot: Attempt to do auto-set if no admin.",root,255,255,255,true) local pAdmins = getXtremeAdmins() if #pAdmins < 1 then if not alreadySeted then local result = mysql_query( handler, 'SELECT COUNT(*) FROM whishlist' ) if result then row = mysql_fetch_row(result) if row then if row[1]-1 >= 0 then local count = math.random(0,row[1]-1) local result = mysql_query( handler, 'SELECT map,name FROM whishlist LIMIT '..count..',1' ) row = mysql_fetch_assoc(result) if row then map = row["map"] name = row["name"] alreadySeted = true outputDebugString("[Wishlist] Next map setted to: "..map) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') --//Make it happen. triggerEvent("onServerWannaSetmap",getResourceRootElement(getThisResource()),map) else outputDebugString("[Wishlist] Can't get final row!") end else outputDebugString("[Wishlist] Wishlist its empty!") end else outputDebugString("[Wishlist] Can't get row!") end else outputDebugString("[Wishlist] Can't get result!") end else outputDebugString("[Wishlist] One map where already setted.") end else outputDebugString("[Wishlist] There's one or more online admin.") end end setTimer(onAdminChecker,120000,0) --//2 Minutes. --Tab5 addEvent("refreshTotalAccounts", true) addEventHandler("refreshTotalAccounts", getRootElement(), function() local query = "SELECT COUNT(*) FROM account;" local result = mysql_query(handler, query) row = mysql_fetch_row(result) if row then setElementData(root, "totalAccounts", row[1]) end end) function getRankColorName(level) if level then if level == 1 then return "#18BC5BMember" elseif level == 2 then return "#FFFF00Moderator" elseif level == 3 then return "#0000CCAdmin" elseif level == 4 then return "#F45F2FTeam-Manager" elseif level == 5 then return "#CC0000Server Owner" else return "" end end end addEvent("setUserData", true) addEventHandler("setUserData", getRootElement(), function (wert, data, player, player2) if not hasRights(source,5) then return end if data == "Adminlevel" then local RankName = getRankColorName(wert) outputDebugString(wert) outputDebugString(RankName) mysql_query(handler,"UPDATE account SET Adminlevel = '"..wert.."' WHERE NAME = '"..player.."'") mysql_query(handler,"UPDATE account SET Title = '"..RankName.."' WHERE NAME = '"..player.."'") elseif data == "Name" then local query = "SELECT * FROM account WHERE Name = '"..wert.."'" local result = mysql_query(handler, query) row = mysql_num_rows(result) if row > 0 then outputChatBox("This Name is already in use!", player2, 255, 0, 0) return end if getPlayerFromName(player) ~= false then outputChatBox("This player is Online, use the Player Managemant to change his Stats", player2, 255, 0, 0) return end mysql_query(handler,"UPDATE account SET Name = '"..wert.."' WHERE NAME = '"..player.."'") outputChatBox("You changed the Name from "..player.." to "..wert..".", player2, 255, 0, 0) elseif data == "Money" then mysql_query(handler,"UPDATE account SET Geld = '"..wert.."' WHERE NAME = '"..player.."'") elseif data == "Points" then mysql_query(handler,"UPDATE account SET Points = '"..wert.."' WHERE NAME = '"..player.."'") elseif data == "Wins" then mysql_query(handler,"UPDATE account SET Wins = '"..wert.."' WHERE NAME = '"..player.."'") end end) addEvent("searchPlayers", true) addEventHandler("searchPlayers", getRootElement(), function(wert, wert2) if not hasRights(source,5) then return end if wert2 == "Name" then local accTable = {} local query = "SELECT * FROM account WHERE Name LIKE \'%"..wert.."%\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif wert2 == "Serial" then local accTable = {} local query = "SELECT * FROM account WHERE LastSerial LIKE \'%"..wert.."%\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif wert2 == "Adminlevel" then local accTable = {} if wert == "" then local query = "SELECT * FROM account WHERE Adminlevel > 0;" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif tonumber(wert) > 0 then local query = "SELECT * FROM account WHERE Adminlevel = \'"..wert.."\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end end end end) addEvent("searchPlayers2", true) addEventHandler("searchPlayers2", getRootElement(), function() if not hasRights(source,5)then return end local accTable = {} local query = "SELECT * FROM account ORDER BY LastQuit DESC LIMIT 20;" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist3", source, accTable) end end) function addOfflineBan ( name,player,text) if not hasRights(admin, 4)then return end if client ~= getPlayerFromName(name) then return end local zeit = 0 local query1 = "SELECT LastSerial FROM account WHERE Name = '"..player.."'" local result1 = mysql_query( handler, query1 ) if (result1 and mysql_num_rows(result1) > 0) then local row = mysql_fetch_assoc(result1) local serial = row['LastSerial'] local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, Serial ) VALUES ( '"..player.."', '"..name.."', '"..text.."', '"..tonumber(zeit).."', '"..serial.."' )" local result = mysql_query( handler, query ) outputChatBox(player.." Was permanently banned by " ..name.. ".",getRootElement(),255,0,0,true) outputChatBox("Reason: "..text,getRootElement(),255,255,0,true) end if result2 then mysql_free_result(result1) end if result then mysql_free_result(result) return true else return false end end addEvent("BanOffline",true) addEventHandler("BanOffline",getRootElement(),addOfflineBan) The level 1 i want can do blow not kick , mute/mute and time ban, level 2 can do blow , kick, mute/unmute not time ban
-
can someone help me please
-
gTimerTable = {} gMapsTable = {} comcounter = 0 local g_AdminRanks = { [1] = "Xtreme-Players Trial Member", [2] = "Xtreme-Players Member", [3] = "Xtreme-Players Moderator", [4] = "Xtreme-Players Admin", [5] = "Xtreme-Players Team Manager", [6] = "Xtreme-Players Server Owner", } function hasRights(thePlayer,level) if not isElement(thePlayer) then return false -- Error, there's no player! end local adminLevel = tonumber (getElementData(thePlayer,"pAdminlevel")) if adminLevel and adminLevel >= level then local team = getPlayerTeam(thePlayer) if team then if g_AdminRanks[adminLevel] and getTeamName(team) == g_AdminRanks[adminLevel] then return true end end end return false end addEvent("getSerial",true) addEventHandler("getSerial",getRootElement(), function (player) triggerClientEvent("giveBack",getRootElement(),getPlayerSerial(player),getPlayerIP(player)) end) addEventHandler("onPlayerJoin",getRootElement(), function () mysql_close(handler) handler = mysql_connect ( "localhost", "race-db", "KVU6we7XAFTEeE3T", "styla" ) end) addEventHandler("onPlayerQuit",getRootElement(), function ( ) local name = getPlayerName(source) mysql_query( handler, 'DELETE FROM whishlist WHERE name = "'..name..'"') end) addEventHandler("onResourceStart",getResourceRootElement(getThisResource()), function () handler = mysql_connect ( "localhost", "race-db", "KVU6we7XAFTEeE3T", "styla" ) commandlog = xmlLoadFile("commandlog.xml") local i = 1 while i ~= 0 do idnode = xmlFindChild(commandlog, "id"..comcounter, 0) if idnode then comcounter = comcounter + 1 else i = 0 end end end) addEvent("deleteAccount",true) addEventHandler("deleteAccount",root, function(theAccount) if not hasRights(source,5) then return end if theAccount then mysql_query( handler, 'DELETE FROM account WHERE Name = "'..theAccount..'"') --//Refresh. triggerClientEvent(source,"onAccountDeleted",root) outputChatBox("Account "..theAccount.." has been deleted!",source,255,0,0) end end ) addEvent("getBans",true) addEventHandler("getBans",getRootElement(), function (player) if not hasRights(source,5) then return end local query = "SELECT * FROM ban ORDER BY Eintragedatum DESC" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 0) then row = mysql_fetch_assoc(result) while row do local name = row["Name"] local admin = row["Admin"] local reason = row["Grund"] local ip = row["IP"] local serial = row["Serial"] row = mysql_fetch_assoc(result) triggerClientEvent("giveBans",player,name,admin,reason,ip,serial) end end end) addEvent("Kick",true) addEventHandler("Kick",getRootElement(), function (admin,kicked,grund) if client ~= admin then return end if kicked == admin then outputChatBox("Try /disconnect ;)",admin,255,0,0,true) return end if not hasRights(admin, 2) then return end if kicked then outputChatBox("Player "..getPlayerName(kicked).. " was kicked by " ..getPlayerName(admin).. "!",getRootElement(),255,0,0) outputChatBox("Reason: "..grund,getRootElement(),255,255,0,true) kickPlayer(kicked,admin,grund) end end) --Ban function addBanPlayer ( name,player,text) if not hasRights(source, 4) then return end if client ~= getPlayerFromName(name) then return end local name2 = getPlayerName(player) local ip = getPlayerIP(player) local serial = getPlayerSerial(player) local zeit = 0 local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, IP, Serial ) VALUES ( '"..name2.."', '"..name.."', '"..text.."', '"..tonumber(zeit).."', '"..ip.."', '"..serial.."' )" local result = mysql_query( handler, query ) local query2 = "UPDATE account SET Banned = '1' WHERE Name = '"..name2.."'" local result2 = mysql_query( handler, query2 ) kickPlayer(player,"You were banned permanently \Reason: "..text) addBan(ip, serial, getPlayerAccount(player) , name, text, zeit) outputChatBox(name2.." Was permanently banned by " ..name.. ".",getRootElement(),255,0,0,true) outputChatBox("Reason: "..text,getRootElement(),255,255,0,true) if result then mysql_free_result(result) mysql_free_result(result2) return true else return false end end addEvent("Banperm",true) addEventHandler("Banperm",getRootElement(),addBan) --TBan function addTimeBan ( name,player,text,zeit ) if hasRights(source, 3) then return end if client ~= getPlayerFromName(name) then return end local name2 = getPlayerName(player) local ip = getPlayerIP(player) local serial = getPlayerSerial(player) time = zeit*3600 local _stamp = getRealTime() _stamp = _stamp.timestamp local stamp = getRealTime( tonumber(_stamp+time) ) stamp = stamp.timestamp local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, IP, Serial ) VALUES ( '"..name2.."', '"..name.."', '"..text.."', '"..stamp.."', '"..ip.."', '"..serial.."' )" local result = mysql_query( handler, query ) kickPlayer(player,"You were banned for "..zeit.." hours /Reason: "..text) addBan(ip, serial, getPlayerAccount(player), name, text, zeit) outputChatBox(name2.." Was banned by " ..name.. " for " ..zeit.. " hour/s",getRootElement(),255,0,0,true) outputChatBox("Grund: "..text,getRootElement(),255,255,0,true) if result then mysql_free_result(result) return true else return false end end addEvent("Tban",true) addEventHandler("Tban",getRootElement(),addTimeBan) --Ban abfrage addEventHandler ( "onPlayerConnect", getRootElement(), function (playerNick, playerIP, playerUsername, playerSerial, playerVersionNumber ) local pname = playerNick local pserial = playerSerial local query = mysql_query( handler, "SELECT Name, Datum FROM ban WHERE Name = '"..pname.."'") local _query = mysql_query( handler, "SELECT Name, Datum FROM ban WHERE Serial = '"..pserial.."'") local rows = mysql_num_rows ( query ) local _rows = mysql_num_rows ( _query ) local _stamp = getRealTime() _stamp = tonumber(_stamp.timestamp) if rows > 0 then local dsatz = mysql_fetch_assoc ( query ) if _stamp > tonumber(dsatz["Datum"]) and tonumber(dsatz["Datum"]) == 0 then cancelEvent( true, "You are permanently banned" ) elseif _stamp > tonumber(dsatz["Datum"]) then mysql_query( handler, "DELETE FROM ban WHERE Name = '"..pname.."'") elseif _stamp < tonumber(dsatz["Datum"]) then cancelEvent( true, "You are still banned" ) end return true elseif _rows > 0 then local dsatz = mysql_fetch_assoc ( _query ) if _stamp > tonumber(dsatz["Datum"]) and tonumber(dsatz["Datum"]) == 0 then cancelEvent( true, "You are permanently banned" ) elseif _stamp > tonumber(dsatz["Datum"]) then mysql_query( handler, "DELETE FROM ban WHERE Serial = '"..pserial.."'") elseif _stamp < tonumber(dsatz["Datum"]) then cancelEvent( true, "You are still banned" ) end return true end end ) --Blow addEvent("Blow",true) addEventHandler("Blow",getRootElement(), function (admin,vehicle,player) if client ~= admin then return end if admin == player then return end if not hasRights(admin, 1) then return end blowVehicle(vehicle,false) outputChatBox("Your vehicle was Blown by "..getPlayerName(admin),player,255,0,0,true) for i, playerid in pairs (getElementsByType("player")) do local player22 = string.gsub(getPlayerName(player),"#%x%x%x%x%x%x", "") outputChatBox(getPlayerName(admin).." has blowed "..player22.."!", playerid, 255, 0, 0) end end ) addEvent("Mute",true) addEventHandler("Mute",getRootElement(), function (admin,player,time) if not hasRights(admin, 2) then return end if client ~= admin then return end local time = time*60000 if isPlayerMuted(player) == true then mutedby = (tonumber(getElementData(player, "mutedby"))) --muteteam = getTeamName(getPlayerTeam(admin)) muteteamnumber = (tonumber(getElementData(admin,"pAdminlevel"))) --[[if muteteam == "Xtreme-Players Server Owner" then muteteamnumber = 6 elseif muteteam == "Xtreme-Players Tean Manager" then muteteamnumber = 5 elseif muteteam == "Xtreme-Players Admins" then muteteamnumber = 4 elseif muteteam == "Xtreme-Players Moderators" then muteteamnumber = 3 elseif muteteam == "Xtreme-Players Member" then muteteamnumber = 2 end--]] if (muteteamnumber <= mutedby-1) then if admin == player then outputChatBox("You dont have the premissions to unmute yourself!", admin, 255, 0, 0) return else outputChatBox("You dont have the premissions to unmute "..getPlayerName(player).."!", admin, 255, 0, 0) return end elseif muteteamnumber >= mutedby then setPlayerMuted(player,false) removeEventHandler("onPlayerQuit",player,quit) if gTimerTable[getPlayerName(player)] then killTimer(gTimerTable[getPlayerName(player)]) end outputChatBox(getPlayerName(player).. " is not longer Muted!",getRootElement(),0,255,0,true) end elseif isPlayerMuted(player) == false then setPlayerMuted(player,true) setElementData(player,"mutedby",tonumber(getElementData(admin,"pAdminlevel"))) outputChatBox(getPlayerName(player).." has been Muted by "..getPlayerName(admin),getRootElement(),255,0,0,true) addEventHandler("onPlayerQuit",player,quit) gTimerTable[getPlayerName(player)] = setTimer(function (player) setPlayerMuted(player,false) outputChatBox(getPlayerName(player).." is not longer Muted!",getRootElement(),0,255,0,true) removeEventHandler("onPlayerQuit",player,quit) end,time,1,player) end end) function quit () if isTimer(gTimerTable[getPlayerName(source)]) then killTimer(gTimerTable[getPlayerName(source)]) removeEventHandler("onPlayerQuit",source,quit) end end --Tab2 --Gravity addEvent("gravity",true) addEventHandler("gravity",getRootElement(), function (player, gravity) if not hasRights(source,5) then return end setGravity(tonumber(gravity)) for id, player in ipairs ( getElementsByType ( "player" ) ) do setPedGravity ( player, getGravity() ) end outputChatBox("You setted the Gravitylevel to "..gravity, player, 255,0,0) end) --Weather addEvent("weather",true) addEventHandler("weather",getRootElement(), function (player, weather) if not hasRights(source,5) then return end if (weather == "Blue Sky, Sunny") then setWeather(0) end if (weather == "Blue Sky, Clouds") then setWeather(2) end if (weather == "Storming") then setWeather(8) end if (weather == "Cloudy and Foggy") then setWeather(9) end if (weather == "Clear Blue Sky") then setWeather(10) end if (weather == "Sunny, Scorching Hot") then setWeather(11) end if (weather == "Very Dull, Colourless, Hazy") then setWeather(12) end if (weather == "Dull, Cloudy, Rainy") then setWeather(16) end if (weather == "Sunny, Scorching Hot") then setWeather(17) end if (weather == "Sandstorm") then setWeather(19) end outputChatBox("You setted the Weather to "..weather, player, 255,0,0) end) --Time addEvent("time",true) addEventHandler("time",getRootElement(), function (player, hour, min) if not hasRights(source,5)then return end setTime(tonumber(hour), tonumber(min)) outputChatBox("You setted the Time to "..hour..":"..min, player, 255,0,0) end) --Waves addEvent("waves",true) addEventHandler("waves",getRootElement(), function (player, waves) if not hasRights(source,5) then return end setWaveHeight(tonumber(waves)) outputChatBox("You setted the Waves to "..waves, player, 255,0,0) end) --Gamespeed addEvent("gamespeed",true) addEventHandler("gamespeed",getRootElement(), function (player, gamespeed) if not hasRights(source,5) then return end setGameSpeed(tonumber(gamespeed)) outputChatBox("You setted the Gamespeed to "..gamespeed, player, 255,0,0) end) --GetCommandList addEvent("get_commands", true) addEventHandler("get_commands", getRootElement(), function (text, lines, resultcounter, fulllist) fulllist = fulllist commandtablelist = {} for index = comcounter - lines + 99, comcounter - lines - 1, -1 do if index >= 0 then peniscounter = 1 tragodie = {} commandlog = xmlLoadFile("commandlog.xml") idnode = xmlFindChild(commandlog, "id"..index, 0) if idnode then attribute = xmlNodeGetAttributes(idnode) for name,value in pairs ( attribute ) do tragodie[tonumber(peniscounter)] = value peniscounter = peniscounter + 1 end if string.find(string.lower(tragodie[1]), text) or string.find(string.lower(tragodie[2]), text) or string.find(string.lower(tragodie[3]), text) or string.find(string.lower(tragodie[4]), text) or string.find(string.lower(tragodie[5]), text) then resultcounter = resultcounter + 1 commandtablelist[resultcounter] = tragodie end end else fulllist = true end end triggerClientEvent("set_commands", getRootElement(), commandtablelist, resultcounter, fulllist) end) --Tab3 addEvent("unbann",true) addEventHandler("unbann",getRootElement(), function (player,ban) if not hasRights(source,5) then return end if client ~= player then return end mysql_query( handler, "DELETE FROM ban WHERE Name = '"..ban.."'") mysql_query( handler, "UPDATE account SET Banned = '0' WHERE Name = '"..ban.."'" ) end) --ADMINCMDS --Muten/Unmuten --[[addCommandHandler("pmute", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) if getElementData(player2,"pAdminlevel") == "4" then outputChatBox(":O You Bitch!", player,255,0,0) return end if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else setPlayerMuted(player2,true) if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then setElementData(player2, "mutedby", 4) elseif getTeamName(getPlayerTeam(admin)) == "Xtreme-Players Team Manager" then setElementData(player2, "mutedby", 3) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" then setElementData(player2, "mutedby", 2) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" then setElementData(player2, "mutedby", 1) elseif getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" then setElementData(player2, "mutedby", 0) end outputChatBox("You muted "..getPlayerName(player2).."!",player,255,0,0) outputChatBox("You have been muted by"..getPlayerName(player).."!",player2,255,0,0) if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end) addCommandHandler("punmute", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) mutedby = getElementData(player2, "mutedby") muteteam = getTeamName(getPlayerTeam(player)) muteteamnumber = 0 if muteteam == "Xtreme-Players Server Owner" then muteteamnumber = 4 elseif muteteam == "Xtreme-Players Team Manager" then muteteamnumber = 3 elseif muteteam == "Xtreme-Players Admins" then muteteamnumber = 2 elseif muteteam == "Xtreme-Players Moderators" then muteteamnumber = 1 elseif muteteam == "Xtreme-Players Member" then muteteamnumber = 0 end if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if muteteamnumber <= mutedby-1 then if player == player2 then outputChatBox("You dont have the premissions to unmute yourself!", player, 255, 0, 0) return else outputChatBox("You dont have the premissions to unmute "..player2.."!", player, 255, 0, 0) return end elseif muteteamnumber >= mutedby then setPlayerMuted(player2,false) outputChatBox("You unmuted "..getPlayerName(player2).."!",player,0,255,0) outputChatBox("You have been unmuted by"..getPlayerName(player).."!",player2,0,255,0) end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)--]] --Blow --[[addCommandHandler("pblow", function( player, cmd, target ) if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Trial Member" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderator" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admin" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Team Manager" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then player2 = findPlayerByName(target) if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if(player2 == player) then outputChatBox("You can't blow yourself!", player, 255, 0, 0) return end veh = getPedOccupiedVehicle(player2) blowVehicle(veh) outputChatBox("You have been blowed "..getPlayerName(player2).."'s vehicle!",player,255,0,0) if getPlayerName(player) ~= "[XP]yourdeathcomes" or getPlayerName(player) ~= "HeadSh0T~" then outputChatBox("Your vehicle has been blowed by "..getPlayerName(player).."!",player2,255,0,0) end if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Trial-Member" then for i, playerid in pairs (getElementsByType("player")) do if getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderator" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admin" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Team Manager" or getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" then local player22 = string.gsub(getPlayerName(player2),"#%x%x%x%x%x%x", "") outputChatBox("Xtreme-Players Trial-Member "..getPlayerName(player).." has blowed "..player22.."!", playerid, 255, 0, 0) end end end if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)]] --pkick --[[addCommandHandler("pkick", function( player, cmd, target ) if ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Member" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Moderators" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Admins" ) or ( getTeamName(getPlayerTeam(player)) == "Xtreme-Players Server Owner" ) then local player2 = findPlayerByName( target ) --local player2 = string.gsub(player22,"#%x%x%x%x%x%x", "") --local player2 = findPlayerByName( target ) if ( player2 == nil ) then outputChatBox("Invalid username!", player,255,0,0) else if ( getElementData(player2, "state" ) ~= "not ready" ) then outputChatBox ( "You only can kick Players which state is 'not ready'. For camper use '/pblow'!", player, 255, 0, 0 ) return false end if ( fileExists( "commandlog.txt" ) ) then logfile = fileOpen( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 while not fileIsEOF( logfile ) do buffer = fileRead( logfile, 500 ) end fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) else logfile = fileCreate( "commandlog.txt" ) time = getRealTime() hour = time.hour min = time.minute sec = time.second day = time.monthday month = time.month + 1 year = time.year + 1900 fileWrite( logfile, "["..day.."."..month.."."..year.."]["..hour..":"..min..":"..sec.."] command: "..cmd.." source: "..getPlayerName(player).." target: "..getPlayerName(player2).."\n" ) fileClose( logfile ) end if fileExists("commandlog.xml") then commandlog = xmlLoadFile("commandlog.xml") newnode = xmlCreateChild(commandlog, "id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 else commandlog = xmlCreateFile("commandlog.xml", "log") newnode = xmlCreateChild(commandlog,"id"..comcounter) xmlNodeSetAttribute ( newnode, "Befehl", cmd ) xmlNodeSetAttribute ( newnode, "Benutzer", getPlayerName(player) ) xmlNodeSetAttribute ( newnode, "Ziel", getPlayerName(player2) ) xmlNodeSetAttribute ( newnode, "Zeit", hour..":"..min..":"..sec ) xmlNodeSetAttribute ( newnode, "Datum", day.."."..month.."."..year ) xmlSaveFile(commandlog) xmlUnloadFile(commandlog) comcounter = comcounter + 1 end blowVehicle(getPedOccupiedVehicle(player2), true) setTimer ( function() kickPlayer(player2, player) end, 1000, 1) end else outputChatBox("You dont have the premissions to use this command!",player,255,0,0) end end)--]] --Findplayer function findPlayerByName( Part ) local Player = getPlayerFromName( Part ) if isElement( Player ) then return Player else for i, p in ipairs ( getElementsByType( "player" ) ) do if ( string.find( getPlayerName(p), Part ) ) then return p end end end end --Tab4 addEvent("s_GetMaps",true) addEventHandler("s_GetMaps",getRootElement(), function () tableOutput = {} local gamemodes = {} gamemodes = call(getResourceFromName("mapmanager"), "getGamemodes") for id,gamemode in ipairs (gamemodes) do tableOutput[id] = {} tableOutput[id].name = getResourceInfo(gamemode, "name") or getResourceName(gamemode) tableOutput[id].maps = {} local maps = call(getResourceFromName("mapmanager"), "getMapsCompatibleWithGamemode" , gamemode) for _,map in ipairs (maps) do table.insert(tableOutput[id]["maps"] ,{name = getResourceInfo(map, "name") or getResourceName(map), resname = getResourceName(map)}) end table.sort(tableOutput[id]) end local map = call(getResourceFromName("mapmanager"), "getRunningGamemodeMap") local gamemode = call(getResourceFromName("mapmanager"), "getRunningGamemode") gamemode = gamemode and getResourceName(gamemode) or "N/A" map = map and getResourceName(map) or "N/A" triggerClientEvent(source ,"c_GetMaps", source, tableOutput,gamemode,map) end) addEvent("s_GetWhishes",true) addEventHandler("s_GetWhishes",getRootElement(), function (player) local query = "SELECT * FROM whishlist" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 0) then row = mysql_fetch_assoc(result) while row do local map = row["map"] local name = row["name"] row = mysql_fetch_assoc(result) triggerClientEvent("c_GiveWishes",player,map,name) end end end) local alreadySeted = false addEvent("onServerConfirmNexmtap",true) addEventHandler("onServerConfirmNexmtap",root, function() alreadySeted = true end ) addEvent("setMap",true) addEventHandler("setMap",getRootElement(), function (player,map,name,delvar) if delvar ~= 1 then if not hasRights(source,4) then return end end if alreadySeted then outputChatBox("One map its already setted!",player,255,0,0) return end if delvar == 1 then local mapname1 = mysql_escape_string(handler, map) local name1 = mysql_escape_string(handler, name) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..mapname1..'" AND name = "'..name1..'"') setElementData(player,"isAllowedToSet",true) end executeCommandHandler("nextmap",player,map) end ) addEvent("whishMap",true) addEventHandler("whishMap",getRootElement(), function (player,map) local name = getPlayerName(player) local query = "SELECT * FROM whishlist WHERE name = '"..name.."'" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) > 1) then return end local query = "SELECT * FROM whishlist WHERE map = '"..map.."'" local result = mysql_query( handler, query ) if ( result and mysql_num_rows( result ) == 1) then outputChatBox("This map was already wished!",player,255,0,0) return end outputChatBox("You wished the map "..map,player,0,255,0) local query = 'INSERT INTO whishlist ( map,name ) VALUES ( "'..map..'", "'..name..'" )' local result = mysql_query( handler, query ) --//Tell xp members. for i, playerid in ipairs (getElementsByType("player")) do if tonumber(getElementData(playerid, "pLogin")) == 1 then local team = getPlayerTeam(playerid) local level = getElementData(playerid,"pAdminlevel") if team then if hasRights(admin, 3) then if player ~= playerid then outputChatBox("[Wishmap] "..name:gsub("#%x%x%x%x%x%x","").." wished the Map "..map..".",playerid,0,255,0) end end end end end end ) addEvent("removeWhish",true) addEventHandler("removeWhish",getRootElement(), function (player,map,name) outputChatBox("Map form wishlist removed!",player,255,0,0) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') end) --RandomWish addCommandHandler("randomwish", function (player) if not hasRights(player, 3) then return end if not alreadySeted then local result = mysql_query( handler, 'SELECT COUNT(*) FROM whishlist' ) if result then local row = mysql_fetch_row(result) if row then local count = math.random(0,row[1]-1) local result = mysql_query( handler, 'SELECT map,name FROM whishlist LIMIT '..count..',1' ) row = mysql_fetch_assoc(result) if row then name = row["name"] map = row["map"] alreadySeted = true mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') setElementData(player, "randomwhish", 1) executeCommandHandler("nextmap",player,map) else outputChatBox("[Wishlist] Can't get final row!",player,255,0,0) end end else outputChatBox("There's no Map in the Wishlist",player,255,0,0) end else outputChatBox("One map its already setted!",player,255,0,0) end end ) addCommandHandler("nextblock", function(player) local team = getPlayerTeam(player) local name = getPlayerName(player) local level = getElementData(player,"pAdminlevel") if team then if hasRights(player, 3)then alreadySeted = not alreadySeted outputChatBox("[Admin] Nextmap block has changed map block to: "..tostring(alreadySeted)..".",root,0,255,0) end end end ) function getXtremeAdmins() local adminList = {} for k,v in ipairs(getElementsByType("player")) do if hasRights(v, 3) then adminList[#adminList+1] = v end end return adminList end function onFinishedCurrentMap() alreadySeted = false outputDebugString("[Wishlist] Map set block updated! (Changed to: "..tostring(alreadySeted)..")",player,255,0,0) end addEvent("onMapStarting",true) addEventHandler("onMapStarting",root,onFinishedCurrentMap) function onAdminChecker() --outputChatBox("[XP]AdminBot: Attempt to do auto-set if no admin.",root,255,255,255,true) local pAdmins = getXtremeAdmins() if #pAdmins < 1 then if not alreadySeted then local result = mysql_query( handler, 'SELECT COUNT(*) FROM whishlist' ) if result then row = mysql_fetch_row(result) if row then if row[1]-1 >= 0 then local count = math.random(0,row[1]-1) local result = mysql_query( handler, 'SELECT map,name FROM whishlist LIMIT '..count..',1' ) row = mysql_fetch_assoc(result) if row then map = row["map"] name = row["name"] alreadySeted = true outputDebugString("[Wishlist] Next map setted to: "..map) mysql_query( handler, 'DELETE FROM whishlist WHERE map = "'..map..'" AND name = "'..name..'"') --//Make it happen. triggerEvent("onServerWannaSetmap",getResourceRootElement(getThisResource()),map) else outputDebugString("[Wishlist] Can't get final row!") end else outputDebugString("[Wishlist] Wishlist its empty!") end else outputDebugString("[Wishlist] Can't get row!") end else outputDebugString("[Wishlist] Can't get result!") end else outputDebugString("[Wishlist] One map where already setted.") end else outputDebugString("[Wishlist] There's one or more online admin.") end end setTimer(onAdminChecker,120000,0) --//2 Minutes. --Tab5 addEvent("refreshTotalAccounts", true) addEventHandler("refreshTotalAccounts", getRootElement(), function() local query = "SELECT COUNT(*) FROM account;" local result = mysql_query(handler, query) row = mysql_fetch_row(result) if row then setElementData(root, "totalAccounts", row[1]) end end) function getRankColorName(level) if level then if level == 1 then return "#18BC5BMember" elseif level == 2 then return "#FFFF00Moderator" elseif level == 3 then return "#0000CCAdmin" elseif level == 4 then return "#F45F2FTeam-Manager" elseif level == 5 then return "#CC0000Server Owner" else return "" end end end addEvent("setUserData", true) addEventHandler("setUserData", getRootElement(), function (wert, data, player, player2) if not hasRights(source,5) then return end if data == "Adminlevel" then local RankName = getRankColorName(wert) outputDebugString(wert) outputDebugString(RankName) mysql_query(handler,"UPDATE account SET Adminlevel = '"..wert.."' WHERE NAME = '"..player.."'") mysql_query(handler,"UPDATE account SET Title = '"..RankName.."' WHERE NAME = '"..player.."'") elseif data == "Name" then local query = "SELECT * FROM account WHERE Name = '"..wert.."'" local result = mysql_query(handler, query) row = mysql_num_rows(result) if row > 0 then outputChatBox("This Name is already in use!", player2, 255, 0, 0) return end if getPlayerFromName(player) ~= false then outputChatBox("This player is Online, use the Player Managemant to change his Stats", player2, 255, 0, 0) return end mysql_query(handler,"UPDATE account SET Name = '"..wert.."' WHERE NAME = '"..player.."'") outputChatBox("You changed the Name from "..player.." to "..wert..".", player2, 255, 0, 0) elseif data == "Money" then mysql_query(handler,"UPDATE account SET Geld = '"..wert.."' WHERE NAME = '"..player.."'") elseif data == "Points" then mysql_query(handler,"UPDATE account SET Points = '"..wert.."' WHERE NAME = '"..player.."'") elseif data == "Wins" then mysql_query(handler,"UPDATE account SET Wins = '"..wert.."' WHERE NAME = '"..player.."'") end end) addEvent("searchPlayers", true) addEventHandler("searchPlayers", getRootElement(), function(wert, wert2) if not hasRights(source,5) then return end if wert2 == "Name" then local accTable = {} local query = "SELECT * FROM account WHERE Name LIKE \'%"..wert.."%\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif wert2 == "Serial" then local accTable = {} local query = "SELECT * FROM account WHERE LastSerial LIKE \'%"..wert.."%\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif wert2 == "Adminlevel" then local accTable = {} if wert == "" then local query = "SELECT * FROM account WHERE Adminlevel > 0;" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end elseif tonumber(wert) > 0 then local query = "SELECT * FROM account WHERE Adminlevel = \'"..wert.."\';" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist2", source, accTable) end end end end) addEvent("searchPlayers2", true) addEventHandler("searchPlayers2", getRootElement(), function() if not hasRights(source,5)then return end local accTable = {} local query = "SELECT * FROM account ORDER BY LastQuit DESC LIMIT 20;" local result = mysql_query(handler, query) if (result and mysql_num_rows(result) > 0) then local testcounter = mysql_num_rows(result) local testcounter2 = 0 while(testcounter > 0) do testcounter2 = testcounter2 + 1 local row = mysql_fetch_assoc(result) local dataTable = {} dataTable[1] = row['Name'] dataTable[2] = row['Geld'] dataTable[3] = row['Points'] dataTable[4] = row['Wins'] dataTable[5] = row['Spielzeit'] dataTable[6] = row['Adminlevel'] accTable[testcounter2] = dataTable testcounter = testcounter - 1 end triggerClientEvent("fillPlayerlist3", source, accTable) end end) function addOfflineBan ( name,player,text) if not hasRights(admin, 4)then return end if client ~= getPlayerFromName(name) then return end local zeit = 0 local query1 = "SELECT LastSerial FROM account WHERE Name = '"..player.."'" local result1 = mysql_query( handler, query1 ) if (result1 and mysql_num_rows(result1) > 0) then local row = mysql_fetch_assoc(result1) local serial = row['LastSerial'] local query = "INSERT INTO ban ( Name, Admin, Grund, Datum, Serial ) VALUES ( '"..player.."', '"..name.."', '"..text.."', '"..tonumber(zeit).."', '"..serial.."' )" local result = mysql_query( handler, query ) outputChatBox(player.." Was permanently banned by " ..name.. ".",getRootElement(),255,0,0,true) outputChatBox("Reason: "..text,getRootElement(),255,255,0,true) end if result2 then mysql_free_result(result1) end if result then mysql_free_result(result) return true else return false end end addEvent("BanOffline",true) addEventHandler("BanOffline",getRootElement(),addOfflineBan) Not work as supose too without errors, at /randomwish all apear one map its already setted! without any map be seted
-
function rainbowColor(thePlayer) if isPedInVehicle(thePlayer) then if getPedOccupiedVehicleSeat(thePlayer, 0) then local theVehicle = getPedOccupiedVehicle(thePlayer) local rainbowTimer = getElementData(theVehicle, "rainbowTimer") if isTimer(rainbowTimer) then killTimer(rainbowTimer) return end local money = getPlayerMoney(thePlayer) if money >= 10000 then takePlayerMoney(thePlayer, 10000) local rainbowTimer = setTimer(function (veh) local r, g, b = math.random(0, 255), math.random(0, 255), math.random(0, 255) setVehicleColor(veh, r, g, b) end, 1000, 0, theVehicle) setElementData(theVehicle, "rainbowTimer", rainbowTimer, false) else outputChatBox("You do not have enough money for this ! ($10000 required)", thePlayer, 255, 0, 0) end else outputChatBox("You must be at driver seat for turn on/off!", thePlayer, 255, 0 ,0) end else outputChatBox("You have to be in a vehicle to do that !", thePlayer, 255, 0, 0) end end addCommandHandler("rainbow", rainbowColor) I use this code for race gamemode and every map need do /rainbow can help me
-
MarkTraf = createMarker(2430.783203125, -988.7255859375, 70.2225921630859, "cylinder", 2.0, 255, 255, 0, 255) setTimer(function() local players = getElementsByType("player") for i=1, #players do if isElementWithinMarker(i, MarkTraf) then givePlayerMoney(i, 500) else addCommandHandler("traficar", function() end) end end end, 120000, 0) after the addCommandHandler put your code you want
-
client is all players thePlayer or source is only the player join and np
-
addEvent("checkAccounts",true) addEvent("playerLogins",true) addEvent("playerRegisters",true) function checkingAccounts(thePlayer) heSerial = getPlayerSerial(thePlayer) accounts = getAccountsBySerial(heSerial) if (#accounts ~= 0) then triggerClientEvent(thePlayer, "accountFound", root) else triggerClientEvent(thePlayer,"accountNotFound",root) end end function loginProcces (thePlayer,username , password ) if not getAccount(username) then triggerClientEvent(thePlayer,"clientResponse", root,1 , "INVALID USERNAME") return end if not getAccount(username,password) then triggerClientEvent(thePlayer,"clientResponse", root,2,"INVALID PASSWORD,") return end logIn(thePlayer,getAccount(username),password) triggerClientEvent(thePlayer,"clientResponse",root,3) end function registerProcces(thePlayer ,username, password, email) if getAccount(username) then triggerClientEvent(thePlayer,"clientResponse",root,4,"THERE IS ANOTHER ACCOUNT WITH THIS NAME TRY SOMETHING NEW ") return end addAccount(username,password) logIn(thePlayer,getAccount(username),password) setAccountData (getAccount(username),heSerial,password) setAccountData (getAccount(username),email,username) triggerClientEvent(thePlayer,"clientResponse",root,3) end addEventHandler("checkAccounts",getRootElement(),checkingAccounts) addEventHandler("playerLogins",getRootElement(),loginProcces) addEventHandler("playerRegisters",getRootElement(),registerProcces) try this