/* * Copyright (C) 2013-2015 RoboVM AB * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.robovm.apple.security; /*<imports>*/ import java.io.*; import java.nio.*; import java.util.*; import org.robovm.objc.*; import org.robovm.objc.annotation.*; import org.robovm.objc.block.*; import org.robovm.rt.*; import org.robovm.rt.annotation.*; import org.robovm.rt.bro.*; import org.robovm.rt.bro.annotation.*; import org.robovm.rt.bro.ptr.*; import org.robovm.apple.foundation.*; import org.robovm.apple.corefoundation.*; import org.robovm.apple.dispatch.*; /*</imports>*/ /*<javadoc>*/ /*</javadoc>*/ /*<annotations>*/@Library("Security")/*</annotations>*/ @Marshaler(/*<name>*/SecMatch/*</name>*/.Marshaler.class) /*<visibility>*/public/*</visibility>*/ class /*<name>*/SecMatch/*</name>*/ extends /*<extends>*/CFDictionaryWrapper/*</extends>*/ /*<implements>*//*</implements>*/ { /*<marshalers>*/ public static class Marshaler { @MarshalsPointer public static SecMatch toObject(Class<SecMatch> cls, long handle, long flags) { CFDictionary o = (CFDictionary) CFType.Marshaler.toObject(CFDictionary.class, handle, flags); if (o == null) { return null; } return new SecMatch(o); } @MarshalsPointer public static long toNative(SecMatch o, long flags) { if (o == null) { return 0L; } return CFType.Marshaler.toNative(o.data, flags); } } public static class AsListMarshaler { @MarshalsPointer public static List<SecMatch> toObject(Class<? extends CFType> cls, long handle, long flags) { CFArray o = (CFArray) CFType.Marshaler.toObject(CFArray.class, handle, flags); if (o == null) { return null; } List<SecMatch> list = new ArrayList<>(); for (int i = 0; i < o.size(); i++) { list.add(new SecMatch(o.get(i, CFDictionary.class))); } return list; } @MarshalsPointer public static long toNative(List<SecMatch> l, long flags) { if (l == null) { return 0L; } CFArray array = CFMutableArray.create(); for (SecMatch i : l) { array.add(i.getDictionary()); } return CFType.Marshaler.toNative(array, flags); } } /*</marshalers>*/ /*<constructors>*/ SecMatch(CFDictionary data) { super(data); } public SecMatch() {} /*</constructors>*/ /*<methods>*/ public boolean has(CFType key) { return data.containsKey(key); } public <T extends NativeObject> T get(CFType key, Class<T> type) { if (has(key)) { return data.get(key, type); } return null; } public SecMatch set(CFType key, NativeObject value) { data.put(key, value); return this; } /** * @since Available in iOS 2.0 and later. */ public SecPolicy getPolicy() { if (has(Keys.Policy())) { SecPolicy val = get(Keys.Policy(), SecPolicy.class); return val; } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setPolicy(SecPolicy policy) { set(Keys.Policy(), policy); return this; } /** * @since Available in iOS 2.0 and later. */ public NSArray<NSData> getIssuers() { if (has(Keys.Issuers())) { NSArray<NSData> val = get(Keys.Issuers(), NSArray.class); return val; } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setIssuers(NSArray<NSData> issuers) { set(Keys.Issuers(), issuers); return this; } /** * @since Available in iOS 2.0 and later. */ public String getEmailAddressIfPresent() { if (has(Keys.EmailAddressIfPresent())) { CFString val = get(Keys.EmailAddressIfPresent(), CFString.class); return val.toString(); } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setEmailAddressIfPresent(String emailAddressIfPresent) { set(Keys.EmailAddressIfPresent(), new CFString(emailAddressIfPresent)); return this; } /** * @since Available in iOS 2.0 and later. */ public String getSubjectContains() { if (has(Keys.SubjectContains())) { CFString val = get(Keys.SubjectContains(), CFString.class); return val.toString(); } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setSubjectContains(String subjectContains) { set(Keys.SubjectContains(), new CFString(subjectContains)); return this; } /** * @since Available in iOS 2.0 and later. */ public boolean isCaseInsensitive() { if (has(Keys.CaseInsensitive())) { CFBoolean val = get(Keys.CaseInsensitive(), CFBoolean.class); return val.booleanValue(); } return false; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setCaseInsensitive(boolean caseInsensitive) { set(Keys.CaseInsensitive(), CFBoolean.valueOf(caseInsensitive)); return this; } /** * @since Available in iOS 2.0 and later. */ public boolean isTrustedOnly() { if (has(Keys.TrustedOnly())) { CFBoolean val = get(Keys.TrustedOnly(), CFBoolean.class); return val.booleanValue(); } return false; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setTrustedOnly(boolean trustedOnly) { set(Keys.TrustedOnly(), CFBoolean.valueOf(trustedOnly)); return this; } /** * @since Available in iOS 2.0 and later. */ public NSDate getValidOnDate() { if (has(Keys.ValidOnDate())) { NSDate val = get(Keys.ValidOnDate(), NSDate.class); return val; } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setValidOnDate(NSDate validOnDate) { set(Keys.ValidOnDate(), validOnDate); return this; } /** * @since Available in iOS 2.0 and later. */ public SecMatchLimit getLimit() { if (has(Keys.Limit())) { CFType val = get(Keys.Limit(), CFType.class); return SecMatchLimit.valueOf(val); } return null; } /** * @since Available in iOS 2.0 and later. */ public SecMatch setLimit(SecMatchLimit limit) { set(Keys.Limit(), limit.value()); return this; } /*</methods>*/ /*<keys>*/ @Library("Security") public static class Keys { static { Bro.bind(Keys.class); } /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchPolicy", optional=true) public static native CFType Policy(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchItemList", optional=true) public static native CFType ItemList(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchSearchList", optional=true) public static native CFType SearchList(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchIssuers", optional=true) public static native CFType Issuers(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchEmailAddressIfPresent", optional=true) public static native CFType EmailAddressIfPresent(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchSubjectContains", optional=true) public static native CFType SubjectContains(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchCaseInsensitive", optional=true) public static native CFType CaseInsensitive(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchTrustedOnly", optional=true) public static native CFType TrustedOnly(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchValidOnDate", optional=true) public static native CFType ValidOnDate(); /** * @since Available in iOS 2.0 and later. */ @GlobalValue(symbol="kSecMatchLimit", optional=true) public static native CFType Limit(); } /*</keys>*/ }