mirror of
https://github.com/cwinfo/matterbridge.git
synced 2025-01-15 00:46:30 +00:00
41 lines
1.4 KiB
Go
41 lines
1.4 KiB
Go
/*
|
|
Allows automation of Steam Trading.
|
|
|
|
Usage
|
|
|
|
Like go-steam, this package is event-based. Call Poll() until the trade has ended, that is until the TradeEndedEvent is emitted.
|
|
|
|
// After receiving the steam.TradeSessionStartEvent
|
|
t := trade.New(sessionIdCookie, steamLoginCookie, steamLoginSecure, event.Other)
|
|
for {
|
|
eventList, err := t.Poll()
|
|
if err != nil {
|
|
// error handling here
|
|
continue
|
|
}
|
|
for _, event := range eventList {
|
|
switch e := event.(type) {
|
|
case *trade.ChatEvent:
|
|
// respond to any chat message
|
|
t.Chat("Trading is awesome!")
|
|
case *trade.TradeEndedEvent:
|
|
return
|
|
// other event handlers here
|
|
}
|
|
}
|
|
}
|
|
|
|
You can either log into steamcommunity.com and use the values of the `sessionId` and `steamLogin` cookies,
|
|
or use go-steam and after logging in with client.Web.LogOn() and receiving the WebLoggedOnEvent use the `SessionId`
|
|
and `SteamLogin` fields of steam.Web for the respective cookies.
|
|
|
|
It is important that there is no delay between the Poll() calls greater than the timeout of the Steam client
|
|
(currently five seconds before the trade partner sees a warning) or the trade will be closed automatically by Steam.
|
|
|
|
Notes
|
|
|
|
All method calls to Steam APIs are blocking. This packages' and its subpackages' types are not thread-safe and no calls to any method of the same
|
|
trade instance may be done concurrently except when otherwise noted.
|
|
*/
|
|
package trade
|