1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
|
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================
#ifndef CLIENTENUMS_H
#define CLIENTENUMS_H
#ifdef _WIN32
#pragma once
#endif
enum ELogonState
{
k_ELogonStateNotLoggedOn = 0,
k_ELogonStateLoggingOn = 1,
k_ELogonStateLoggingOff = 2,
k_ELogonStateLoggedOn = 3
};
// Enums for all personal questions supported by the system.
enum EPersonalQuestion
{
// Never ever change these after initial release.
k_EPSMsgNameOfSchool = 0, // Question: What is the name of your school?
k_EPSMsgFavoriteTeam = 1, // Question: What is your favorite team?
k_EPSMsgMothersName = 2, // Question: What is your mother's maiden name?
k_EPSMsgNameOfPet = 3, // Question: What is the name of your pet?
k_EPSMsgChildhoodHero = 4, // Question: Who was your childhood hero?
k_EPSMsgCityBornIn = 5, // Question: What city were you born in?
k_EPSMaxPersonalQuestion
};
// account flags (stored in DB)
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASEd
enum EAccountFlags
{
m_EAccountFlagNormalUser = 0, // Standard user level (yes, this is meant to be zero)
k_EAccountFlagPersonaNameSet = ( 1 << 0 ), // true if the user has set the persona name they really want, instead of the auto-generated one
k_EAccountFlagUnbannable = ( 1 << 1 ), // whatever happens, this account can't be banned
k_EAccountFlagPasswordSet = ( 1 << 2 ), // we've set the password at least once on this account
k_EAccountFlagSupport = ( 1 << 3 ), // Enables use of web support tool
k_EAccountFlagAdmin = ( 1 << 4 ), // The name says it all, can do everything
k_EAccountFlagSupervisor = ( 1 << 5 ), // support supervisory role
k_EAccountFlagAppEditor = ( 1 << 6 ), // Can edit app info
k_EAccountFlagHWIDSet = ( 1 << 7 ), // Set HWID once
k_EAccountFlagPersonalQASet = ( 1 << 8 ), // user has personal Question & anser set
k_EAccountFlagVacBeta = ( 1 << 9 ), // user participates in VAC beta tests
k_EAccountFlagDebug = ( 1 << 10 ), // user is in debug mode, eg VAC doesn't kick etc
k_EAccountFlagDisabled = ( 1 << 11 ), // account is disabled.
k_EAccountFlagLimitedUser = ( 1 << 12 ), // account is limited user account because it doesnt own anything
k_EAccountFlagLimitedUserForce = ( 1 << 13 ), // account is limited user account because we forced it to be
k_EAccountFlagEmailValidated = ( 1 << 14 ), // user has verified email address via WG
k_EAccountFlagMarketingTreatment = ( 1 << 15), // account is flagged as being in a treatment for marketing/sales experiments
};
// profile state (stored in DB)
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ECommunityProfileState
{
k_ECommunityProfileNotCreated = 0, // user hasn't setup community account yet
k_ECommunityProfileActive = 1, // user joined community, site is public
k_ECommunityProfilePrivate = 2, // user joined community, site is private
k_ECommunityProfileLocked = 3, // user got locked, content can't be changed but is still accessible
k_ECommunityProfileDisabled = 4, // user got disabled, site not accessible anymore
};
// profile privacy option setting (stored in DB)
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ECommunityPrivacyState
{
k_ECommunityPrivacyInvalid = 0,
k_ECommunityPrivacyPrivate = 1, // ain't nobody can see it
k_ECommunityPrivacyFriendsOnly = 2, // only your friends can see it
k_ECommunityPrivacyPublic = 3, // anybody could see it
};
enum ECommunityVisibilityState
{
k_ECommunityVisibilityPrivate = 1, // private, requester see only public fields
k_ECommunityVisibilityFriendsOnly = 2, // friends only, requester sees only public fields
k_ECommunityVisibilityOpen = 3, // it is visible to requester; they are owner or friend or public
k_ECommunityVisibilitySupportPrivate = 4, // was private, but it's a support account asking
k_ECommunityVisibilitySupportFriendsOnly = 5,// was friends only, but it's a support account asking
};
enum ECommentPermission
{
k_ECommentPermissionFriendsOnly = 0, // only friends can leave a comment
k_ECommentPermissionAnyone = 1, // anybody can leave a comment
k_ECommentPermissionSelfOnly = 2, // only the account owner can leave a comment
};
// Payment methods for purchases - BIT FLAGS so can be used to indicate
// acceptable payment methods for packages
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum EPaymentMethod
{
k_EPaymentMethodNone = 0x000, // user got the license for free
k_EPaymentMethodActivationCode = 0x001, // user paid by entering unused CD-Key or other activation code
k_EPaymentMethodCreditCard = 0x002, // user paid with credit card
k_EPaymentMethodPayPal = 0x004, // user paid with via paypal
k_EPaymentMethodGuestPass = 0x008, // user paid by redeeming a guest pass
k_EPaymentMethodHardwarePromo = 0x010, // user presented machine credentials
k_EPaymentMethodClickAndBuy = 0x020, // ClickandBuy
k_EPaymentMethodAutoGrant = 0x040, // server side purchased package, things like German specific TF2 free weekend
k_EPaymentMethodWallet = 0x080, // user paid with wallet
k_EPaymentMethodOEMTicket = 0x100, // user paid by redeeming a OEM license ticket
k_EPaymentMethodSplit = 0x200, // user paid with wallet AND a provider
};
// Sources for WalletTxn records
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum EWalletSource
{
k_EWalletSourceInvalid = 0,
k_EWalletSourcePurchase = 1, // Created from a purchase, refund, chargeback, or reverse chargeback (PurchaseRefGID -> TransID)
k_EWalletSourceGuestPass = 2, // Created from a guest pass (PurchaseRefGID -> GuestPassID)
k_EWalletSourceConversion = 3, // Created from a wallet conversion (PurchaseRefGID -> GID shared between debit & credit records)
k_EWalletSourceRebate = 4, // Created from a rebate (PurchaseRefGID -> TransID)
};
// License types
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ELicenseType
{
k_ENoLicense = 0, // for shipped goods
k_ESinglePurchase = 1, // single purchase
k_ESinglePurchaseLimitedUse = 2, // single purchase w/ expiration
k_ERecurringCharge = 3, // recurring subscription
k_ERecurringChargeLimitedUse = 4, // recurring subscription w/ limited minutes per period
k_ERecurringChargeLimitedUseWithOverages = 5, // like above but w/ soft limit and overage charges
};
// Flags for licenses - BITS
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ELicenseFlags
{
k_ELicenseFlagNone = 0x00, // just a place holder
k_ELicenseFlagRenew = 0x01, // Renew this license next period
k_ELicenseFlagRenewalFailed = 0x02, // Auto-renew failed
k_ELicenseFlagPending = 0x04, // Purchase or renewal is pending
k_ELicenseFlagExpired = 0x08, // Set if no longer active (whatever the reason)
k_ELicenseFlagCancelledByUser = 0x10, // Cancelled by the user
k_ELicenseFlagCancelledByAdmin = 0x20, // Cancelled by customer support
k_ELicenseFlagLowViolenceContent = 0x40,// license is for low violence content
};
// Status of a package
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum EPackageStatus
{
k_EPackageAvailable = 0, // Available for purchase and use
k_EPackagePreorder = 1, // Available for purchase, as a pre-order
k_EPackageUnavailable = 2, // Not available for new purchases, may still be owned
k_EPackageInvalid = 3, // Either an unknown package or a deleted one that nobody should own
};
// Purchase status
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum EPurchaseStatus
{
k_EPurchasePending = 0, // purchase is pending, valid but pending subscription
k_EPurchaseSucceeded = 1, // purchase successful, valid subscription
k_EPurchaseFailed = 2, // purchase failed, no subscription
k_EPurchaseRefunded = 3, // we refunded the purchase and removed subscription
k_EPurchaseInit = 4, // user started purchase
k_EPurchaseChargedback = 5, // the user issued a chargeback, we removed subscription
k_EPurchaseRevoked = 6, // we revoked the purchase and removed subscription. Usually stolen CD-Keys
k_EPurchaseInDispute = 7, // the purchase is being disputed by the user, preliminary to a chargeback
};
// LineItemTypes
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASEd
enum ELineItemType
{
k_ELineItemTypeInvalid = 0, // Unknown - load all purchase line items
k_ELineItemTypeMicroTxn = ( 1 << 0 ), // Transaction has data in MicroTxnLineItem table
k_ELineItemTypeWallet = ( 1 << 1 ), // Transaction has data in WalletLineItem table
k_ELineItemTypePkg = ( 1 << 2 ), // Transaction has data in PurchaseLineItem table
};
// Enum for the types of news push items you can get
enum ENewsUpdateType
{
k_EAppNews = 0, // news about a particular app
k_ESteamAds = 1, // Marketing messages
k_ESteamNews = 2, // EJ's corner and the like
k_ECDDBUpdate = 3, // backend has a new CDDB for you to load
k_EClientUpdate = 4, // new version of the steam client is available
};
// Detailed purchase result codes for the client
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum EPurchaseResultDetail
{
k_EPurchaseResultNoDetail = 0,
k_EPurchaseResultAVSFailure = 1,
k_EPurchaseResultInsufficientFunds = 2,
k_EPurchaseResultContactSupport = 3,
k_EPurchaseResultTimeout = 4,
k_EPurchaseResultInvalidPackage = 5,
k_EPurchaseResultInvalidPaymentMethod = 6,
k_EPurchaseResultInvalidData = 7,
k_EPurchaseResultOthersInProgress = 8,
k_EPurchaseResultAlreadyPurchased = 9,
k_EPurchaseResultWrongPrice = 10,
k_EPurchaseResultFraudCheckFailed = 11,
k_EPurchaseResultCancelledByUser = 12,
k_EPurchaseResultRestrictedCountry = 13,
k_EPurchaseResultBadActivationCode = 14, // this code gives no receipt
k_EPurchaseResultDuplicateActivationCode = 15,
k_EPurchaseResultUseOtherPaymentMethod = 16, // User should try a different payment method
k_EPurchaseResultUseOtherFundingSource = 17, // Select a different funding source (paypal)
k_EPurchaseResultInvalidShippingAddress = 18, // Shipping address is invalid (paypal)
k_EPurchaseResultRegionNotSupported = 19, // This region is not supported with this payment type
k_EPurchaseResultAcctIsBlocked = 20, // Acct has been blocked by provider - user should contact provider to resolve
k_EPurchaseResultAcctNotVerified = 21, // Provider indicated account needs to be verified for transaction to complete
k_EPurchaseResultInvalidAccount = 22, // Provider indicated the account is invalid or no longer usable
k_EPurchaseResultStoreBillingCountryMismatch = 23, // store country code & billing country code do not match
k_EPurchaseResultDoesNotOwnRequiredApp = 24, // user does not own one of the apps required for purchase
k_EPurchaseResultCanceledByNewTransaction = 25, // user made a new transaction which canceled an old, pending transaction
k_EPurchaseResultForceCanceledPending = 26, // A pending transaction was force canceled (no response from provider)
k_EPurchaseResultFailCurrencyTransProvider = 27, // selected transaction provider does not support calculated currency
k_EPurchaseResultFailedCyberCafe = 28, // cybercafe account tried to purchase or use an activation code
k_EPurchaseResultNeedsPreApproval = 29, // Transaction needs approval from support
k_EPurchaseResultPreApprovalDenied = 30, // Transaction was denied by support
k_EPurchaseResultWalletCurrencyMismatch = 31, // Currency of purchase does not match currency of wallet
};
// Type of system IM. The client can use this to do special UI handling in specific circumstances
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ESystemIMType
{
k_ESystemIMRawText = 0,
k_ESystemIMInvalidCard = 1,
k_ESystemIMRecurringPurchaseFailed = 2,
k_ESystemIMCardWillExpire = 3,
k_ESystemIMSubscriptionExpired = 4,
k_ESystemIMGuestPassReceived = 5, // User has received a guest pass from a friend
k_ESystemIMGuestPassGranted = 6, // System has granted a user a guest pass to give out
k_ESystemIMGiftRevoked = 7, // We revoked a gift due to chargeback, etc
//
k_ESystemIMTypeMax
};
// Ways an external cd key can be munged onto a users PC
enum ELegacyKeyRegistrationMethod
{
eLegacyKeyRegistrationMethodNone = 0, // doesn't support legacy cd keys
eLegacyKeyRegistrationMethodRegistry, // just place it into the registry
eLegacyKeyRegistrationMethodDisk, // put it in a file on disk
};
// Support events, generated by system or support input
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ESupportEvent
{
// support activity
eSupportNote = 0, // a generic support note
eSupportLogin = 1, // support account logged in out, data: IP:Port
eSupportLogoff = 2, // support account logged out, text: IP:Port
eSupportTicketCreated = 3, // a support ticket was created
eSupportTicketClosed = 4, // problem was solved, ticket closed
// account changes
eSupportEnableAccount = 5, // support enabled account, text: reason
eSupportDisableAccount = 6, // support disabled account, text: reason
eSupportChangeAccountPassword = 7, // support or user changed password, data: DONT include old password
eSupportChangeAccountEmail = 8, // support or user changed email, data: old email
eSupportChangeAccountName = 9, // support or user changed name, data: old name
eSupportChangeAccountPlayer = 10, // support or user changed player name, data: old name
eSupportPurchaseChargedback = 11, // a charge back was issued
eSupportPurchaseRefunded = 12, // a refund was issued
eSupportPurchaseForcedCompletion = 13, // support forced a pending purchase to complete
// license handling
eSupportLicenseAdded = 14, // support added a license, text: reason
eSupportLicenseCanceled = 15, // support or user cancel a license
eSupportLicenseChanged = 16, // support removed a license, text: reason
eSupportBannedGame = 17, // support banned game for an account
eSupportUnbannedGame = 18, // support unbanned game for an account
// purchase activity
eSupportRunPurchase = 19,
eSupportChangedCreditCard = 20, // support updated a credit card
eSupportSetNoFraudCheckFlag = 21, // support disabled fraud check, data: reason
// banning
eSupportBannedCreditCard = 22, // support banned a credit card
eSupportBannedIP = 23, // support banned an IP
eSupportBannedCDKey = 24, // support banned an CDKey
eSupportBannedCountry = 25, // support banned a country
eSupportBannedPayPalAccount = 26,
eSupportPurchaseCanceled = 27, // support forced a pending purchase to cancel
eSupportChangeAvatar = 28,
eSupportChangeProfileURL = 29,
eSupportRegisterCDKey = 30, // support added a CD key to this account
eSupportGrantGuestPass = 31, // support granted a guest pass to this account
eSupportResubmitTransaction = 32, // support resubmitted a transaction
eSupportResetContent = 33, // reset user content based on abuse reports
eSupportLockProfile = 34, // temp block a user from modifying community content
eSupportSetCommunityState = 35, // perm lock a user profile, can't be modified
eSupportDeleteAbuseReports = 36, // deleted abuse reports for the SteamID
eSupportSetAccountFlags = 37, // changed account flags
eSupportChargebackStatusUpdate = 38, // support updated the pending chargeback status
eSupportRefundForcedCompletion = 39, // support forced a pending refund to complete
eSupportRefundCanceled = 40, // support forced a pending refund to cancel
eSupportRevokeActivationKey = 41, // support revoked and unlocked activation key
eSupportReverseChargeback = 42, // a charge back was reversed
eSupportRejectedActivationKey = 43, // activation key was rejected (invalid or already used)
eSupportPurchaseError = 44, // Purchase error
eSupportAudited = 45,
// items
eSupportBanItems = 46, // support banned a user's items
eSupportRestoreBannedItems = 47, // support restored banned items
eSupportRestoreDeletedItems = 48, // support restored deleted items
// comments
eSupportDeleteComments = 49, // cleared comments on this account (not written by this account)
eSupportDeleteItems = 50, // support deleted a user's items
eSupportDeleteCachedCard = 51, // support deleted a user's cached credit card
eSupportConvertedWallet = 52, // user's wallet was converted
eSupportTxnApproved = 53, // PreApproval granted
eSupportTxnDenied = 54, // PreApproval denied
eSupportGCAction = 55, // used for all support actions from the GC
};
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ESupportTicket
{
// all kinds of problems tickets that have to be handled by support
k_ETicketUnknown = 0, // an unknown problem. yay.
k_ETicketManual = 1, // a problem manually entered by support.
k_ETicketFraudRedFlag = 2, // fraud detection marked this account
k_ETicketPurchaseError = 3, // a purchase error happened
k_ETicketChargeback = 4, // a chargeback needs attention
};
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ESupportTicketState
{
// all kinds of problems tickets that have to be handled by support
k_ETicketStateUnknown = 0, // support issue state is unknown
k_ETicketStateUnassigned = 1, // support issue is 'open' but not assigned yet
k_ETicketStateInProcess = 2, // support issue is assigned to an support actor
k_ETicketStateResolved = 3, // support issue is fixed and closed
k_ETicketStateUnresolved = 4, // support issue couldn't be fixed. closed anyway
k_ETicketStateAutoClosed = 5, // System closed the ticket automatically
};
//-----------------------------------------------------------------------------
// types of content that can be reported as abused
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum ECommunityContentType
{
k_EContentUnspecified = 0,
k_EContentAll = 1, // reset all community content
k_EContentAvatarImage = 2, // clear avatar image
k_EContentProfileText = 3, // reset profile text
k_EContentWebLinks = 4, // delete web links
k_EContentAnnouncement = 5,
k_EContentEventText = 6,
k_EContentCustomCSS = 7,
k_EContentProfileURL = 8, // delete community URL ID
k_EContentComments = 9, // just comments this guy has written
};
//-----------------------------------------------------------------------------
// types of reasons why a violation report was issued
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum EAbuseReportType
{
k_EAbuseUnspecified = 0,
k_EAbuseInappropriate = 1, // just not ok to post
k_EAbuseProhibited = 2, // prohibited by EULA or general law
k_EAbuseSpamming = 3, // excessive spamming
k_EAbuseAdvertisement = 4, // unwanted advertisement
k_EAbuseExploit = 5, // content data attempts to exploit code issue
k_EAbuseSpoofing = 6, // user/group is impersonating an official contact
k_EAbuseLanguage = 7, // bad language
k_EAbuseAdultContent = 8, // any kind of adult material, references etc
k_EAbuseHarassment = 9, // harassment, discrimination, racism etc
};
//-----------------------------------------------------------------------------
// actions for a user within a clan for logging in the ClanHistory table
//-----------------------------------------------------------------------------
enum EClanAction
{
k_EJoined = 1, // joined the clan
k_ELeft = 2, // left the clan
k_EPromoted = 3, // promoted to officer
k_EDemoted = 4, // demoted from officer
k_EKicked = 5, // kicked off the clan
k_ECreated = 6, // clan was created
k_EInvited = 7, // invited someone
k_EEventCreated = 8, // clan event created
k_EEventUpdated = 9, // clan event updated
k_EEventDeleted = 10, // clan event deleted
k_EPermissionsChanged = 11, // clan permissions were changed
k_EAnnouncementCreated = 12, // clan announcement created
k_EAnnouncementUpdated = 13, // clan announcement updated
k_EAnnouncementDeleted = 14, // clan announcement deleted
k_EPOTWChanged = 15, // changed the POTW
k_ELinksChanged = 16, // links changed
k_EDetailsChanged = 17, // details changed
k_ESupportResetContent = 18, // support reset some or all of the clan content
k_ESupportLockedGroup = 19, // support locked this clan, it can't be modified anymore
k_ESupportUnlockedGroup = 20, // support unlocked this clan
k_ESupportChangedOwner = 21, // support transfered ownership
k_EMadePublic = 22, // made from private into public
k_EMadePrivate = 23, // made from public into private
k_ESupportDisabledGroup = 24, // support disabled this group, nobody can see it anymore
k_EKickedChat = 25, // kicked from chat
k_EBannedChat = 26, // banned from chat
k_EUnBannedChat = 27, // un-banned from chat
k_EHighestValidAction // keep me updated, please!
};
//-----------------------------------------------------------------------------
// types of events for use in the Clan Event Type table
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum EClanEventType
{
k_EOtherEvent = 1,
k_EGameEvent = 2,
k_EPartyEvent = 3,
k_EMeetingEvent = 4,
k_ESpecialCauseEvent = 5,
k_EMusicAndArtsEvent = 6,
k_ESportsEvent = 7,
k_ETripEvent = 8,
k_EChatEvent = 9,
k_EGameReleaseEvent = 10,
};
//-----------------------------------------------------------------------------
// types of marketing messages displayed to users
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum EMarketingMessageType
{
k_EMarketingMessageNowAvailable = 1,
k_EMarketingMessageWeekendDeal = 2,
k_EMarketingMessagePrePurchase = 3,
k_EMarketingMessagePlayNow = 4,
k_EMarketingMessagePreloadNow = 5,
k_EMarketingMessageGeneral = 6,
k_EMarketingMessageDemoQuit = 7,
k_EMarketingMessageGifting = 8,
k_EMarketingMessageEJsKorner = 9,
};
//-----------------------------------------------------------------------------
// types of associations a marketing message may have
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum EMarketingMessageAssociationType
{
k_EMarketingMessageNoAssociation = 0,
k_EMarketingMessageAppAssociation = 1,
k_EMarketingMessageSubscriptionAssociation = 2,
k_EMarketingMessagePublisherAssociation = 3,
k_EMarketingMessageGenreAssociation = 4,
};
//-----------------------------------------------------------------------------
// Marketing message visibility
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
//-----------------------------------------------------------------------------
enum EMarketingMessageVisibility
{
k_EMarketingMessageVisibleBeta = 1,
k_EMarketingMessageVisiblePublic = 2,
};
//-----------------------------------------------------------------------------
// Structures used in multiple messages
//-----------------------------------------------------------------------------
// Purchase message constants
// WARNING: Do not change these if an instance of this record may exist in a database!!!
// BUGBUG derrick - Since these also define schema, they should be moved into steamschema.h
const int k_cchCCNumMax = 16 + 1;
const int k_cchHolderNameMax = 100 + 1;
const int k_cchExpYearMax = 4 + 1;
const int k_cchExpMonthMax = 2 + 1;
const int k_cchCVV2Max = 4 + 1;
const int k_cchAddressMax = 128 + 1;
const int k_cchAddress2Max = k_cchAddressMax;
const int k_cchCityMax = 50 + 1;
const int k_cchPostcodeMax = 16 + 1;
const int k_cchStateMax = 32 + 1;
const int k_cchPhoneMax = 20 + 1;
const int k_cchEmailMax = 100 + 1;
const int k_cchCountryCodeMax = 2 + 1;
const int k_cchPayPalCheckoutTokenMax = 20 + 1;
const int k_cchStateCodeMax = 3 + 1;
const int k_cchCurrencyCodeMax = 3 + 1;
const int k_cubMaxDfsURL = 128; // Max size for URL descriptors on DFS
// License information
struct LicenseInfo_t
{
PackageId_t m_unPackageID;
RTime32 m_RTime32Created;
RTime32 m_RTime32NextProcess;
int32 m_nMinuteLimit;
int32 m_nMinutesUsed;
EPaymentMethod m_ePaymentMethod;
uint32 m_nFlags;
char m_rgchPurchaseCountryCode[k_cchCountryCodeMax];
int32 m_nTerritoryCode;
};
// Supported Currency Codes
// WARNING: DO NOT RENUMBER EXISTING VALUES - STORED IN DATABASE
enum ECurrencyCode
{
k_ECurrencyCodeInvalid = 0,
k_ECurrencyCodeUSD = 1,
k_ECurrencyCodeGBP = 2,
k_ECurrencyCodeEUR = 3,
k_ECurrencyCodeMax = 4
};
enum ETaxType
{
k_ETaxTypeInvalid = 0,
k_ETaxTypeUSState = 1,
k_ETaxTypeVAT = 2
};
// client stat list
// needs to be kept in the same order, since it's part of the protocol
enum EClientStat
{
k_EClientStatP2PConnectionsUDP = 0,
k_EClientStatP2PConnectionsRelay = 1,
k_EClientStatP2PGameConnections = 2,
k_EClientStatP2PVoiceConnections = 3,
k_EClientStatBytesDownloaded = 4,
k_EClientStatMax, // must be last, used as array's of data
};
enum EP2PState
{
k_EP2PStateNotConnected,
k_EP2PStateUDP,
k_EP2PStateRelay,
};
// User response for authentication request
enum EMicroTxnAuthResponse
{
k_EMicroTxnAuthResponseInvalid = 0, // Invalid value
k_EMicroTxnAuthResponseAuthorize = 1, // user accepted microtransaction
k_EMicroTxnAuthResponseDeny = 2, // user denied microtransaction
k_EMicroTxnAuthResponseAutoDeny = 3, // client automatically denied microtransaction (user wasn't in game, etc.)
};
// Result of authorization request, returned to client
enum EMicroTxnAuthResult
{
k_EMicroTxnAuthResultInvalid = 0, // Invalid value
k_EMicroTxnAuthResultOK = 1, // Successfully authorized
k_EMicroTxnAuthResultFail = 2, // An error occurred
k_EMicroTxnAuthResultInsufficientFunds = 3, // User has insufficient funds to complete microtransaction
};
#endif
|