SOSPeerRateLimiter.m   [plain text]


//
//  SOSPeerRateLimiter.m
//  SecureObjectSyncServer
//

#import <Foundation/Foundation.h>
#import <keychain/ckks/RateLimiter.h>
#import "Security/SecureObjectSync/SOSPeerRateLimiter.h"

#include <Security/SecureObjectSync/SOSPeer.h>
#include <utilities/SecCFError.h>
#include <utilities/SecCFRelease.h>
#include <utilities/SecCFWrappers.h>

//
// RateLimiting Code per Peer

@implementation PeerRateLimiter

@synthesize peerID = peerID;

-(NSDictionary*) setUpConfigForPeer
{
    NSData *configData = [@"<?xml version=\"1.0\" encoding=\"UTF-8\"?>\
                          <!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\
                          <plist version=\"1.0\">\
                          <dict>\
                          <key>general</key>\
                          <dict>\
                          <key>maxStateSize</key>\
                          <integer>250</integer>\
                          <key>maxItemAge</key>\
                          <integer>3600</integer>\
                          <key>overloadDuration</key>\
                          <integer>1800</integer>\
                          <key>name</key>\
                          <string>SOS</string>\
                          <key>MAType</key>\
                          <string></string>\
                          </dict>\
                          <key>groups</key>\
                          <array>\
                                <dict>\
                                    <key>property</key>\
                                    <string>global</string>\
                                    <key>capacity</key>\
                                    <integer>1000</integer>\
                                    <key>rate</key>\
                                    <integer>10</integer>\
                                    <key>badness</key>\
                                    <integer>1</integer>\
                                </dict>\
                                <dict>\
                                    <key>property</key>\
                                    <string>accessGroup</string>\
                                    <key>capacity</key>\
                                    <integer>50</integer>\
                                    <key>rate</key>\
                                    <integer>900</integer>\
                                    <key>badness</key>\
                                    <integer>3</integer>\
                                </dict>\
                          </array>\
                          </dict>\
                          </plist>\
                          " dataUsingEncoding:NSUTF8StringEncoding];

    NSError *err = nil;
    return ([NSPropertyListSerialization propertyListWithData:configData options:NSPropertyListImmutable format:nil error:&err]);
}

-(instancetype)initWithPeer:(SOSPeerRef)peer
{
    self = [super initWithConfig:[self setUpConfigForPeer]];
    if(self){
        self.peerID = (__bridge NSString *)(SOSPeerGetID(peer));
        self.accessGroupRateLimitState = [[NSMutableDictionary alloc] init];
        self.accessGroupToTimer = [[NSMutableDictionary alloc]init];
        self.accessGroupToNextMessageToSend = [[NSMutableDictionary alloc]init];
    }
    return self;
}

-(enum RateLimitState) stateForAccessGroup:(NSString*) accessGroup
{
    enum RateLimitState stateForAccessGroup;
     NSNumber *state = [self.accessGroupRateLimitState objectForKey:accessGroup];
    if(state == nil)
    {
        //initialize access group state
        stateForAccessGroup = RateLimitStateCanSend;
        NSNumber *initialize = [[NSNumber alloc] initWithLong:stateForAccessGroup];
        [self.accessGroupRateLimitState setObject:initialize forKey:accessGroup];
    }else{
        stateForAccessGroup = [state intValue];
    }
    return stateForAccessGroup;
}
@end

@implementation KeychainItem

-(instancetype)initWithAccessGroup:(NSString *)accessGroup
{
    self = [super init];
    if(self){
        _accessGroup = accessGroup;
    }
    return self;
}

@end