android-simple-storage


Source link: https://github.com/sromku/android-simple-storage

android-storage

Library to create, read, delete, append, encrypt files and more, on internal or external disk spaces with a really simple API.

Latest Release

dependencies {

  compile 'com.snatik:storage:2.1.0' 
}

Don't forget to update AndroidManifest.xml and add next line:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

Usage

// init Storage storage = new Storage(getApplicationContext());
  // get external storage String path = storage.getExternalStorageDirectory();
  // new dir String newDir = path + File.separator + "My Sample Directory"; storage.createDirectory(newDir);

Check all options, scroll down ;)

Sample app

The app has some simple UI screens and uses the storage library. This is just an example of what can be done with this lib.

Options

Initialize

Storage storage = new Storage(getApplicationContext());
 

Work on External Storage.

  • Check if external writable

     boolean isWritable = storage.isExternalWritable();
    
  • Root external storage path

     String path = storage.getExternalStorageDirectory();
    
  • If you want to use a particular public directory

    Storage storage = SimpleStorage.getExternalStorage(Environment.DIRECTORY_PICTURES);
    

Work on Internal Storage.

  • Directory for storing app internal files ( documentation):

     String path = SimpleStorage.getInternalFilesDirectory();
    
  • Cache dir

     String path = SimpleStorage.getInternalCacheDirectory();
    
  • Root internal storage dir

     String path = SimpleStorage.getInternalRootDirectory();
    

Create directory

  • Create directory

     storage.createDirectory(path);
    
  • Create directory and override the existing one.

     storage.createDirectory(path, true);
    

Create file

Create a new file with the content in it.

storage.createFile(path, "some content of the file");

The content of the file can be one of the next types:

  • String
  • byte[]
  • Bitmap
  • Storable

Read file

Read the content of any file to byte array.

byte[] bytes = storage.readFile(path);

Read the content of the file to String.

String content = storage.readTextFile(path);

Append content to file

storage.appendFile(path, "more new data");

You can append:

  • String
  • byte[]

Copy

storage.copy(fromPath, toPath);

Move

storage.move(fromPath, toPath);

Delete directory

storage.deleteDirectory(path);

Delete file

storage.deleteFile(path);

Get files

  • Get files in ordered way by: name, date, size

     List<File> files = storage.getFiles(path, OrderType.DATE);
    
  • Get files and filter by regular expression:

     String regex = ...;  List<File> files = storage.getFiles(path, regex);
    
  • Get all nested files (without the directories)
     List<File> files = storage.getNestedFiles(path);
    

More...

  • Is directory exists

     boolean dirExists = storage.isDirectoryExists(path);
    
  • Is file exists

     boolean fileExists = storage.isFileExist(path);
    

Security configuration

You can write and read files while the content is encrypted. It means, that no one can read the data of your files from external or internal storage.

You will continue using the same api as before. The only thing you need to do is to configure the Simple Storage library before the you want to create/read encrypted data.

// set encryption String IVX = "abcdefghijklmnop"; // 16 lenght - not secret String SECRET_KEY = "secret1234567890"; // 16 lenght - secret byte[] SALT = "0000111100001111".getBytes();
 // random 16 bytes array  // build configuratio EncryptConfiguration configuration = new EncryptConfiguration.Builder()  .setEncryptContent(IVX, SECRET_KEY, SALT)  .build();

// configure the simple storage storage.setEncryptConfiguration(configuration);

Now, you can create a new file with content and the content will be automatically encrypted.
You can read the file and the content will be decrypted.

Example

Create file with next content "this is the secret data":

storage.setEncryptConfiguration(configuration);
 storage.createFile(path, "this is the secret data");

If we open the file to see it's content then it we will something like this: „f°α?ΤG†_i??p . It looks good :)

And now, read the file data with the same api:

storage.setEncryptConfiguration(configuration);
 String content = storage.readTextFile(path);

You will see that the content will be: "this is the secret data".

Tests

Just play and check the sample app ;)

Follow us

Resources

Epoxy is an Android library for building complex screens in a RecyclerView. It abstracts the boilerplate of view holders, item types, item ids, span counts, and more, in order to simplify building screens with multiple view types. Additionally, Epoxy adds support for saving view state and automatic diffing of item changes.

Tiger - the fastest java dependency injection framework.

A SharedPreferences wrapper for Android that encrypts the content with 256 bit AES encryption. The Encryption key is securely stored in device's KeyStore. You can also use the EncryptionManager to encrypt/decrypt data out of the box.

An example project which imitates Liulishuo guide view.

A light Android library containing code to work with RecyclerViews and ViewGroups which is usually copy-pasted across projects.

Simple PriceView that can be used to represent any prices in Russian rouble currency. Library uses RobotoTextView as text presenter.

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes