Source RCON Protocol: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
m (SPAM revert)
Line 1: Line 1:
[http://lestenger.ifrance.com/resources/6-exploror-security.html 6 exploror security] [http://maryannecrossle.ifrance.com/blog/scottsdale-condos.html scottsdale condos for sale] [http://loving-skate.isuisse.com/pages/internet-roaming.html global internet roaming] [http://whipartist.profil.in/disneys-beauty.html disneys beauty and the beast] [http://shainarainville.ifrance.com/web/paris-hilton-porn.html paris hilton porn] [http://oliviagrimaldo.ifrance.com/view/viola-string-instrument.html viola string instrument] [http://lexiehorton.ifrance.com/what-state-are.html what state are you from] [http://rosymcphearson.jushige.cn/data/urticaria.html urticaria] [http://lapsed.trickip.net/rosas.html rosas] [http://aladdill.ourprofile.info/articles/spy-sunglasses.html glasses spy sun wear] [http://aladdill.ourprofile.info/articles/nikon-coolpix.html nikon coolpix 5900] [http://swill.ns1.name/article/2003-fax-server.html 2003 fax server network printer] [http://giant.ns02.biz/blog/scat-movie-downloads.html scat movie downloads] [http://ashtonlemos.ifrance.com/pages/summer-lovin.html summer lovin] [http://canyondrey.ibelgique.com/topic/metformin-side-effect.html metformin side effect] [http://kasiecrosland.profil.in/comments/ime-out.html ime out] [http://linniebittinger.profil.in/view/pullman-area-code.html pullman area code] [http://agued.ns01.info/library/xp-pro-administrator.html xp pro administrator password] [http://nishamuniz.ifrance.com/clindamycin.html clindamycin] [http://giant.ns02.biz/blog/boat-bumpers.html boat bumpers] [http://oliviagrimaldo.ifrance.com/view/micheal-eric-dyson.html micheal eric dyson biography] [http://cdn-slave.isuisse.com/blog/addressing-a-selection.html addressing a selection criteria for a job application] [http://cried.sixth.biz/topic/top-down-bottom.html top down bottom up approach] [http://canyondrey.ibelgique.com/topic/tarot-card-readings.html tarot card readings] [http://lapsed.trickip.net/skylar.html skylar] [http://allysonhering.ifrance.com/atlantic-bayside.html atlantic bayside city hampton in inn] [http://nishamuniz.ifrance.com/accupril.html accupril] [http://candicepray.ifrance.com/blog/animal-fur.html animal comforter fur] [http://edelmirashiffle.ifrance.com/directory/peerless.html peerless faucets] [http://ships.xxuz.com/resources/margot-stiller.html margot stiller nine songs] [http://renatamonty.ifrance.com/pathophysiology.html pathophysiology of osteoarthritis] [http://tandraverdugo.ifrance.com/wiki/sometime-i-feel.html sometime i feel ive got to run away] [http://antionetterikar.ifrance.com/small/52-leather-coats.html 52 leather coats] [http://revjo.jushige.com/text/halejak.html halejak] [http://candicepray.ifrance.com/blog/blackassbuster.html blackassbuster] [http://moot-hest.iespana.es/free-gallery-mature.html free gallery mature women] [http://roger.compress.to/view/riu-cancun.html riu cancun] [http://shenitayoungqui.ifrance.com/amitriptyline-information.html amitriptyline information] [http://paullamphere.ifrance.com/topic/bride-and-groom.html bride and groom] [http://agued.ns01.info/library/cartoon-comic-sex.html cartoon comic sex] [http://antionetterikar.ifrance.com/small/lori-lins-ltd.html lori lins ltd] [http://carleehallum.ifrance.com/comments/star-ice-hockey.html star ice hockey] [http://delorismontoya.jushige.com/q/bikinis.html bikini contest] [http://spend.vizvaz.com/new-york-auto.html new york auto auction] [http://paullamphere.ifrance.com/topic/evertt-event.html evertt event center] [http://lapsed.trickip.net/debra-d-andrea.html debra d andrea] [http://janniekilroy.ifrance.com/content/free-hot-lesbian.html free hot lesbian sex] [http://gwenluttrell.ifrance.com/wiki/mya.html mya ticket] [http://dessiegiancola.ifrance.com/manufactured.html manufactured home dealer] [http://leonoreswaney.ifrance.com/steven-testa.html steven testa] [http://mairarolston.ifrance.com/in-regard-writing.html in regard writing] [http://renatamonty.ifrance.com/real-life-street.html real life street fight videos] [http://renatamonty.ifrance.com/free-digimon-porn.html free digimon porn] [http://whipartist.profil.in/online-turnkey.html business online site turnkey web] [http://larondaglen.ifrance.com/data/roca-portugal.html roca portugal] [http://roger.compress.to/view/lionel-rosenblatt.html lionel rosenblatt] [http://mairarolston.ifrance.com/quotation-marks.html quotation marks punctuation rules] [http://giant.ns02.biz/blog/thank-you-notes.html thank you notes] [http://larondaglen.ifrance.com/data/the-ramones.html the ramones] [http://cindisheen.ifrance.com/view/proses-kehamilan.html proses kehamilan] [http://kimimattingly.ifrance.com/view/military-stud.html military stud] [http://gildachoice.ifrance.com/small/levitz-furniture.html levitz furniture] [http://ships.xxuz.com/resources/jewelry-making.html jewelry making] [http://leonoreswaney.ifrance.com/3000bc-computer.html 3000bc computer history dust] [http://trilingualgirl.ourprofile.info/library/sterling-motor.html sterling motor group uk] [http://larondaglen.ifrance.com/data/kemp-little-solicitors.html kemp little solicitors] [http://mairarolston.ifrance.com/sakar-digital.html sakar digital concepts deluxe bag] [http://dessiegiancola.ifrance.com/redheads.html redheads] [http://linniebittinger.profil.in/view/lake-lots-park.html lake lots park rapids] [http://joyegrundy.ifrance.com/article/bathroom-vanity.html bathroom vanity design] [http://valenecaison.ide.am/max-lucado-daily.html max lucado daily devotional] [http://shainarainville.ifrance.com/web/verizon-free-ringtones.html verizon free ringtones] [http://kimimattingly.ifrance.com/view/jim-morrison-article.html jim morrison article] [http://libbiemorphis.ifrance.com/blog/chemise.html chemise] [http://poni-tto.isuisse.com/pages/portable-air-compressor.html portable air compressor] [http://coribergquist.ifrance.com/pages/love-it-or-hate.html love it or hate it] [http://renatamonty.ifrance.com/microsoft-front.html microsoft front page web templates] [http://departiz.jushige.cn/daddies-gay.html daddies gay] [http://dessiegiancola.ifrance.com/american-greetings.html american greetings] [http://departiz.jushige.cn/garden-supply-online.html garden supply online] [http://canyondrey.ibelgique.com/topic/online-medical-encyclopedia.html online medical encyclopedia] [http://giant.ns02.biz/blog/one-step-backward.html one step backward] [http://cristinamassey.ifrance.com/face-smother-galleries.html face smother galleries] [http://troubledsparrow.ide.am/marion.html marion] [http://brittanyelwood.ifrance.com/topic/football-clip.html football clip art] [http://myrtiswillis.iespana.es/scream-4-picture.html scream 4 picture] [http://selphie-jazz.ibelgique.com/automobile-body.html automobile body painting repairing service] [http://lestenger.ifrance.com/resources/business-logos.html business logos crafts de...] [http://poni-tto.isuisse.com/pages/local-security.html local security policy xp home] [http://nishamuniz.ifrance.com/lifestyler-treadmill.html lifestyler treadmill] [http://desiraecosby.ifrance.com/library/photographic-memory.html photographic memory] [http://ritawinn.ifrance.com/directory/prada-handbags.html prada handbags] [http://mala-gorie.ibelgique.com/article/turkey-hunting.html turkey hunting secret] [http://kyongflax.ifrance.com/resources/mc-cartney-super.html mc cartney super bowl] [http://revjo.jushige.com/text/weather-man.html weather man tartar sauce] [http://leonoreswaney.ifrance.com/tesselations.html tesselations] [http://roseleeheredia.ifrance.com/electric-radiant.html electric radiant floor systems] [http://cried.sixth.biz/topic/state-birds.html state birds] [http://paullamphere.ifrance.com/topic/information-on.html information on lanl] [http://swill.ns1.name/article/snow-boarding.html snow boarding] [http://allysonhering.ifrance.com/1021-edge-myspacecom.html 102.1 edge myspace.com site toronto] [http://spend.vizvaz.com/universal-studios.html universal studios discount ticket] [http://roseleeheredia.ifrance.com/dog-bowl.html dog bowl] [http://paullamphere.ifrance.com/topic/horizon-hobbies.html horizon hobbies] [http://linniebittinger.profil.in/view/polymers.html polymer clay crafts] [http://antionetterikar.ifrance.com/small/aljazeera-english.html aljazeera english version] [http://loving-skate.isuisse.com/pages/funny-home-videos.html funny home videos] [http://kaang.ide.am/mask.html mask] [http://scourg.ikwb.com/new/no-fax-fast.html no fax fast cash] [http://swill.ns1.name/article/tsubasa-chronicle.html tsubasa chronicle] [http://scourg.ikwb.com/new/weapons-used-in.html weapons used in ww2] [http://cdn-slave.isuisse.com/blog/fake-nude-alicia.html fake nude alicia keys] [http://lexiehorton.ifrance.com/reverse-mortgage.html reverse mortgage info] [http://myrtiswillis.iespana.es/mike-tyson.html mike tyson news] [http://char-zheckz.ibelgique.com/mwave-sound-card.html mwave sound card driver] [http://kyongflax.ifrance.com/resources/tatoo-artist.html tatoo artist schools] [http://x-accipiter.isuisse.com/small/alone-bed-girl.html alone bed girl in] [http://renatamonty.ifrance.com/shannon-gleason.html shannon gleason actress] [http://alyshabeery.ifrance.com/blog/en-sexyservidoras.html en sexyservidoras] [http://daniel.ygto.com/wiki/list-of-free-government.html list of free government grants] [http://roseleeheredia.ifrance.com/background-investigation.html background investigation] [http://lahomayamaguchi.jushige.com/description/photomerge.html photomerge] [http://astridorona.ifrance.com/tradin-times.html tradin times] [http://gildachoice.ifrance.com/small/nissan-repair-manual.html nissan repair manual quest] [http://revjo.jushige.com/text/o-ring-ingold.html o-ring ingold] [http://tandraverdugo.ifrance.com/wiki/holding-pee.html holding pee] [http://joyegrundy.ifrance.com/article/bisodol.html bisodol] [http://cdn-slave.isuisse.com/blog/grooved-hardwood.html grooved hardwood panels] [http://turoush.ifrance.com/pet-animals-for.html pet animals for sale] [http://lapsed.trickip.net/loritab.html loritab] [http://karigalles.jushige.cn/blog/desperate-teens.html desperate teens] [http://shenitayoungqui.ifrance.com/seroquel-for.html seroquel for sleep] [http://kasiecrosland.profil.in/comments/web-phone-conferencing.html web phone conferencing] [http://giant.ns02.biz/blog/female-escort-service.html female escort service] [http://dessiegiancola.ifrance.com/job-corp.html job corp] [http://linniebittinger.profil.in/view/ugly-girl-photos.html ugly girl photos] [http://sanadche.ibelgique.com/blog/coralife.html coralife] [http://larondaglen.ifrance.com/data/k-love-spanish-radio.html k love spanish radio station] [http://nishamuniz.ifrance.com/furniture-parts.html furniture parts] [http://paullamphere.ifrance.com/topic/reloading-supplies.html reloading supplies] [http://ritawinn.ifrance.com/directory/cellphone-wallpaper.html cellphone wallpaper] [http://laynephillips.ifrance.com/article/www-mypay-com.html www mypay com] [http://lahomayamaguchi.jushige.com/description/mississippi-money.html mississippi money for surveys] [http://chuvaaak.iespana.es/q/online-medical-billing.html billing course medical online] [http://lahomayamaguchi.jushige.com/description/box-jellyfish.html box jelly fish habitat] [http://giant.ns02.biz/blog/hendrix.html hendrix] [http://leonoreswaney.ifrance.com/software-sales.html software sales] [http://oliviagrimaldo.ifrance.com/view/polypropylene-films.html polypropylene films] [http://renatamonty.ifrance.com/honda-shadow.html honda shadow] [http://sergeshestakov.ourprofile.info/description/free-music-catalogs.html free music catalogs] [http://laynephillips.ifrance.com/article/old-car.html old car] [http://selphie-jazz.ibelgique.com/metal-ringtone.html big black penis pic] [http://valenecaison.ide.am/mads-junker.html mads junker] [http://desiraecosby.ifrance.com/library/bowling-green.html bowling green kentucky chevrolet] [http://roseleeheredia.ifrance.com/my-first-ejaculation.html my first ejaculation] [http://antionetterikar.ifrance.com/small/strange-meeting.html strange meeting by susan hill] [http://agued.ns01.info/library/wwwcmtcom.html www.cmt.com] [http://departiz.jushige.cn/ass-movies.html ass movies] [http://ritawinn.ifrance.com/directory/lavasoft-adaware.html lavasoft adaware] [http://aladdill.ourprofile.info/articles/freida.html freida] [http://astridorona.ifrance.com/railway-hotel-kalgoorlie.html railway hotel kalgoorlie] [http://x-accipiter.isuisse.com/small/felix-trinidad.html felix trinidad] [http://spend.vizvaz.com/musical-theatre.html musical theatre dance] [http://kaang.ide.am/autocom.html aig auto.com] [http://poni-tto.isuisse.com/pages/pakistan-international.html airline international pakistan pia] [http://brittanyelwood.ifrance.com/topic/sears-home-center.html sears home center] [http://huldagriggs.ifrance.com/articles/private-video.html private video] [http://astridorona.ifrance.com/texas-department.html texas department of motor vehicles] [http://oliviagrimaldo.ifrance.com/view/indianapolis-business.html indianapolis business] [http://moot-hest.iespana.es/listen-my-children.html listen my child and you shall hear] [http://gildachoice.ifrance.com/small/today-show.html today show] [http://coribergquist.ifrance.com/pages/amateur-match.html amateur match] [http://kaang.ide.am/london-sightseeing.html london england sightseeing] [http://joyegrundy.ifrance.com/article/sapphic-erotica.html sapphic erotica] [http://chuvaaak.iespana.es/q/lorrie-morgan.html lorrie morgan] [http://shonnaculbert.ifrance.com/lib/kingston-secure.html card digital kingston memory secure] [http://lapsed.trickip.net/keyless-remote.html keyless remote] [http://valenecaison.ide.am/getty-images.html abrams dan getty image] [http://coribergquist.ifrance.com/pages/refinishing-cast.html refinishing cast iron bath tub] [http://antionetterikar.ifrance.com/small/summer-days.html summer days] [http://whipartist.profil.in/artist-clip-art.html artist clip art] [http://yokowaldrup.ifrance.com/succulents.html complete book of cactus succulents] [http://daniel.ygto.com/wiki/discount-ceiling.html discount ceiling fan] [http://alyshabeery.ifrance.com/blog/system-restore.html system restore] [http://cristinamassey.ifrance.com/patchwork.html patchwork] [http://cristinamassey.ifrance.com/6736-hc9.html 6736 hc9] [http://shenitayoungqui.ifrance.com/printable-birthday.html printable birthday cards] [http://aladdill.ourprofile.info/articles/jim-zulevic.html jim zulevic] [http://cindisheen.ifrance.com/view/mangarosa-restaurant.html mangarosa restaurant] [http://ships.xxuz.com/resources/young-pussy-small.html young pussy small tit] [http://roger.compress.to/view/ati-mach64-gx-64.html ati mach64 gx 64 bit] [http://rosymcphearson.jushige.cn/data/bachelor-party.html bachelor party sex] [http://spend.vizvaz.com/backgammon-game.html backgammon game] [http://moot-hest.iespana.es/embroidery-digitizing.html embroidery digitizing software] [http://x-accipiter.isuisse.com/small/uk-horse-racing.html uk horse racing tracks] [http://rosymcphearson.jushige.cn/data/britany-spears.html britany spears porn] [http://edelmirashiffle.ifrance.com/directory/birth-video.html birth video] [http://gildachoice.ifrance.com/small/cellular-south.html cellular south free ringtones] [http://huldagriggs.ifrance.com/articles/all-hard-sex.html all hard sex] [http://brittanyelwood.ifrance.com/topic/1914-studebaker.html 1914 studebaker]
This article was taken from a HLDS_APPS posting by [[User:Alfred|Alfred Reynolds]].
This article was taken from a HLDS_APPS posting by [[User:Alfred|Alfred Reynolds]].



Revision as of 07:12, 2 January 2008

This article was taken from a HLDS_APPS posting by Alfred Reynolds.

Additional Remarks have been added to Alfred's Documentation. This is taken from the KQuery Wiki, as unfortunately the page is defaced. One can dig deeply through the revision history to obtain the information, some of which is vital to creating a working implementation.. I have taken the liberty of echoing it here.

Source Server RCON format

The protocol is based around command/response packets encapsulated in a TCP/IP stream. The stream can have multiple outstanding commands and can be extended to allow for multiple sub-channels of data.

Sending

The command packet format consists of:

  • packet size (int)
    • the number of bytes from the start of the requestid to the end of string2 (including the null byte). It must be at least 10.
  • request id (int)
  • SERVERDATA_EXECCOMMAND / SERVERDATA_AUTH (int)
    • SERVERDATA_AUTH is currently 3
    • SERVERDATA_EXECCOMMAND is currently 2
  • string1 (is the command to run).
  • string2 must be null ("");

For RCON connections the first command must be a SERVERDATA_AUTH command. If a SERVERDATA_EXECCOMMAND command is sent prior to successful authentication then a SERVERDATA_AUTH_RESPONSE response packet with the failure condition is sent (see the response section for details). The INT's are 32 Bit Little Endian byte order.

Receiving

The response packet is the same as the command packet, which is:

  • packet size (int)
    • If the response spans over multiple packets only the first has these fields. The Other packets are just data.
      • It seems to me, that this has been changed, my response are including those fields. --Plastofix 18:46, 19 Dec 2007 (PST)
  • request id (int)
  • command response (int)
    • valid command responses being:
      SERVERDATA_RESPONSE_VALUE = 0
      or SERVERDATA_AUTH_RESPONSE = 2
  • string1 (null delimited string)
  • string2 (null delimited string)

SERVERDATA_AUTH_RESPONSE is sent in response to a SERVERDATA_AUTH command (or to a SERVERDATA_EXECCOMMAND command if the connection is not successfully authenticated). Both strings are set to null. If the request id is -1 (0xffffffff) then the authentication attempt failed (due to a bad password). If the request id is the same value as sent in the command (i.e the value was mirrored back) then authentication was successful. Any other request id is an error and the SERVERDATA_AUTH command should be resent.

SERVERDATA_RESPONSE_VALUE is sent in response to a SERVERDATA_EXECCOMMAND command. string1 contains the response to the command and string2 is null (""). string1 is at most 4096 characters, so a single SERVERDATA_EXECCOMMAND command may result in multiple SERVERDATA_RESPONSE_VALUE response packets.

Additional Comments

These are additional comments added by an anonymous reader on the KQuery wiki. These are accurate and recommended (and in some cases required) for proper implementation of the RCON protocol in Source.

  • Request ID is mirrored back properly
  • CS:Source server sends one junk packet during the authentication step, before it responds with the correct authentication response.
    • It seems this junk packet is also valid under HL2:DM, not just CS:Source, so probably applies to all Source games (unless Rcon stuff is done differently in other Source powered games by 3rd parties). --Bartk 12:13, 2 Oct 2006 (PDT)
  • The packet size field does NOT include the size of the packet size field itself. That is why the minimum length is 10 -- four bytes for the two integers (request ID and command) plus two bytes for the potentially empty ASCIIZ strings.
  • Make sure that you code the ability to handle multiple response "packets". With a 32-player server, it will use these commonly for status commands (for instance), just as HLDS often did. Also, keep in mind that you won't be able to read the whole "packet" at one time -- you need to keep reading in a loop until you receive the entire packet before processing it.

Implementations

A (hopefully comprehensive) listing of library implementations of the Source RCON protocol.

  • Ruby RCon RCon library for Source and Quake RCON derivatives (such as HLDS) written in Ruby.
  • C++ Sample class to do Source RCON in C++
  • CLI A command-line program to issue RCON commands, written in C
  • Python SRCDSpy Python Library to handle all Source Queries, including RCON
  • C# C# Library and Sample Program (by Andrew Simpson)
  • Java Java RCON Library for Source (also HL1, COD/2, and BF2)
  • VB6 VisualBasic 6.0 (Source RCON only) sample up to you to process DataArrival (by: Jaime Gavin)