Updated libraries, most notably Jabit to develop-SNAPSHOT
Also, finally added proper icon Known issue: the client seems to sever all connections after some time, I'll need to look into this. This might happen when 8 connections are reached for the first time.
| @@ -1,25 +1,25 @@ | |||||||
| apply plugin: 'idea' | apply plugin: 'idea' | ||||||
| apply plugin: 'com.android.application' | apply plugin: 'com.android.application' | ||||||
|  |  | ||||||
|  | ext { | ||||||
|  |     appName = "Abit" | ||||||
|  | } | ||||||
|  | if (project.hasProperty("project.configs") | ||||||
|  |         && new File(project.property("project.configs") + appName + ".gradle").exists()) { | ||||||
|  |     apply from: project.property("project.configs") + appName + ".gradle"; | ||||||
|  | } | ||||||
|  |  | ||||||
| android { | android { | ||||||
|     compileSdkVersion 23 |     compileSdkVersion 24 | ||||||
|     buildToolsVersion "23.0.3" |     buildToolsVersion "24.0.1" | ||||||
|  |  | ||||||
|     defaultConfig { |     defaultConfig { | ||||||
|         applicationId "ch.dissem.apps.abit" |         applicationId "ch.dissem.apps." + appName.toLowerCase() | ||||||
|         minSdkVersion 19 |         minSdkVersion 19 | ||||||
|         targetSdkVersion 23 |         targetSdkVersion 24 | ||||||
|         versionCode 7 |         versionCode 7 | ||||||
|         versionName "1.0-beta7" |         versionName "1.0-beta7" | ||||||
|     } |     } | ||||||
|     signingConfigs { |  | ||||||
|         release { |  | ||||||
|             storeFile file(keyStoreFile) |  | ||||||
|             storePassword keyStorePassword |  | ||||||
|             keyAlias signingKeyAlias |  | ||||||
|             keyPassword signingKeyPassword |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     buildTypes { |     buildTypes { | ||||||
|         release { |         release { | ||||||
|             minifyEnabled false |             minifyEnabled false | ||||||
| @@ -29,12 +29,12 @@ android { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| ext.jabitVersion = '1.1.0-SNAPSHOT' | ext.jabitVersion = 'develop-SNAPSHOT' | ||||||
| dependencies { | dependencies { | ||||||
|     compile fileTree(dir: 'libs', include: ['*.jar']) |     compile fileTree(dir: 'libs', include: ['*.jar']) | ||||||
|     compile 'com.android.support:appcompat-v7:23.3.0' |     compile 'com.android.support:appcompat-v7:24.1.1' | ||||||
|     compile 'com.android.support:support-v4:23.3.0' |     compile 'com.android.support:support-v4:24.1.1' | ||||||
|     compile 'com.android.support:design:23.3.0' |     compile 'com.android.support:design:24.1.1' | ||||||
|  |  | ||||||
|     compile "ch.dissem.jabit:jabit-core:$jabitVersion" |     compile "ch.dissem.jabit:jabit-core:$jabitVersion" | ||||||
|     compile "ch.dissem.jabit:jabit-networking:$jabitVersion" |     compile "ch.dissem.jabit:jabit-networking:$jabitVersion" | ||||||
|   | |||||||
| @@ -0,0 +1,2 @@ | |||||||
|  | ALTER TABLE POW ADD COLUMN expiration_time BIGINT; | ||||||
|  | ALTER TABLE POW ADD COLUMN message_id BIGINT; | ||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | ALTER TABLE Message ADD COLUMN ack_data BINARY(32); | ||||||
|  | ALTER TABLE Message ADD COLUMN ttl      BIGINT NOT NULL DEFAULT 0; | ||||||
|  | ALTER TABLE Message ADD COLUMN retries  INT NOT NULL DEFAULT 0; | ||||||
|  | ALTER TABLE Message ADD COLUMN next_try BIGINT; | ||||||
							
								
								
									
										
											BIN
										
									
								
								app/src/main/ic_launcher-web.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 25 KiB | 
| @@ -36,7 +36,7 @@ import ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest; | |||||||
| import ch.dissem.bitmessage.ports.ProofOfWorkEngine; | import ch.dissem.bitmessage.ports.ProofOfWorkEngine; | ||||||
|  |  | ||||||
| import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.CALCULATE; | import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.CALCULATE; | ||||||
| import static ch.dissem.bitmessage.utils.Singleton.security; | import static ch.dissem.bitmessage.utils.Singleton.cryptography; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author Christian Basler |  * @author Christian Basler | ||||||
| @@ -78,7 +78,7 @@ public class ServerPowEngine implements ProofOfWorkEngine, InternalContext | |||||||
|                             (request); |                             (request); | ||||||
|                     cryptoMsg.signAndEncrypt( |                     cryptoMsg.signAndEncrypt( | ||||||
|                             identity, |                             identity, | ||||||
|                             security().createPublicKey(identity.getPublicDecryptionKey()) |                             cryptography().createPublicKey(identity.getPublicDecryptionKey()) | ||||||
|                     ); |                     ); | ||||||
|                     context.getNetworkHandler().send( |                     context.getNetworkHandler().send( | ||||||
|                             Preferences.getTrustedNode(ctx), Preferences.getTrustedNodePort(ctx), |                             Preferences.getTrustedNode(ctx), Preferences.getTrustedNodePort(ctx), | ||||||
|   | |||||||
| @@ -22,17 +22,6 @@ import android.database.Cursor; | |||||||
| import android.database.DatabaseUtils; | import android.database.DatabaseUtils; | ||||||
| import android.database.sqlite.SQLiteConstraintException; | import android.database.sqlite.SQLiteConstraintException; | ||||||
| import android.database.sqlite.SQLiteDatabase; | import android.database.sqlite.SQLiteDatabase; | ||||||
| import android.support.v4.database.DatabaseUtilsCompat; |  | ||||||
|  |  | ||||||
| import ch.dissem.apps.abit.R; |  | ||||||
| import ch.dissem.bitmessage.InternalContext; |  | ||||||
| import ch.dissem.bitmessage.entity.BitmessageAddress; |  | ||||||
| import ch.dissem.bitmessage.entity.Plaintext; |  | ||||||
| import ch.dissem.bitmessage.entity.valueobject.InventoryVector; |  | ||||||
| import ch.dissem.bitmessage.entity.valueobject.Label; |  | ||||||
| import ch.dissem.bitmessage.ports.MessageRepository; |  | ||||||
| import ch.dissem.bitmessage.utils.Encode; |  | ||||||
| import ch.dissem.bitmessage.utils.Strings; |  | ||||||
|  |  | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| @@ -43,12 +32,19 @@ import java.util.Collection; | |||||||
| import java.util.LinkedList; | import java.util.LinkedList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import static ch.dissem.apps.abit.repository.SqlHelper.join; | import ch.dissem.apps.abit.R; | ||||||
|  | import ch.dissem.bitmessage.entity.BitmessageAddress; | ||||||
|  | import ch.dissem.bitmessage.entity.Plaintext; | ||||||
|  | import ch.dissem.bitmessage.entity.valueobject.InventoryVector; | ||||||
|  | import ch.dissem.bitmessage.entity.valueobject.Label; | ||||||
|  | import ch.dissem.bitmessage.ports.AbstractMessageRepository; | ||||||
|  | import ch.dissem.bitmessage.ports.MessageRepository; | ||||||
|  | import ch.dissem.bitmessage.utils.Encode; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * {@link MessageRepository} implementation using the Android SQL API. |  * {@link MessageRepository} implementation using the Android SQL API. | ||||||
|  */ |  */ | ||||||
| public class AndroidMessageRepository implements MessageRepository, InternalContext.ContextHolder { | public class AndroidMessageRepository extends AbstractMessageRepository { | ||||||
|     private static final Logger LOG = LoggerFactory.getLogger(AndroidMessageRepository.class); |     private static final Logger LOG = LoggerFactory.getLogger(AndroidMessageRepository.class); | ||||||
|  |  | ||||||
|     private static final String TABLE_NAME = "Message"; |     private static final String TABLE_NAME = "Message"; | ||||||
| @@ -58,9 +54,13 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|     private static final String COLUMN_SENDER = "sender"; |     private static final String COLUMN_SENDER = "sender"; | ||||||
|     private static final String COLUMN_RECIPIENT = "recipient"; |     private static final String COLUMN_RECIPIENT = "recipient"; | ||||||
|     private static final String COLUMN_DATA = "data"; |     private static final String COLUMN_DATA = "data"; | ||||||
|  |     private static final String COLUMN_ACK_DATA = "ack_data"; | ||||||
|     private static final String COLUMN_SENT = "sent"; |     private static final String COLUMN_SENT = "sent"; | ||||||
|     private static final String COLUMN_RECEIVED = "received"; |     private static final String COLUMN_RECEIVED = "received"; | ||||||
|     private static final String COLUMN_STATUS = "status"; |     private static final String COLUMN_STATUS = "status"; | ||||||
|  |     private static final String COLUMN_TTL = "ttl"; | ||||||
|  |     private static final String COLUMN_RETRIES = "retries"; | ||||||
|  |     private static final String COLUMN_NEXT_TRY = "next_try"; | ||||||
|     private static final String COLUMN_INITIAL_HASH = "initial_hash"; |     private static final String COLUMN_INITIAL_HASH = "initial_hash"; | ||||||
|  |  | ||||||
|     private static final String JOIN_TABLE_NAME = "Message_Label"; |     private static final String JOIN_TABLE_NAME = "Message_Label"; | ||||||
| @@ -74,27 +74,11 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|     private static final String LBL_COLUMN_COLOR = "color"; |     private static final String LBL_COLUMN_COLOR = "color"; | ||||||
|     private static final String LBL_COLUMN_ORDER = "ord"; |     private static final String LBL_COLUMN_ORDER = "ord"; | ||||||
|     private final SqlHelper sql; |     private final SqlHelper sql; | ||||||
|     private final Context ctx; |     private final Context context; | ||||||
|     private InternalContext bmc; |  | ||||||
|  |  | ||||||
|     public AndroidMessageRepository(SqlHelper sql, Context ctx) { |     public AndroidMessageRepository(SqlHelper sql, Context ctx) { | ||||||
|         this.sql = sql; |         this.sql = sql; | ||||||
|         this.ctx = ctx; |         this.context = ctx; | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void setContext(InternalContext context) { |  | ||||||
|         bmc = context; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Label> getLabels() { |  | ||||||
|         return findLabels(null); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Label> getLabels(Label.Type... types) { |  | ||||||
|         return findLabels("type IN (" + join(types) + ")"); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public List<Label> findLabels(String where) { |     public List<Label> findLabels(String where) { | ||||||
| @@ -134,22 +118,22 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|         } else { |         } else { | ||||||
|             switch (type) { |             switch (type) { | ||||||
|                 case INBOX: |                 case INBOX: | ||||||
|                     text = ctx.getString(R.string.inbox); |                     text = context.getString(R.string.inbox); | ||||||
|                     break; |                     break; | ||||||
|                 case DRAFT: |                 case DRAFT: | ||||||
|                     text = ctx.getString(R.string.draft); |                     text = context.getString(R.string.draft); | ||||||
|                     break; |                     break; | ||||||
|                 case SENT: |                 case SENT: | ||||||
|                     text = ctx.getString(R.string.sent); |                     text = context.getString(R.string.sent); | ||||||
|                     break; |                     break; | ||||||
|                 case UNREAD: |                 case UNREAD: | ||||||
|                     text = ctx.getString(R.string.unread); |                     text = context.getString(R.string.unread); | ||||||
|                     break; |                     break; | ||||||
|                 case TRASH: |                 case TRASH: | ||||||
|                     text = ctx.getString(R.string.trash); |                     text = context.getString(R.string.trash); | ||||||
|                     break; |                     break; | ||||||
|                 case BROADCAST: |                 case BROADCAST: | ||||||
|                     text = ctx.getString(R.string.broadcasts); |                     text = context.getString(R.string.broadcasts); | ||||||
|                     break; |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     text = c.getString(c.getColumnIndex(LBL_COLUMN_LABEL)); |                     text = c.getString(c.getColumnIndex(LBL_COLUMN_LABEL)); | ||||||
| @@ -179,47 +163,7 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     protected List<Plaintext> find(String where) { | ||||||
|     public Plaintext getMessage(byte[] initialHash) { |  | ||||||
|         List<Plaintext> results = find("initial_hash=X'" + Strings.hex(initialHash) + "'"); |  | ||||||
|         switch (results.size()) { |  | ||||||
|             case 0: |  | ||||||
|                 return null; |  | ||||||
|             case 1: |  | ||||||
|                 return results.get(0); |  | ||||||
|             default: |  | ||||||
|                 throw new RuntimeException("This shouldn't happen, found " + results.size() + |  | ||||||
|                         " messages, one or none was expected"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Plaintext> findMessages(Label label) { |  | ||||||
|         if (label != null) { |  | ||||||
|             return find("id IN (SELECT message_id FROM Message_Label WHERE label_id=" + label |  | ||||||
|                     .getId() + ")"); |  | ||||||
|         } else { |  | ||||||
|             return find("id NOT IN (SELECT message_id FROM Message_Label)"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Plaintext> findMessages(Plaintext.Status status, BitmessageAddress recipient) { |  | ||||||
|         return find("status='" + status.name() + "' AND recipient='" + recipient.getAddress() + |  | ||||||
|                 "'"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Plaintext> findMessages(BitmessageAddress sender) { |  | ||||||
|         return find("sender=" + sender.getAddress()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<Plaintext> findMessages(Plaintext.Status status) { |  | ||||||
|         return find("status='" + status.name() + "'"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private List<Plaintext> find(String where) { |  | ||||||
|         List<Plaintext> result = new LinkedList<>(); |         List<Plaintext> result = new LinkedList<>(); | ||||||
|  |  | ||||||
|         // Define a projection that specifies which columns from the database |         // Define a projection that specifies which columns from the database | ||||||
| @@ -231,9 +175,13 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|                 COLUMN_SENDER, |                 COLUMN_SENDER, | ||||||
|                 COLUMN_RECIPIENT, |                 COLUMN_RECIPIENT, | ||||||
|                 COLUMN_DATA, |                 COLUMN_DATA, | ||||||
|  |                 COLUMN_ACK_DATA, | ||||||
|                 COLUMN_SENT, |                 COLUMN_SENT, | ||||||
|                 COLUMN_RECEIVED, |                 COLUMN_RECEIVED, | ||||||
|                 COLUMN_STATUS |                 COLUMN_STATUS, | ||||||
|  |                 COLUMN_TTL, | ||||||
|  |                 COLUMN_RETRIES, | ||||||
|  |                 COLUMN_NEXT_TRY | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         SQLiteDatabase db = sql.getReadableDatabase(); |         SQLiteDatabase db = sql.getReadableDatabase(); | ||||||
| @@ -254,14 +202,21 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|                 long id = c.getLong(c.getColumnIndex(COLUMN_ID)); |                 long id = c.getLong(c.getColumnIndex(COLUMN_ID)); | ||||||
|                 builder.id(id); |                 builder.id(id); | ||||||
|                 builder.IV(new InventoryVector(iv)); |                 builder.IV(new InventoryVector(iv)); | ||||||
|                 builder.from(bmc.getAddressRepository().getAddress(c.getString(c.getColumnIndex |                 builder.from(ctx.getAddressRepository().getAddress(c.getString(c.getColumnIndex | ||||||
|                         (COLUMN_SENDER)))); |                         (COLUMN_SENDER)))); | ||||||
|                 builder.to(bmc.getAddressRepository().getAddress(c.getString(c.getColumnIndex |                 builder.to(ctx.getAddressRepository().getAddress(c.getString(c.getColumnIndex | ||||||
|                         (COLUMN_RECIPIENT)))); |                         (COLUMN_RECIPIENT)))); | ||||||
|  |                 builder.ackData(c.getBlob(c.getColumnIndex(COLUMN_ACK_DATA))); | ||||||
|                 builder.sent(c.getLong(c.getColumnIndex(COLUMN_SENT))); |                 builder.sent(c.getLong(c.getColumnIndex(COLUMN_SENT))); | ||||||
|                 builder.received(c.getLong(c.getColumnIndex(COLUMN_RECEIVED))); |                 builder.received(c.getLong(c.getColumnIndex(COLUMN_RECEIVED))); | ||||||
|                 builder.status(Plaintext.Status.valueOf(c.getString(c.getColumnIndex |                 builder.status(Plaintext.Status.valueOf(c.getString(c.getColumnIndex | ||||||
|                         (COLUMN_STATUS)))); |                         (COLUMN_STATUS)))); | ||||||
|  |                 builder.ttl(c.getLong(c.getColumnIndex(COLUMN_TTL))); | ||||||
|  |                 builder.retries(c.getInt(c.getColumnIndex(COLUMN_RETRIES))); | ||||||
|  |                 int nextTryColumn = c.getColumnIndex(COLUMN_NEXT_TRY); | ||||||
|  |                 if (!c.isNull(nextTryColumn)) { | ||||||
|  |                     builder.nextTry(c.getLong(nextTryColumn)); | ||||||
|  |                 } | ||||||
|                 builder.labels(findLabels(id)); |                 builder.labels(findLabels(id)); | ||||||
|                 result.add(builder.build()); |                 result.add(builder.build()); | ||||||
|                 c.moveToNext(); |                 c.moveToNext(); | ||||||
| @@ -284,13 +239,13 @@ public class AndroidMessageRepository implements MessageRepository, InternalCont | |||||||
|  |  | ||||||
|             // save from address if necessary |             // save from address if necessary | ||||||
|             if (message.getId() == null) { |             if (message.getId() == null) { | ||||||
|                 BitmessageAddress savedAddress = bmc.getAddressRepository().getAddress(message |                 BitmessageAddress savedAddress = ctx.getAddressRepository().getAddress(message | ||||||
|                         .getFrom().getAddress()); |                         .getFrom().getAddress()); | ||||||
|                 if (savedAddress == null || savedAddress.getPrivateKey() == null) { |                 if (savedAddress == null || savedAddress.getPrivateKey() == null) { | ||||||
|                     if (savedAddress != null && savedAddress.getAlias() != null) { |                     if (savedAddress != null && savedAddress.getAlias() != null) { | ||||||
|                         message.getFrom().setAlias(savedAddress.getAlias()); |                         message.getFrom().setAlias(savedAddress.getAlias()); | ||||||
|                     } |                     } | ||||||
|                     bmc.getAddressRepository().save(message.getFrom()); |                     ctx.getAddressRepository().save(message.getFrom()); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ import ch.dissem.bitmessage.ports.ProofOfWorkRepository; | |||||||
| import ch.dissem.bitmessage.utils.Encode; | import ch.dissem.bitmessage.utils.Encode; | ||||||
| import ch.dissem.bitmessage.utils.Strings; | import ch.dissem.bitmessage.utils.Strings; | ||||||
|  |  | ||||||
| import static ch.dissem.bitmessage.utils.Singleton.security; | import static ch.dissem.bitmessage.utils.Singleton.cryptography; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author Christian Basler |  * @author Christian Basler | ||||||
| @@ -49,6 +49,8 @@ public class AndroidProofOfWorkRepository implements ProofOfWorkRepository { | |||||||
|     private static final String COLUMN_VERSION = "version"; |     private static final String COLUMN_VERSION = "version"; | ||||||
|     private static final String COLUMN_NONCE_TRIALS_PER_BYTE = "nonce_trials_per_byte"; |     private static final String COLUMN_NONCE_TRIALS_PER_BYTE = "nonce_trials_per_byte"; | ||||||
|     private static final String COLUMN_EXTRA_BYTES = "extra_bytes"; |     private static final String COLUMN_EXTRA_BYTES = "extra_bytes"; | ||||||
|  |     private static final String COLUMN_EXPIRATION_TIME = "expiration_time"; | ||||||
|  |     private static final String COLUMN_MESSAGE_ID = "message_id"; | ||||||
|  |  | ||||||
|     private final SqlHelper sql; |     private final SqlHelper sql; | ||||||
|  |  | ||||||
| @@ -114,16 +116,20 @@ public class AndroidProofOfWorkRepository implements ProofOfWorkRepository { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void putObject(ObjectMessage object, long nonceTrialsPerByte, long extraBytes) { |     public void putObject(Item item) { | ||||||
|         try { |         try { | ||||||
|             SQLiteDatabase db = sql.getWritableDatabase(); |             SQLiteDatabase db = sql.getWritableDatabase(); | ||||||
|             // Create a new map of values, where column names are the keys |             // Create a new map of values, where column names are the keys | ||||||
|             ContentValues values = new ContentValues(); |             ContentValues values = new ContentValues(); | ||||||
|             values.put(COLUMN_INITIAL_HASH, security().getInitialHash(object)); |             values.put(COLUMN_INITIAL_HASH, cryptography().getInitialHash(item.object)); | ||||||
|             values.put(COLUMN_DATA, Encode.bytes(object)); |             values.put(COLUMN_DATA, Encode.bytes(item.object)); | ||||||
|             values.put(COLUMN_VERSION, object.getVersion()); |             values.put(COLUMN_VERSION, item.object.getVersion()); | ||||||
|             values.put(COLUMN_NONCE_TRIALS_PER_BYTE, nonceTrialsPerByte); |             values.put(COLUMN_NONCE_TRIALS_PER_BYTE, item.nonceTrialsPerByte); | ||||||
|             values.put(COLUMN_EXTRA_BYTES, extraBytes); |             values.put(COLUMN_EXTRA_BYTES, item.extraBytes); | ||||||
|  |             if (item.message != null) { | ||||||
|  |                 values.put(COLUMN_EXPIRATION_TIME, item.expirationTime); | ||||||
|  |                 values.put(COLUMN_MESSAGE_ID, (Long) item.message.getId()); | ||||||
|  |             } | ||||||
|  |  | ||||||
|             db.insertOrThrow(TABLE_NAME, null, values); |             db.insertOrThrow(TABLE_NAME, null, values); | ||||||
|         } catch (SQLiteConstraintException e) { |         } catch (SQLiteConstraintException e) { | ||||||
| @@ -133,6 +139,11 @@ public class AndroidProofOfWorkRepository implements ProofOfWorkRepository { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void putObject(ObjectMessage object, long nonceTrialsPerByte, long extraBytes) { | ||||||
|  |         putObject(new Item(object, nonceTrialsPerByte, extraBytes)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void removeObject(byte[] initialHash) { |     public void removeObject(byte[] initialHash) { | ||||||
|         SQLiteDatabase db = sql.getWritableDatabase(); |         SQLiteDatabase db = sql.getWritableDatabase(); | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ import ch.dissem.apps.abit.util.Assets; | |||||||
|  */ |  */ | ||||||
| public class SqlHelper extends SQLiteOpenHelper { | public class SqlHelper extends SQLiteOpenHelper { | ||||||
|     // If you change the database schema, you must increment the database version. |     // If you change the database schema, you must increment the database version. | ||||||
|     public static final int DATABASE_VERSION = 3; |     public static final int DATABASE_VERSION = 4; | ||||||
|     public static final String DATABASE_NAME = "jabit.db"; |     public static final String DATABASE_NAME = "jabit.db"; | ||||||
|  |  | ||||||
|     protected final Context ctx; |     protected final Context ctx; | ||||||
| @@ -53,6 +53,9 @@ public class SqlHelper extends SQLiteOpenHelper { | |||||||
|                 executeMigration(db, "V2.1__Create_table_POW"); |                 executeMigration(db, "V2.1__Create_table_POW"); | ||||||
|             case 2: |             case 2: | ||||||
|                 executeMigration(db, "V3.0__Update_table_address"); |                 executeMigration(db, "V3.0__Update_table_address"); | ||||||
|  |             case 3: | ||||||
|  |                 executeMigration(db, "V3.1__Update_table_POW"); | ||||||
|  |                 executeMigration(db, "V3.2__Update_table_message"); | ||||||
|             default: |             default: | ||||||
|                 // Nothing to do. Let's assume we won't upgrade from a version that's newer than DATABASE_VERSION. |                 // Nothing to do. Let's assume we won't upgrade from a version that's newer than DATABASE_VERSION. | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ import static ch.dissem.apps.abit.synchronization.Authenticator.ACCOUNT_SYNC; | |||||||
| import static ch.dissem.apps.abit.synchronization.StubProvider.AUTHORITY; | import static ch.dissem.apps.abit.synchronization.StubProvider.AUTHORITY; | ||||||
| import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.CALCULATE; | import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.CALCULATE; | ||||||
| import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.COMPLETE; | import static ch.dissem.bitmessage.extensions.pow.ProofOfWorkRequest.Request.COMPLETE; | ||||||
| import static ch.dissem.bitmessage.utils.Singleton.security; | import static ch.dissem.bitmessage.utils.Singleton.cryptography; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Sync Adapter to synchronize with the Bitmessage network - fetches |  * Sync Adapter to synchronize with the Bitmessage network - fetches | ||||||
| @@ -107,13 +107,13 @@ public class SyncAdapter extends AbstractThreadedSyncAdapter { | |||||||
|         try { |         try { | ||||||
|             BitmessageAddress identity = Singleton.getIdentity(getContext()); |             BitmessageAddress identity = Singleton.getIdentity(getContext()); | ||||||
|             byte[] privateKey = identity.getPrivateKey().getPrivateEncryptionKey(); |             byte[] privateKey = identity.getPrivateKey().getPrivateEncryptionKey(); | ||||||
|             byte[] signingKey = security().createPublicKey(identity.getPublicDecryptionKey()); |             byte[] signingKey = cryptography().createPublicKey(identity.getPublicDecryptionKey()); | ||||||
|             ProofOfWorkRequest.Reader reader = new ProofOfWorkRequest.Reader(identity); |             ProofOfWorkRequest.Reader reader = new ProofOfWorkRequest.Reader(identity); | ||||||
|             ProofOfWorkRepository powRepo = Singleton.getProofOfWorkRepository(getContext()); |             ProofOfWorkRepository powRepo = Singleton.getProofOfWorkRepository(getContext()); | ||||||
|             List<byte[]> items = powRepo.getItems(); |             List<byte[]> items = powRepo.getItems(); | ||||||
|             for (byte[] initialHash : items) { |             for (byte[] initialHash : items) { | ||||||
|                 ProofOfWorkRepository.Item item = powRepo.getItem(initialHash); |                 ProofOfWorkRepository.Item item = powRepo.getItem(initialHash); | ||||||
|                 byte[] target = security().getProofOfWorkTarget(item.object, item |                 byte[] target = cryptography().getProofOfWorkTarget(item.object, item | ||||||
|                         .nonceTrialsPerByte, item.extraBytes); |                         .nonceTrialsPerByte, item.extraBytes); | ||||||
|                 CryptoCustomMessage<ProofOfWorkRequest> cryptoMsg = new CryptoCustomMessage<>( |                 CryptoCustomMessage<ProofOfWorkRequest> cryptoMsg = new CryptoCustomMessage<>( | ||||||
|                         new ProofOfWorkRequest(identity, initialHash, CALCULATE, target)); |                         new ProofOfWorkRequest(identity, initialHash, CALCULATE, target)); | ||||||
|   | |||||||
| Before Width: | Height: | Size: 3.3 KiB After Width: | Height: | Size: 2.2 KiB | 
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 1.4 KiB | 
| Before Width: | Height: | Size: 4.7 KiB After Width: | Height: | Size: 3.0 KiB | 
| Before Width: | Height: | Size: 7.5 KiB After Width: | Height: | Size: 5.1 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.3 KiB | 
| @@ -9,7 +9,7 @@ buildscript { | |||||||
|         jcenter() |         jcenter() | ||||||
|     } |     } | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'com.android.tools.build:gradle:2.0.0' |         classpath 'com.android.tools.build:gradle:2.1.2' | ||||||
|  |  | ||||||
|         // NOTE: Do not place your application dependencies here; they belong |         // NOTE: Do not place your application dependencies here; they belong | ||||||
|         // in the individual module build.gradle files |         // in the individual module build.gradle files | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
| # Specifies the JVM arguments used for the daemon process. | # Specifies the JVM arguments used for the daemon process. | ||||||
| # The setting is particularly useful for tweaking memory settings. | # The setting is particularly useful for tweaking memory settings. | ||||||
| # Default value: -Xmx10248m -XX:MaxPermSize=256m | # Default value: -Xmx10248m -XX:MaxPermSize=256m | ||||||
| # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 | org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 | ||||||
|  |  | ||||||
| # When configured, Gradle will run in incubating parallel mode. | # When configured, Gradle will run in incubating parallel mode. | ||||||
| # This option should only be used with decoupled projects. More details, visit | # This option should only be used with decoupled projects. More details, visit | ||||||
| @@ -20,10 +20,18 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # Signing and encryption settings |  | ||||||
| # Don't change those parameters - override those properties in the | # Don't change those parameters - override those properties in the | ||||||
| # gradle.properties file in your home directory instead | # gradle.properties file in your home directory instead | ||||||
| keyStoreFile= | # Create a directory containing the signing configs and keystores | ||||||
| keyStorePassword= | project.configs= | ||||||
| signingKeyAlias= | # The signing config should be called 'Abit.gradle' and look like this: | ||||||
| signingKeyPassword= | #    android { | ||||||
|  | #      signingConfigs { | ||||||
|  | #        release { | ||||||
|  | #          storeFile file("C:/Path/To/Keystores/abit.jks") | ||||||
|  | #          storePassword "****************" | ||||||
|  | #          keyAlias "Abit" | ||||||
|  | #          keyPassword "****************" | ||||||
|  | #        } | ||||||
|  | #      } | ||||||
|  | #    } | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
							
								
								
									
										4
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,6 +1,6 @@ | |||||||
| #Mon Apr 11 14:09:13 CEST 2016 | #Fri Aug 12 22:10:25 CEST 2016 | ||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-all.zip | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -6,12 +6,30 @@ | |||||||
| ## | ## | ||||||
| ############################################################################## | ############################################################################## | ||||||
|  |  | ||||||
| # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | # Attempt to set APP_HOME | ||||||
| DEFAULT_JVM_OPTS="" | # Resolve links: $0 may be a link | ||||||
|  | PRG="$0" | ||||||
|  | # Need this for relative symlinks. | ||||||
|  | while [ -h "$PRG" ] ; do | ||||||
|  |     ls=`ls -ld "$PRG"` | ||||||
|  |     link=`expr "$ls" : '.*-> \(.*\)$'` | ||||||
|  |     if expr "$link" : '/.*' > /dev/null; then | ||||||
|  |         PRG="$link" | ||||||
|  |     else | ||||||
|  |         PRG=`dirname "$PRG"`"/$link" | ||||||
|  |     fi | ||||||
|  | done | ||||||
|  | SAVED="`pwd`" | ||||||
|  | cd "`dirname \"$PRG\"`/" >/dev/null | ||||||
|  | APP_HOME="`pwd -P`" | ||||||
|  | cd "$SAVED" >/dev/null | ||||||
|  |  | ||||||
| APP_NAME="Gradle" | APP_NAME="Gradle" | ||||||
| APP_BASE_NAME=`basename "$0"` | APP_BASE_NAME=`basename "$0"` | ||||||
|  |  | ||||||
|  | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | DEFAULT_JVM_OPTS="" | ||||||
|  |  | ||||||
| # Use the maximum available, or set MAX_FD != -1 to use that value. | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
| MAX_FD="maximum" | MAX_FD="maximum" | ||||||
|  |  | ||||||
| @@ -30,6 +48,7 @@ die ( ) { | |||||||
| cygwin=false | cygwin=false | ||||||
| msys=false | msys=false | ||||||
| darwin=false | darwin=false | ||||||
|  | nonstop=false | ||||||
| case "`uname`" in | case "`uname`" in | ||||||
|   CYGWIN* ) |   CYGWIN* ) | ||||||
|     cygwin=true |     cygwin=true | ||||||
| @@ -40,31 +59,11 @@ case "`uname`" in | |||||||
|   MINGW* ) |   MINGW* ) | ||||||
|     msys=true |     msys=true | ||||||
|     ;; |     ;; | ||||||
|  |   NONSTOP* ) | ||||||
|  |     nonstop=true | ||||||
|  |     ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
| # For Cygwin, ensure paths are in UNIX format before anything is touched. |  | ||||||
| if $cygwin ; then |  | ||||||
|     [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| # Attempt to set APP_HOME |  | ||||||
| # Resolve links: $0 may be a link |  | ||||||
| PRG="$0" |  | ||||||
| # Need this for relative symlinks. |  | ||||||
| while [ -h "$PRG" ] ; do |  | ||||||
|     ls=`ls -ld "$PRG"` |  | ||||||
|     link=`expr "$ls" : '.*-> \(.*\)$'` |  | ||||||
|     if expr "$link" : '/.*' > /dev/null; then |  | ||||||
|         PRG="$link" |  | ||||||
|     else |  | ||||||
|         PRG=`dirname "$PRG"`"/$link" |  | ||||||
|     fi |  | ||||||
| done |  | ||||||
| SAVED="`pwd`" |  | ||||||
| cd "`dirname \"$PRG\"`/" >&- |  | ||||||
| APP_HOME="`pwd -P`" |  | ||||||
| cd "$SAVED" >&- |  | ||||||
|  |  | ||||||
| CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
| # Determine the Java command to use to start the JVM. | # Determine the Java command to use to start the JVM. | ||||||
| @@ -90,7 +89,7 @@ location of your Java installation." | |||||||
| fi | fi | ||||||
|  |  | ||||||
| # Increase the maximum file descriptors if we can. | # Increase the maximum file descriptors if we can. | ||||||
| if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | ||||||
|     MAX_FD_LIMIT=`ulimit -H -n` |     MAX_FD_LIMIT=`ulimit -H -n` | ||||||
|     if [ $? -eq 0 ] ; then |     if [ $? -eq 0 ] ; then | ||||||
|         if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then |         if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||||||
| @@ -114,6 +113,7 @@ fi | |||||||
| if $cygwin ; then | if $cygwin ; then | ||||||
|     APP_HOME=`cygpath --path --mixed "$APP_HOME"` |     APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||||||
|     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` |     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||||||
|  |     JAVACMD=`cygpath --unix "$JAVACMD"` | ||||||
|  |  | ||||||
|     # We build the pattern for arguments to be converted via cygpath |     # We build the pattern for arguments to be converted via cygpath | ||||||
|     ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` |     ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -8,14 +8,14 @@ | |||||||
| @rem Set local scope for the variables with windows NT shell | @rem Set local scope for the variables with windows NT shell | ||||||
| if "%OS%"=="Windows_NT" setlocal | if "%OS%"=="Windows_NT" setlocal | ||||||
|  |  | ||||||
| @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |  | ||||||
| set DEFAULT_JVM_OPTS= |  | ||||||
|  |  | ||||||
| set DIRNAME=%~dp0 | set DIRNAME=%~dp0 | ||||||
| if "%DIRNAME%" == "" set DIRNAME=. | if "%DIRNAME%" == "" set DIRNAME=. | ||||||
| set APP_BASE_NAME=%~n0 | set APP_BASE_NAME=%~n0 | ||||||
| set APP_HOME=%DIRNAME% | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
|  | set DEFAULT_JVM_OPTS= | ||||||
|  |  | ||||||
| @rem Find java.exe | @rem Find java.exe | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
| @@ -46,7 +46,7 @@ echo location of your Java installation. | |||||||
| goto fail | goto fail | ||||||
|  |  | ||||||
| :init | :init | ||||||
| @rem Get command-line arguments, handling Windowz variants | @rem Get command-line arguments, handling Windows variants | ||||||
|  |  | ||||||
| if not "%OS%" == "Windows_NT" goto win9xME_args | if not "%OS%" == "Windows_NT" goto win9xME_args | ||||||
| if "%@eval[2+2]" == "4" goto 4NT_args | if "%@eval[2+2]" == "4" goto 4NT_args | ||||||
|   | |||||||
							
								
								
									
										404
									
								
								store/icon.svg
									
									
									
									
									
								
							
							
						
						| @@ -7,20 +7,356 @@ | |||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|    xmlns="http://www.w3.org/2000/svg" |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:xlink="http://www.w3.org/1999/xlink" | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|    width="512" |    width="256" | ||||||
|    height="512" |    height="256" | ||||||
|    viewBox="0 0 512.00001 512.00001" |    viewBox="0 0 256 256" | ||||||
|    id="svg2" |    id="svg2" | ||||||
|    version="1.1" |    version="1.1" | ||||||
|    inkscape:version="0.91 r13725" |    inkscape:version="0.91 r13725" | ||||||
|    sodipodi:docname="icon.svg" |    sodipodi:docname="icon.svg"> | ||||||
|    inkscape:export-filename="C:\Users\chrig\Documents\Projekte\Abit\store\icon.png" |  | ||||||
|    inkscape:export-xdpi="90" |  | ||||||
|    inkscape:export-ydpi="90"> |  | ||||||
|   <defs |   <defs | ||||||
|      id="defs4" /> |      id="defs4"> | ||||||
|  |     <linearGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        id="linearGradient4475"> | ||||||
|  |       <stop | ||||||
|  |          style="stop-color:#000000;stop-opacity:1;" | ||||||
|  |          offset="0" | ||||||
|  |          id="stop4477" /> | ||||||
|  |       <stop | ||||||
|  |          style="stop-color:#000000;stop-opacity:0;" | ||||||
|  |          offset="1" | ||||||
|  |          id="stop4479" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <filter | ||||||
|  |        id="filter4284" | ||||||
|  |        inkscape:label="z-depth1" | ||||||
|  |        style="color-interpolation-filters:sRGB"> | ||||||
|  |       <feFlood | ||||||
|  |          id="feFlood4286" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.12" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4288" | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in2="SourceGraphic" | ||||||
|  |          in="flood" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          id="feGaussianBlur4290" | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="1.5" /> | ||||||
|  |       <feOffset | ||||||
|  |          id="feOffset4292" | ||||||
|  |          result="offset" | ||||||
|  |          dy="1" | ||||||
|  |          dx="0" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4294" | ||||||
|  |          result="fbSourceGraphic" | ||||||
|  |          operator="over" | ||||||
|  |          in2="offset" | ||||||
|  |          in="SourceGraphic" /> | ||||||
|  |       <feColorMatrix | ||||||
|  |          id="feColorMatrix4332" | ||||||
|  |          values="0 0 0 -1 0 0 0 0 -1 0 0 0 0 -1 0 0 0 0 1 0" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="fbSourceGraphicAlpha" /> | ||||||
|  |       <feFlood | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.24" | ||||||
|  |          id="feFlood4334" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in="flood" | ||||||
|  |          in2="fbSourceGraphic" | ||||||
|  |          id="feComposite4336" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="1" | ||||||
|  |          id="feGaussianBlur4338" /> | ||||||
|  |       <feOffset | ||||||
|  |          result="offset" | ||||||
|  |          dy="1" | ||||||
|  |          dx="0" | ||||||
|  |          id="feOffset4340" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite2" | ||||||
|  |          operator="over" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          in2="offset" | ||||||
|  |          id="feComposite4342" /> | ||||||
|  |     </filter> | ||||||
|  |     <filter | ||||||
|  |        id="filter4346" | ||||||
|  |        inkscape:label="z-depth2" | ||||||
|  |        style="color-interpolation-filters:sRGB"> | ||||||
|  |       <feFlood | ||||||
|  |          id="feFlood4348" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.16" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4350" | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in2="SourceGraphic" | ||||||
|  |          in="flood" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          id="feGaussianBlur4352" | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="3" /> | ||||||
|  |       <feOffset | ||||||
|  |          id="feOffset4354" | ||||||
|  |          result="offset" | ||||||
|  |          dy="3" | ||||||
|  |          dx="0" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4356" | ||||||
|  |          result="fbSourceGraphic" | ||||||
|  |          operator="over" | ||||||
|  |          in2="offset" | ||||||
|  |          in="SourceGraphic" /> | ||||||
|  |       <feColorMatrix | ||||||
|  |          id="feColorMatrix4358" | ||||||
|  |          values="0 0 0 -1 0 0 0 0 -1 0 0 0 0 -1 0 0 0 0 1 0" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="fbSourceGraphicAlpha" /> | ||||||
|  |       <feFlood | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.23" | ||||||
|  |          id="feFlood4360" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in="flood" | ||||||
|  |          in2="fbSourceGraphic" | ||||||
|  |          id="feComposite4362" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="3" | ||||||
|  |          id="feGaussianBlur4364" /> | ||||||
|  |       <feOffset | ||||||
|  |          result="offset" | ||||||
|  |          dy="3" | ||||||
|  |          dx="0" | ||||||
|  |          id="feOffset4366" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite2" | ||||||
|  |          operator="over" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          in2="offset" | ||||||
|  |          id="feComposite4368" /> | ||||||
|  |     </filter> | ||||||
|  |     <filter | ||||||
|  |        id="filter4375" | ||||||
|  |        inkscape:label="z-depth3" | ||||||
|  |        style="color-interpolation-filters:sRGB"> | ||||||
|  |       <feFlood | ||||||
|  |          id="feFlood4377" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.19" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4379" | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in2="SourceGraphic" | ||||||
|  |          in="flood" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          id="feGaussianBlur4381" | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="10" /> | ||||||
|  |       <feOffset | ||||||
|  |          id="feOffset4383" | ||||||
|  |          result="offset" | ||||||
|  |          dy="10" | ||||||
|  |          dx="0" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4385" | ||||||
|  |          result="fbSourceGraphic" | ||||||
|  |          operator="over" | ||||||
|  |          in2="offset" | ||||||
|  |          in="SourceGraphic" /> | ||||||
|  |       <feColorMatrix | ||||||
|  |          id="feColorMatrix4387" | ||||||
|  |          values="0 0 0 -1 0 0 0 0 -1 0 0 0 0 -1 0 0 0 0 1 0" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="fbSourceGraphicAlpha" /> | ||||||
|  |       <feFlood | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.23" | ||||||
|  |          id="feFlood4389" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in="flood" | ||||||
|  |          in2="fbSourceGraphic" | ||||||
|  |          id="feComposite4391" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="3" | ||||||
|  |          id="feGaussianBlur4393" /> | ||||||
|  |       <feOffset | ||||||
|  |          result="offset" | ||||||
|  |          dy="6" | ||||||
|  |          dx="0" | ||||||
|  |          id="feOffset4395" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite2" | ||||||
|  |          operator="over" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          in2="offset" | ||||||
|  |          id="feComposite4397" /> | ||||||
|  |     </filter> | ||||||
|  |     <filter | ||||||
|  |        id="filter4419" | ||||||
|  |        inkscape:label="z-depth4" | ||||||
|  |        style="color-interpolation-filters:sRGB"> | ||||||
|  |       <feFlood | ||||||
|  |          id="feFlood4421" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.25" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4423" | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in2="SourceGraphic" | ||||||
|  |          in="flood" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          id="feGaussianBlur4425" | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="14" /> | ||||||
|  |       <feOffset | ||||||
|  |          id="feOffset4427" | ||||||
|  |          result="offset" | ||||||
|  |          dy="14" | ||||||
|  |          dx="0" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4429" | ||||||
|  |          result="fbSourceGraphic" | ||||||
|  |          operator="over" | ||||||
|  |          in2="offset" | ||||||
|  |          in="SourceGraphic" /> | ||||||
|  |       <feColorMatrix | ||||||
|  |          id="feColorMatrix4431" | ||||||
|  |          values="0 0 0 -1 0 0 0 0 -1 0 0 0 0 -1 0 0 0 0 1 0" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="fbSourceGraphicAlpha" /> | ||||||
|  |       <feFlood | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.22" | ||||||
|  |          id="feFlood4433" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in="flood" | ||||||
|  |          in2="fbSourceGraphic" | ||||||
|  |          id="feComposite4435" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="5" | ||||||
|  |          id="feGaussianBlur4437" /> | ||||||
|  |       <feOffset | ||||||
|  |          result="offset" | ||||||
|  |          dy="10" | ||||||
|  |          dx="0" | ||||||
|  |          id="feOffset4439" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite2" | ||||||
|  |          operator="over" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          in2="offset" | ||||||
|  |          id="feComposite4441" /> | ||||||
|  |     </filter> | ||||||
|  |     <filter | ||||||
|  |        id="filter4449" | ||||||
|  |        inkscape:label="z-depth5" | ||||||
|  |        style="color-interpolation-filters:sRGB"> | ||||||
|  |       <feFlood | ||||||
|  |          id="feFlood4451" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.3" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4453" | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in2="SourceGraphic" | ||||||
|  |          in="flood" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          id="feGaussianBlur4455" | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="19" /> | ||||||
|  |       <feOffset | ||||||
|  |          id="feOffset4457" | ||||||
|  |          result="offset" | ||||||
|  |          dy="19" | ||||||
|  |          dx="0" /> | ||||||
|  |       <feComposite | ||||||
|  |          id="feComposite4459" | ||||||
|  |          result="fbSourceGraphic" | ||||||
|  |          operator="over" | ||||||
|  |          in2="offset" | ||||||
|  |          in="SourceGraphic" /> | ||||||
|  |       <feColorMatrix | ||||||
|  |          id="feColorMatrix4461" | ||||||
|  |          values="0 0 0 -1 0 0 0 0 -1 0 0 0 0 -1 0 0 0 0 1 0" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="fbSourceGraphicAlpha" /> | ||||||
|  |       <feFlood | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          result="flood" | ||||||
|  |          flood-color="rgb(0,0,0)" | ||||||
|  |          flood-opacity="0.22" | ||||||
|  |          id="feFlood4463" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite1" | ||||||
|  |          operator="in" | ||||||
|  |          in="flood" | ||||||
|  |          in2="fbSourceGraphic" | ||||||
|  |          id="feComposite4465" /> | ||||||
|  |       <feGaussianBlur | ||||||
|  |          result="blur" | ||||||
|  |          stdDeviation="6" | ||||||
|  |          id="feGaussianBlur4467" /> | ||||||
|  |       <feOffset | ||||||
|  |          result="offset" | ||||||
|  |          dy="15" | ||||||
|  |          dx="0" | ||||||
|  |          id="feOffset4469" /> | ||||||
|  |       <feComposite | ||||||
|  |          result="composite2" | ||||||
|  |          operator="over" | ||||||
|  |          in="fbSourceGraphic" | ||||||
|  |          in2="offset" | ||||||
|  |          id="feComposite4471" /> | ||||||
|  |     </filter> | ||||||
|  |     <linearGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient4475" | ||||||
|  |        id="linearGradient4481" | ||||||
|  |        x1="-96.75" | ||||||
|  |        y1="-92.613281" | ||||||
|  |        x2="224" | ||||||
|  |        y2="228.13672" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="translate(-7,822.68216)" /> | ||||||
|  |   </defs> | ||||||
|   <sodipodi:namedview |   <sodipodi:namedview | ||||||
|      id="base" |      id="base" | ||||||
|      pagecolor="#ffffff" |      pagecolor="#ffffff" | ||||||
| @@ -28,9 +364,9 @@ | |||||||
|      borderopacity="1.0" |      borderopacity="1.0" | ||||||
|      inkscape:pageopacity="0.0" |      inkscape:pageopacity="0.0" | ||||||
|      inkscape:pageshadow="2" |      inkscape:pageshadow="2" | ||||||
|      inkscape:zoom="0.35" |      inkscape:zoom="1" | ||||||
|      inkscape:cx="-602.14286" |      inkscape:cx="228.5498" | ||||||
|      inkscape:cy="520" |      inkscape:cy="137.07133" | ||||||
|      inkscape:document-units="px" |      inkscape:document-units="px" | ||||||
|      inkscape:current-layer="layer1" |      inkscape:current-layer="layer1" | ||||||
|      showgrid="false" |      showgrid="false" | ||||||
| @@ -48,7 +384,7 @@ | |||||||
|         <dc:format>image/svg+xml</dc:format> |         <dc:format>image/svg+xml</dc:format> | ||||||
|         <dc:type |         <dc:type | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
|         <dc:title /> |         <dc:title></dc:title> | ||||||
|       </cc:Work> |       </cc:Work> | ||||||
|     </rdf:RDF> |     </rdf:RDF> | ||||||
|   </metadata> |   </metadata> | ||||||
| @@ -56,23 +392,33 @@ | |||||||
|      inkscape:label="Ebene 1" |      inkscape:label="Ebene 1" | ||||||
|      inkscape:groupmode="layer" |      inkscape:groupmode="layer" | ||||||
|      id="layer1" |      id="layer1" | ||||||
|      transform="translate(0,-540.36216)"> |      transform="translate(0,-796.36216)"> | ||||||
|  |     <g | ||||||
|  |        id="g4508" | ||||||
|  |        inkscape:export-filename="C:\Users\chrig\Abit2.png" | ||||||
|  |        inkscape:export-xdpi="602.35297" | ||||||
|  |        inkscape:export-ydpi="602.35297"> | ||||||
|       <path |       <path | ||||||
|        sodipodi:type="star" |          sodipodi:nodetypes="sssssssss" | ||||||
|        style="opacity:1;fill:#ffcc00;fill-opacity:1;stroke:none;stroke-width:4;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" |          style="fill:#819ba8;fill-opacity:1;filter:url(#filter4346)" | ||||||
|        id="path3343" |          inkscape:connector-curvature="0" | ||||||
|        sodipodi:sides="7" |          d="m 230.00001,827.68211 -204.000009,0 c -14.1525,0 -25.5,11.3475 -25.5,25.5 l 0,152.99999 c -5.523e-5,14.0833 11.4167,25.5001 25.5,25.5001 l 204.000009,0 c 14.0833,0 25.50005,-11.4168 25.49999,-25.5001 l 0,-152.99999 c 0,-14.1525 -11.47499,-25.5 -25.49999,-25.5 z" | ||||||
|        sodipodi:cx="254.65251" |          id="path4226" /> | ||||||
|        sodipodi:cy="795.56248" |       <path | ||||||
|        sodipodi:r1="231.12856" |          id="path4435" | ||||||
|        sodipodi:r2="76.300064" |          d="m 26,827.68216 c -14.1525,0 -25.5,11.3475 -25.5,25.5 l 0,1.21289 127.5,79.6875 127.5,-79.6875 0,-1.21289 c 0,-14.1525 -11.475,-25.5 -25.5,-25.5 l -204,0 z" | ||||||
|        sodipodi:arg1="-1.4219063" |          style="fill:#607d8b;fill-opacity:1;filter:url(#filter4346)" | ||||||
|        sodipodi:arg2="-0.97310738" |          inkscape:connector-curvature="0" /> | ||||||
|        inkscape:flatsided="false" |       <path | ||||||
|        inkscape:rounded="1.39" |          id="path4456" | ||||||
|        inkscape:randomized="0" |          d="M 84.9375,845.9556 C 99.46494,905.00376 49.357218,869.16386 30,929.84622 c 0,2.61651 1.051586,4.98591 2.755859,6.71094 0.04073,0.0412 52.392395,52.39156 95.126951,95.12504 l 102.11719,0 c 10.99514,0 20.36483,-6.9593 23.94531,-16.7129 C 197.53224,958.55338 85.073657,846.08936 84.9375,845.9556 Z" | ||||||
|        d="m 288.93824,566.99107 c 227.8089,34.17135 -181.77145,35.86897 8.65088,165.49887 190.42233,129.6299 41.82424,-252.04738 157.14453,-52.63373 C 570.05394,879.26986 313.35752,560.1055 330.73516,789.8066 348.1128,1019.5077 553.87073,665.35713 469.86388,879.85055 385.85704,1094.344 475.34218,694.65489 306.58941,851.45756 137.83665,1008.2602 543.01068,948.319 322.93556,1016.3743 102.86045,1084.4295 471.14302,905.18976 243.33412,871.01841 15.525224,836.84705 315.01104,1116.2521 124.58871,986.62222 -65.833623,856.99233 303.92209,1033.1731 188.60181,833.75941 73.281523,634.34576 41.560203,1042.6994 24.182553,812.99831 6.804904,583.29722 99.600168,982.23077 183.60702,767.73737 267.61388,553.24396 -71.427781,783.04756 97.324978,626.24488 266.07773,469.4422 12.035822,790.72346 232.11094,722.66821 452.18606,654.61296 61.129346,532.81973 288.93824,566.99107 Z" |          style="opacity:0.70099996;fill:url(#linearGradient4481);fill-opacity:1" | ||||||
|        inkscape:transform-center-x="-12.36068" |          inkscape:connector-curvature="0" /> | ||||||
|        inkscape:transform-center-y="-11.435089" /> |       <path | ||||||
|  |          style="fill:#ffc107;fill-opacity:1;filter:url(#filter4346)" | ||||||
|  |          inkscape:connector-curvature="0" | ||||||
|  |          d="m 68.204082,915.51889 a 9.5510204,9.5510204 0 0 0 9.55102,-9.55102 c 0,-5.30081 -4.297959,-9.55102 -9.55102,-9.55102 a 9.5510204,9.5510204 0 0 0 -9.551021,9.55102 9.5510204,9.5510204 0 0 0 9.551021,9.55102 M 96.85714,872.5393 a 9.5510204,9.5510204 0 0 1 9.55102,9.55102 l 0,47.7551 a 9.5510204,9.5510204 0 0 1 -9.55102,9.55102 l -57.30612,0 A 9.5510204,9.5510204 0 0 1 30,929.84542 l 0,-47.7551 c 0,-5.30081 4.297959,-9.55102 9.55102,-9.55102 l 4.775511,0 0,-9.55102 a 23.877551,23.877551 0 0 1 23.877551,-23.87755 23.877551,23.877551 0 0 1 23.877551,23.87755 l 0,9.55102 4.775507,0 M 68.204082,848.66175 a 14.326531,14.326531 0 0 0 -14.326531,14.32653 l 0,9.55102 28.653061,0 0,-9.55102 a 14.326531,14.326531 0 0 0 -14.32653,-14.32653 z" | ||||||
|  |          id="path4160" /> | ||||||
|  |     </g> | ||||||
|   </g> |   </g> | ||||||
| </svg> | </svg> | ||||||
|   | |||||||
| Before Width: | Height: | Size: 3.2 KiB After Width: | Height: | Size: 13 KiB |