| 
									
										
										
										
											2021-02-12 16:51:12 +01:00
										 |  |  | package domain | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"github.com/caos/zitadel/internal/crypto" | 
					
						
							| 
									
										
										
										
											2021-02-23 15:13:04 +01:00
										 |  |  | 	es_models "github.com/caos/zitadel/internal/eventstore/v1/models" | 
					
						
							| 
									
										
										
										
											2021-02-12 16:51:12 +01:00
										 |  |  | 	"time" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type KeyPair struct { | 
					
						
							|  |  |  | 	es_models.ObjectRoot | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Usage      KeyUsage | 
					
						
							|  |  |  | 	Algorithm  string | 
					
						
							|  |  |  | 	PrivateKey *Key | 
					
						
							|  |  |  | 	PublicKey  *Key | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type KeyUsage int32 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const ( | 
					
						
							|  |  |  | 	KeyUsageSigning KeyUsage = iota | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (u KeyUsage) String() string { | 
					
						
							|  |  |  | 	switch u { | 
					
						
							|  |  |  | 	case KeyUsageSigning: | 
					
						
							|  |  |  | 		return "sig" | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return "" | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type Key struct { | 
					
						
							|  |  |  | 	Key    *crypto.CryptoValue | 
					
						
							|  |  |  | 	Expiry time.Time | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) IsValid() bool { | 
					
						
							|  |  |  | 	return k.Algorithm != "" && | 
					
						
							|  |  |  | 		k.PrivateKey != nil && k.PrivateKey.IsValid() && | 
					
						
							|  |  |  | 		k.PublicKey != nil && k.PublicKey.IsValid() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *Key) IsValid() bool { | 
					
						
							|  |  |  | 	return k.Key != nil | 
					
						
							|  |  |  | } |