Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- id = "https://paste.ee/r/FTPuU" -- Pastebin Id here
- services = setmetatable({}, {
- __index = function(self, k, ...)
- return game:GetService(k)
- end})
- curtext = id
- if not NS then
- NS = function() end
- end
- local plr = services.Players.LocalPlayer
- print("Credit to Mokiros for his FE Compatibility script.\nThis project wouldn't be possible without him.\n")
- print("You can obtain a copy of his code for his FE compatability at https://github.com/Mokiros/roblox-FE-compatibility.\n")
- print("You may also obtain a copy of his licence at https://raw.githubusercontent.com/Mokiros/roblox-FE-compatibility/master/LICENSE.\n")
- print("All of the source code in exception to his compatability code is in the public domain, and was made by TheFlamingBlaster.")
- local fecompat = [[
- if game:GetService("RunService"):IsClient() then error("Script must be server-side in order to work; use h/ and not hl/") end
- local Player,Mouse,mouse,UserInputService,ContextActionService = owner
- local RealPlayer = Player
- do local a=RealPlayer;script.Parent=a.Character;local b=Instance.new("RemoteEvent")b.Name="UserInput_Event"local function c()local d={_fakeEvent=true,Functions={},Connect=function(self,e)table.insert(self.Functions,e)end}d.connect=d.Connect;return d end;local f={Target=nil,Hit=CFrame.new(),KeyUp=c(),KeyDown=c(),Button1Up=c(),Button1Down=c(),Button2Up=c(),Button2Down=c()}local g={InputBegan=c(),InputEnded=c()}local CAS={Actions={},BindAction=function(self,h,i,j,...)CAS.Actions[h]=i and{Name=h,Function=i,Keys={...}}or nil end}CAS.UnbindAction=CAS.BindAction;local function k(self,l,...)local d=f[l]if d and d._fakeEvent then for m,e in pairs(d.Functions)do e(...)end end end;f.TrigEvent=k;g.TrigEvent=k;b.OnServerEvent:Connect(function(n,o)if n~=a then return end;f.Target=o.Target;f.Hit=o.Hit;if not o.isMouse then local p=o.UserInputState==Enum.UserInputState.Begin;if o.UserInputType==Enum.UserInputType.MouseButton1 then return f:TrigEvent(p and"Button1Down"or"Button1Up")end;if o.UserInputType==Enum.UserInputType.MouseButton2 then return f:TrigEvent(p and"Button2Down"or"Button2Up")end;for m,d in pairs(CAS.Actions)do for m,q in pairs(d.Keys)do if q==o.KeyCode then d.Function(d.Name,o.UserInputState,o)end end end;f:TrigEvent(p and"KeyDown"or"KeyUp",o.KeyCode.Name:lower())g:TrigEvent(p and"InputBegan"or"InputEnded",o,false)end end)b.Parent=NLS([==[local a=game:GetService("Players").LocalPlayer;local b=script:WaitForChild("UserInput_Event")local c=a:GetMouse()local d=game:GetService("UserInputService")local e=function(f,g)if g then return end;b:FireServer({KeyCode=f.KeyCode,UserInputType=f.UserInputType,UserInputState=f.UserInputState,Hit=c.Hit,Target=c.Target})end;d.InputBegan:Connect(e)d.InputEnded:Connect(e)local h,i;while wait(1/30)do if h~=c.Hit or i~=c.Target then h,i=c.Hit,c.Target;b:FireServer({isMouse=true,Target=i,Hit=h})end end]==],Player.Character)local r=game;local s={__index=function(self,q)local t=rawget(self,"_RealService")if t then return typeof(t[q])=="function"and function(m,...)return t[q](t,...)end or t[q]end end,__newindex=function(self,q,u)local t=rawget(self,"_RealService")if t then t[q]=u end end}local function v(d,w)d._RealService=typeof(w)=="string"and r:GetService(w)or w;return setmetatable(d,s)end;local x={GetService=function(self,t)return rawget(self,t)or r:GetService(t)end,Players=v({LocalPlayer=v({GetMouse=function(self)return f end},Player)},"Players"),UserInputService=v(g,"UserInputService"),ContextActionService=v(CAS,"ContextActionService"),RunService=v({_btrs={},RenderStepped=r:GetService("RunService").Heartbeat,BindToRenderStep=function(self,h,m,i)self._btrs[h]=self.Heartbeat:Connect(i)end,UnbindFromRenderStep=function(self,h)self._btrs[h]:Disconnect()end},"RunService")}rawset(x.Players,"localPlayer",x.Players.LocalPlayer)x.service=x.GetService;v(x,game)game,owner=x,x.Players.LocalPlayer end]]
- NS([[
- wait(1)
- local requestHandlers = {
- ["HttpGet"] = function(client, url, cache)
- return game:GetService"HttpService":GetAsync(url, cache or true)
- end,
- ["GetDataStore"] = function(client, ds, key)
- local ds = game:GetService"DataStoreService":GetDataStore(ds):GetAsync(key)
- end,
- ["SetDataStore"] = function(client, ds, key, newval)
- local ds = game:GetService"DataStoreService":GetDataStore(ds):SetAsync(key, newval)
- end
- }
- local generateRemote
- generateRemote = function()
- local remote = Instance.new("RemoteFunction")
- remote.Name = getfenv().owner.Name.." : Coms"
- remote.OnServerInvoke = function(client, request, ...)
- if requestHandlers[request] then
- return requestHandlers[request](client, ...)
- end
- end
- remote.Parent = workspace
- remote.AncestryChanged:Connect(function()
- delay(0.03, function()
- if remote then
- remote:Destroy()
- end
- end)
- generateRemote()
- end)
- end
- generateRemote()
- ]], workspace)
- local remote = workspace:FindFirstChild(plr.Name..": Coms") or workspace:WaitForChild(plr.Name.." : Coms")
- NS(fecompat.." "..remote:InvokeServer("HttpGet", curtext), workspace)
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement