Facepunch.Steamworks Current running program's AppId Called with a message from Steam Global callback type Call results are results to specific actions An item in your inventory. Careful, this might not be available. Especially on a game server. Called when the local client's items are first retrieved, and when they change. Obviously not called on the server. A list of items owned by this user. You should call Refresh() before trying to access this, and then wait until it's non null or listen to OnUpdate to find out immediately when it's populated. You can send this data to a server, or another player who can then deserialize it and get a verified list of items. Serialized data exprires after an hour. This is the time the value in SerializedItems will expire. Call this at least every two minutes, every frame doesn't hurt. You should call it when you consider it active play time. IE - your player is alive, and playing. Don't stress on it too much tho cuz it's super hijackable anyway. Call this to retrieve the items. Note that if this has already been called it won't trigger a call to OnUpdate unless the items have changed Some definitions aren't sent to the client, and all aren't available on the server. Manually getting a Definition here lets you call functions on those definitions. Called every frame If we have a local player request process it. A list of items defined for this app. This should be immediately populated and available. Utility, given a "1;VLV250" string, convert it to a 2.5 An item definition. This describes an item in your Steam inventory, but is not unique to that item. For example, this might be a tshirt, but you might be able to own multiple tshirts. Trigger an item drop. Call this when it's a good time to award an item drop to a player. This won't automatically result in giving an item to a player. Just call it every minute or so, or on launch. ItemDefinition is usually a generator Basic UDP send. Packets can't be bigger than 1200 bytes (your typical MTU size). Can be lost, or arrive out of order (rare). The sending API does have some knowledge of the underlying connection, so if there is no NAT-traversal accomplished or there is a recognized adjustment happening on the connection, the packet will be batched until the connection is open again. As above, but if the underlying p2p connection isn't yet established the packet will just be thrown away. Using this on the first packet sent to a remote host almost guarantees the packet will be dropped. This is only really useful for kinds of data that should never buffer up, i.e. voice payload packets As above, but applies the Nagle algorithm to the send - sends will accumulate until the current MTU size (typically ~1200 bytes, but can change) or ~200ms has passed (Nagle algorithm). Useful if you want to send a set of smaller messages but have the coalesced into a single packet Since the reliable stream is all ordered, you can do several small message sends with k_EP2PSendReliableWithBuffering and then do a normal k_EP2PSendReliable to force all the buffered data to be sent. Current user's Username Current user's SteamId Current Beta name, if ser Should be called at least once every frame History filters don't seem to work, so we don't bother. You should apply them post process'dly Favourite filters don't seem to work, so we don't bother. You should apply them post process'dly A list of servers that responded. If you're only interested in servers that responded since you last updated, then simply clear this list. A list of servers that were in the master list but didn't respond. True when we have finished Disposing will end the query Callback when rules are receieved. The bool is true if server responded properly. List of server rules. Use HasRules to see if this is safe to access. Returns true if this server has rules Populates Rules for this server Cancels a ticket. You should cancel your ticket when you close the game or leave a server. Creates an auth ticket. Which you can send to a server to authenticate that you are who you say you are. Returns the current BuildId of the game. This is pretty useless, as it isn't guarenteed to return the build id you're playing, or the latest build id. Steam Id Return true if blocked Return true if is a friend. Returns false if blocked, request etc. Their current display name Returns true if this friend is online Returns true if this friend is online and playing this game Returns true if this friend is online and playing this game The AppId this guy is playing Returns all friends, even blocked, ignored, friend requests etc Should be 32x32 - but make sure to check! Should be 64x64 - but make sure to check! Should be 184x184 - but make sure to check! Return true if this image couldn't be loaded for some reason Returns the optimal sample rate for voice - according to Steam If set to true we are listening to the mic. You should usually toggle this with the press of a key for push to talk. The last time voice was detected, recorded If set we will capture the audio at this rate. If unset (set to 0) will capture at OptimalSampleRate Some platforms allow/need CallingConvention.ThisCall. If you're crashing with argument null errors on certain platforms, try flipping this to true. I owe this logic to Riley Labrecque's hard work on Steamworks.net - I don't have the knowledge or patience to find this shit on my own, so massive thanks to him. And also massive thanks to him for releasing his shit open source under the MIT license so we can all learn and iterate. Set this to true on Linux and OSX The Native dll to look for. This is the steam_api.dll renamed. We need to rename the dll anyway because we can't dynamically choose the library ie, we can't load steam_api64.dll on windows 64 platforms. So instead we choose to keep the library name the same. This is exposed only for the benefit of implementation - and cannot be changed at runtime. Returns a class representing this ItemId. We don't query item name, description etc. We don't verify that item exists. We don't verify that this item belongs to your app. Both MicrotransactionItems and subscriptionItems Workshop item that is meant to be voted on for the purpose of selling in-game normal Workshop item that can be subscribed to Return a URL to view this item online The AppId you're querying. This defaults to this appid. The AppId of the app used to upload the item. This defaults to 0 which means all/any. Page starts at 1 !! Only return items with these tags If true, return items that have all RequireTags If false, return items that have any tags in RequireTags Don't return any items with this tag If you're querying for a particular file or files, add them to this. Don't call this in production! Current user's Username Current user's SteamId Initialize a server - query port will use the same as GamePort (MASTERSERVERUPDATERPORT_USEGAMESOCKETSHARE) Should be called at least once every frame Gets or sets the current MaxPlayers. This doesn't enforce any kind of limit, it just updates the master server. Gets or sets the current BotCount. This doesn't enforce any kind of limit, it just updates the master server. Gets or sets the current Map Name. Gets or sets the current ModDir Gets or sets the current Product Gets or sets the current Product Gets or sets the current ServerName Gets or sets the current Passworded Gets or sets the current GameTags Log onto Steam anonymously Sets a Key Value Steamid, Ownerid, Status Steam authetication statuses Steam has verified the user is online, the ticket is valid and ticket has not been reused. Start authorizing a ticket. This user isn't authorized yet. Wait for a call to OnAuthChange. Forget this guy. They're no longer in the game. If true, Steam wants to send a packet. You should respond by sending this packet in an unconnected way to the returned Address and Port We have received a server query on our game port. Pass it to Steam to handle. Retrieve the stats for this user Set the named statistic for this user Set the named statistic for this user Set the named stat for this user Set the named stat for this user