Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/themihel/design-pattern-analysis-app
Android app infrastructure for observing various web applications. For example mimicking a special app to get insights how users are using it. Especially interesting for the usage of design patterns.
https://github.com/themihel/design-pattern-analysis-app
android design-patterns observational-study
Last synced: 29 days ago
JSON representation
Android app infrastructure for observing various web applications. For example mimicking a special app to get insights how users are using it. Especially interesting for the usage of design patterns.
- Host: GitHub
- URL: https://github.com/themihel/design-pattern-analysis-app
- Owner: themihel
- License: mit
- Created: 2020-09-07T20:48:11.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2021-11-09T19:12:33.000Z (about 3 years ago)
- Last Synced: 2024-10-26T17:22:01.240Z (3 months ago)
- Topics: android, design-patterns, observational-study
- Language: Java
- Homepage:
- Size: 163 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Design Pattern Analysis - App
Corresponding server: https://github.com/themihel/Design-Pattern-Analysis-ServerPaper: https://dl.acm.org/doi/10.1145/3473856.3473987
## Background
Background of this repository is a framework to give researchers the opportunity to have a look into closed source apps using their, mostly present, web app.
It is possible to run different tests, like turning specific design patterns on or off. Any change using the functionality of Javascript and CSS is possible.
Also you can track different groups to construct a study based on your need. Furthermore this platform can be used for any other field study using own content.## Adaptions to be done
To get the app up and running for you study participants some adaptions need to be done. Mainly they're located in the MainActivity.
For this reason the constants of this class and their respective usage will be explained in the following:`GROUP`: The group is used to get specific scripts and styles from the server. At current state the app needs to be build for every group separately.
`MODIFICATIONS_BASE_URL`: This URL specifies your server based on the other repo. The GROUP constant should be used to differentiate the groups from each other.
`MODIFICATION_VERSION_POSITION`: This integer specifies where the modification version in the script (delivered by the corresponding server) is located. If no code changes were made *before* the version constant in the JS file, no adaption is needed here. (Default: 12)
`TRACK_URL`: This URL is used to point at the server your data will be tracked. If you're using the provided server, `trackaction` is the way to go.
`USER_AGENT`: The user agent in the POST request to the tracking server may be adapted to your needs. (Default: Design-Pattern-Analysis-App)
`PLATFORM_URL`: This URL specifies the website which should be tracked. Also this is used to prevent opening any incoming links on the device from opening the original app.
`PLATFORM_PROTOCOL`: This is used to set the protocol of the tracked platform. In most cases 'https://' will be fine.
### Additional scripts or styles
If any additional scripts or styles are needed for any group and any version, you can consider putting the into the app to safe bandwidth. For example jQuery is included which makes it possible to easily access specific elements and modifying them.
But you can add anything you want here. Relevant code position: `MainActivity:87`.## Any question?
Feel free to contact me.