Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- if game:GetService("RunService"):IsClient() then error("Script must be server-side in order to work; use h/ and not hl/") end
- local Player,game,owner = owner,game
- local RealPlayer = Player
- do
- print("FE Compatibility code by Mokiros")
- local rp = RealPlayer
- script.Parent = rp.Character
- --RemoteEvent for communicating
- local Event = Instance.new("RemoteEvent")
- Event.Name = "UserInput_Event"
- --Fake event to make stuff like Mouse.KeyDown work
- local function fakeEvent()
- local t = {_fakeEvent=true,Functions={},Connect=function(self,f)table.insert(self.Functions,f) end}
- t.connect = t.Connect
- return t
- end
- --Creating fake input objects with fake variables
- local m = {Target=nil,Hit=CFrame.new(),KeyUp=fakeEvent(),KeyDown=fakeEvent(),Button1Up=fakeEvent(),Button1Down=fakeEvent(),Button2Up=fakeEvent(),Button2Down=fakeEvent()}
- local UIS = {InputBegan=fakeEvent(),InputEnded=fakeEvent()}
- local CAS = {Actions={},BindAction=function(self,name,fun,touch,...)
- CAS.Actions[name] = fun and {Name=name,Function=fun,Keys={...}} or nil
- end}
- --Merged 2 functions into one by checking amount of arguments
- CAS.UnbindAction = CAS.BindAction
- --This function will trigger the events that have been :Connect()'ed
- local function te(self,ev,...)
- local t = m[ev]
- if t and t._fakeEvent then
- for _,f in pairs(t.Functions) do
- f(...)
- end
- end
- end
- m.TrigEvent = te
- UIS.TrigEvent = te
- Event.OnServerEvent:Connect(function(plr,io)
- if plr~=rp then return end
- m.Target = io.Target
- m.Hit = io.Hit
- if not io.isMouse then
- local b = io.UserInputState == Enum.UserInputState.Begin
- if io.UserInputType == Enum.UserInputType.MouseButton1 then
- return m:TrigEvent(b and "Button1Down" or "Button1Up")
- end
- if io.UserInputType == Enum.UserInputType.MouseButton2 then
- return m:TrigEvent(b and "Button2Down" or "Button2Up")
- end
- for _,t in pairs(CAS.Actions) do
- for _,k in pairs(t.Keys) do
- if k==io.KeyCode then
- t.Function(t.Name,io.UserInputState,io)
- end
- end
- end
- m:TrigEvent(b and "KeyDown" or "KeyUp",io.KeyCode.Name:lower())
- UIS:TrigEvent(b and "InputBegan" or "InputEnded",io,false)
- end
- end)
- Event.Parent = NLS([==[
- local Player = game:GetService("Players").LocalPlayer
- local Event = script:WaitForChild("UserInput_Event")
- local Mouse = Player:GetMouse()
- local UIS = game:GetService("UserInputService")
- local input = function(io,a)
- if a then return end
- --Since InputObject is a client-side instance, we create and pass table instead
- Event:FireServer({KeyCode=io.KeyCode,UserInputType=io.UserInputType,UserInputState=io.UserInputState,Hit=Mouse.Hit,Target=Mouse.Target})
- end
- UIS.InputBegan:Connect(input)
- UIS.InputEnded:Connect(input)
- local h,t
- --Give the server mouse data 30 times every second, but only if the values changed
- --If player is not moving their mouse, client won't fire events
- while wait(1/30) do
- if h~=Mouse.Hit or t~=Mouse.Target then
- h,t=Mouse.Hit,Mouse.Target
- Event:FireServer({isMouse=true,Target=t,Hit=h})
- end
- end]==],Player.Character)
- ----Sandboxed game object that allows the usage of client-side methods and services
- --Real game object
- local _rg = game
- --Metatable for fake service
- local fsmt = {
- __index = function(self,k)
- local s = rawget(self,"_RealService")
- if s then
- return typeof(s[k])=="function"
- and function(_,...)return s[k](s,...)end or s[k]
- end
- end,
- __newindex = function(self,k,v)
- local s = rawget(self,"_RealService")
- if s then s[k]=v end
- end
- }
- local function FakeService(t,RealService)
- t._RealService = typeof(RealService)=="string" and _rg:GetService(RealService) or RealService
- return setmetatable(t,fsmt)
- end
- --Fake game object
- local g = {
- GetService = function(self,s)
- return rawget(self,s) or _rg:GetService(s)
- end,
- Players = FakeService({
- LocalPlayer = FakeService({GetMouse=function(self)return m end},Player)
- },"Players"),
- UserInputService = FakeService(UIS,"UserInputService"),
- ContextActionService = FakeService(CAS,"ContextActionService"),
- RunService = FakeService({
- _btrs = {},
- RenderStepped = _rg:GetService("RunService").Heartbeat,
- BindToRenderStep = function(self,name,_,fun)
- self._btrs[name] = self.Heartbeat:Connect(fun)
- end,
- UnbindFromRenderStep = function(self,name)
- self._btrs[name]:Disconnect()
- end,
- },"RunService")
- }
- rawset(g.Players,"localPlayer",g.Players.LocalPlayer)
- g.service = g.GetService
- FakeService(g,game)
- --Changing owner to fake player object to support owner:GetMouse()
- game,owner = g,g.Players.LocalPlayer
- end
- local p = game.Players.LocalPlayer
- local char = p.Character
- local size = 8
- part = function()
- local a = Instance.new("Part", script)
- a.Anchored = true
- a.CanCollide = true
- a.CFrame = char.Torso.CFrame
- a.Size = Vector3.new(size, 0.2, 0.2)
- a.Transparency = .5
- return a
- end
- part2 = function()
- local a = Instance.new("Part", script)
- a.Anchored = true
- a.CanCollide = true
- a.CFrame = char.Torso.CFrame
- a.Size = Vector3.new(0.2, size, 0.2)
- a.Transparency = .5
- return a
- end
- part3 = function()
- local a = Instance.new("Part", script)
- a.Anchored = true
- a.CanCollide = false
- a.Size = Vector3.new(size, size, 1)
- a.Transparency = 0
- a.Material = "Neon"
- a.BrickColor = BrickColor.new("Really blue")
- local b = Instance.new("BlockMesh", a)
- b.Scale = Vector3.new(1, 1, 0)
- return a
- end
- local replicating = false
- local root, a, b, c, d, a2, b2, c2, d2, aa, bb, cc, dd, z, x, c, v, b, n = nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil
- replicate = function()
- replicating = true
- script:ClearAllChildren()
- root = part()
- root.Transparency = .5
- root.Size = Vector3.new(0.2, 0.2, 0.2)
- root.CanCollide = false
- a = part()
- b = part()
- c = part()
- d = part()
- a2 = part()
- b2 = part()
- c2 = part()
- d2 = part()
- aa = part2()
- bb = part2()
- cc = part2()
- dd = part2()
- z = part3()
- x = part3()
- c = part3()
- v = part3()
- b = part3()
- n = part3()
- replicating = false
- end
- script.ChildRemoved:connect(function(a)
- if a.ClassName == "Part" and replicating == false then
- replicate()
- end
- end
- )
- replicate()
- local tick = 0
- CreateRegion3FromLocAndSize = function(Position, Size)
- local SizeOffset = Size / 2
- local Point1 = Position - SizeOffset
- local Point2 = Position + SizeOffset
- return Region3.new(Point1, Point2)
- end
- local set = false
- local whitelist = {"Hmm465", "IoIman616", "RynLaFreak"}
- p.Chatted:connect(function(ms)
- if ms:sub(1, 5) == "size-" then
- size = tonumber(ms:sub(6))
- replicate()
- else
- if ms:sub(1, 4) == "set-" then
- set = true
- z.CanCollide = false
- x.CanCollide = false
- c.CanCollide = false
- v.CanCollide = false
- b.CanCollide = false
- n.CanCollide = false
- else
- if ms:sub(1, 6) == "unset-" then
- set = false
- z.CanCollide = false
- x.CanCollide = false
- c.CanCollide = false
- v.CanCollide = false
- b.CanCollide = false
- n.CanCollide = false
- else
- if ms:sub(1, 10) == "whitelist-" then
- table.insert(whitelist, ms:sub(11))
- else
- if ms:sub(1, 12) == "unwhitelist-" then
- for i,v in pairs(whitelist) do
- if ms:sub(13) == v then
- table.remove(whitelist, i)
- break
- end
- end
- end
- end
- end
- end
- end
- end
- )
- local magicpos = nil
- game:GetService("RunService").Heartbeat:connect(function()
- pcall(function()
- local void = char:GetChildren()
- for _,pl in pairs(whitelist) do
- if game.Players:FindFirstChild(pl) ~= nil and game.Players:FindFirstChild(pl).Character ~= nil then
- for i,v in pairs(game.Players[pl].Character:GetChildren()) do
- table.insert(void, v)
- end
- end
- end
- for i,v in pairs(game.Players:GetPlayers()) do
- if v.Character:isDescendantOf(char) and not v.Name == "FangxWulf" then
- v:LoadCharacter()
- end
- end
- char.Humanoid.Health = math.huge
- tick = tick + 0.01
- if not set then
- root.CFrame = root.CFrame:lerp(CFrame.new(char.Torso.CFrame.p) * CFrame.Angles(math.sin(tick) * 100 / 30 / (size / 2), math.cos(tick) * 100 / 30 / (size / 2), math.cos(tick) * 100 / 30 / (size / 2)), 0.1)
- magicpos = char.Torso.CFrame
- else
- root.CFrame = root.CFrame:lerp(CFrame.new(magicpos.p) * CFrame.Angles(0, 0, 0), 0.05)
- end
- local reg = CreateRegion3FromLocAndSize(root.CFrame.p, Vector3.new(size, size, size))
- for i,v in pairs(game.Workspace:FindPartsInRegion3WithIgnoreList(reg, void, 100)) do
- if v.Name ~= "Base" then
- v:Destroy()
- end
- end
- a.CFrame = root.CFrame * CFrame.new(size / 2, size / 2, 0) * CFrame.Angles(0, math.rad(90), 0)
- b.CFrame = root.CFrame * CFrame.new(-size / 2, size / 2, 0) * CFrame.Angles(0, math.rad(90), 0)
- c.CFrame = root.CFrame * CFrame.new(0, size / 2, size / 2)
- d.CFrame = root.CFrame * CFrame.new(0, size / 2, -size / 2)
- a2.CFrame = root.CFrame * CFrame.new(size / 2, -size / 2, 0) * CFrame.Angles(0, math.rad(90), 0)
- b2.CFrame = root.CFrame * CFrame.new(-size / 2, -size / 2, 0) * CFrame.Angles(0, math.rad(90), 0)
- c2.CFrame = root.CFrame * CFrame.new(0, -size / 2, size / 2)
- d2.CFrame = root.CFrame * CFrame.new(0, -size / 2, -size / 2)
- aa.CFrame = root.CFrame * CFrame.new(size / 2, 0, size / 2)
- bb.CFrame = root.CFrame * CFrame.new(-size / 2, 0, size / 2)
- cc.CFrame = root.CFrame * CFrame.new(-size / 2, 0, -size / 2)
- dd.CFrame = root.CFrame * CFrame.new(size / 2, 0, -size / 2)
- z.CFrame = root.CFrame * CFrame.new(size / 2, 0, 0) * CFrame.Angles(0, math.rad(90), 0)
- x.CFrame = root.CFrame * CFrame.new(-size / 2, 0, 0) * CFrame.Angles(0, math.rad(90), 0)
- c.CFrame = root.CFrame * CFrame.new(0, 0, size / 2) * CFrame.Angles(0, 0, math.rad(90))
- v.CFrame = root.CFrame * CFrame.new(0, 0, -size / 2) * CFrame.Angles(0, 0, math.rad(90))
- b.CFrame = root.CFrame * CFrame.new(0, size / 2, 0) * CFrame.Angles(math.rad(90), 0, 0)
- n.CFrame = root.CFrame * CFrame.new(0, -size / 2, 0) * CFrame.Angles(math.rad(90), 0, 0)
- end
- )
- end
- )
Add Comment
Please, Sign In to add comment