Browse Source

first commit

d0c 1 year ago
commit
22ed355e69

+ 62 - 0
.gitignore

@@ -0,0 +1,62 @@
+db.sqlite3
+
+# ---> Python
+# Byte-compiled / optimized / DLL files
+__pycache__/
+*.py[cod]
+*$py.class
+
+# C extensions
+*.so
+
+# Distribution / packaging
+.Python
+env/
+build/
+develop-eggs/
+dist/
+downloads/
+eggs/
+.eggs/
+lib/
+lib64/
+parts/
+sdist/
+var/
+*.egg-info/
+.installed.cfg
+*.egg
+
+# PyInstaller
+#  Usually these files are written by a python script from a template
+#  before PyInstaller builds the exe, so as to inject date/other infos into it.
+*.manifest
+*.spec
+
+# Installer logs
+pip-log.txt
+pip-delete-this-directory.txt
+
+# Unit test / coverage reports
+htmlcov/
+.tox/
+.coverage
+.coverage.*
+.cache
+nosetests.xml
+coverage.xml
+*,cover
+
+# Translations
+*.mo
+*.pot
+
+# Django stuff:
+*.log
+
+# Sphinx documentation
+docs/_build/
+
+# PyBuilder
+target/
+

+ 17 - 0
Readme.md

@@ -0,0 +1,17 @@
+# Suitable Phones
+
+## Setup
+
+Clone this repository.
+
+Download Lineage official wiki as data source:
+
+```
+git clone https://github.com/LineageOS/lineage_wiki.git
+```
+
+Yaml file descripting all devices are in _"lineage_wiki/_data/devices/"_
+
+Set the proper path in var _LINEAGEWIKI_
+
+TODO: choose where to set _LINEAGEWIKI_

+ 22 - 0
manage.py

@@ -0,0 +1,22 @@
+#!/usr/bin/env python
+"""Django's command-line utility for administrative tasks."""
+import os
+import sys
+
+
+def main():
+    """Run administrative tasks."""
+    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'mysuitablephone.settings')
+    try:
+        from django.core.management import execute_from_command_line
+    except ImportError as exc:
+        raise ImportError(
+            "Couldn't import Django. Are you sure it's installed and "
+            "available on your PYTHONPATH environment variable? Did you "
+            "forget to activate a virtual environment?"
+        ) from exc
+    execute_from_command_line(sys.argv)
+
+
+if __name__ == '__main__':
+    main()

+ 0 - 0
mysuitablephone/__init__.py


+ 16 - 0
mysuitablephone/asgi.py

@@ -0,0 +1,16 @@
+"""
+ASGI config for mysuitablephone project.
+
+It exposes the ASGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/howto/deployment/asgi/
+"""
+
+import os
+
+from django.core.asgi import get_asgi_application
+
+os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'mysuitablephone.settings')
+
+application = get_asgi_application()

+ 124 - 0
mysuitablephone/settings.py

@@ -0,0 +1,124 @@
+"""
+Django settings for mysuitablephone project.
+
+Generated by 'django-admin startproject' using Django 4.1.4.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/topics/settings/
+
+For the full list of settings and their values, see
+https://docs.djangoproject.com/en/4.1/ref/settings/
+"""
+
+from pathlib import Path
+
+# Build paths inside the project like this: BASE_DIR / 'subdir'.
+BASE_DIR = Path(__file__).resolve().parent.parent
+
+
+# Quick-start development settings - unsuitable for production
+# See https://docs.djangoproject.com/en/4.1/howto/deployment/checklist/
+
+# SECURITY WARNING: keep the secret key used in production secret!
+SECRET_KEY = 'django-insecure-+$i2ntzli6&4!d7#n9kidpmd8-#02eem(7%jvn@+##4^$=yci%'
+
+# SECURITY WARNING: don't run with debug turned on in production!
+DEBUG = True
+
+ALLOWED_HOSTS = []
+
+
+# Application definition
+
+INSTALLED_APPS = [
+    'django.contrib.admin',
+    'django.contrib.auth',
+    'django.contrib.contenttypes',
+    'django.contrib.sessions',
+    'django.contrib.messages',
+    'django.contrib.staticfiles',
+    'suitablephones',
+]
+
+MIDDLEWARE = [
+    'django.middleware.security.SecurityMiddleware',
+    'django.contrib.sessions.middleware.SessionMiddleware',
+    'django.middleware.common.CommonMiddleware',
+    'django.middleware.csrf.CsrfViewMiddleware',
+    'django.contrib.auth.middleware.AuthenticationMiddleware',
+    'django.contrib.messages.middleware.MessageMiddleware',
+    'django.middleware.clickjacking.XFrameOptionsMiddleware',
+]
+
+ROOT_URLCONF = 'mysuitablephone.urls'
+
+TEMPLATES = [
+    {
+        'BACKEND': 'django.template.backends.django.DjangoTemplates',
+        'DIRS': [],
+        'APP_DIRS': True,
+        'OPTIONS': {
+            'context_processors': [
+                'django.template.context_processors.debug',
+                'django.template.context_processors.request',
+                'django.contrib.auth.context_processors.auth',
+                'django.contrib.messages.context_processors.messages',
+            ],
+        },
+    },
+]
+
+WSGI_APPLICATION = 'mysuitablephone.wsgi.application'
+
+
+# Database
+# https://docs.djangoproject.com/en/4.1/ref/settings/#databases
+
+DATABASES = {
+    'default': {
+        'ENGINE': 'django.db.backends.sqlite3',
+        'NAME': BASE_DIR / 'db.sqlite3',
+    }
+}
+
+
+# Password validation
+# https://docs.djangoproject.com/en/4.1/ref/settings/#auth-password-validators
+
+AUTH_PASSWORD_VALIDATORS = [
+    {
+        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
+    },
+    {
+        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
+    },
+    {
+        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
+    },
+    {
+        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
+    },
+]
+
+
+# Internationalization
+# https://docs.djangoproject.com/en/4.1/topics/i18n/
+
+LANGUAGE_CODE = 'en-us'
+
+TIME_ZONE = 'UTC'
+
+USE_I18N = True
+
+USE_TZ = True
+
+
+# Static files (CSS, JavaScript, Images)
+# https://docs.djangoproject.com/en/4.1/howto/static-files/
+
+STATIC_URL = 'static/'
+
+# Default primary key field type
+# https://docs.djangoproject.com/en/4.1/ref/settings/#default-auto-field
+
+DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'

+ 23 - 0
mysuitablephone/urls.py

@@ -0,0 +1,23 @@
+"""mysuitablephone URL Configuration
+
+The `urlpatterns` list routes URLs to views. For more information please see:
+    https://docs.djangoproject.com/en/4.1/topics/http/urls/
+Examples:
+Function views
+    1. Add an import:  from my_app import views
+    2. Add a URL to urlpatterns:  path('', views.home, name='home')
+Class-based views
+    1. Add an import:  from other_app.views import Home
+    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
+Including another URLconf
+    1. Import the include() function: from django.urls import include, path
+    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
+"""
+from django.contrib import admin
+from django.urls import include, path
+
+urlpatterns = [
+    path('', include('suitablephones.urls')),
+    path('admin/', admin.site.urls),
+]
+

+ 16 - 0
mysuitablephone/wsgi.py

@@ -0,0 +1,16 @@
+"""
+WSGI config for mysuitablephone project.
+
+It exposes the WSGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/4.1/howto/deployment/wsgi/
+"""
+
+import os
+
+from django.core.wsgi import get_wsgi_application
+
+os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'mysuitablephone.settings')
+
+application = get_wsgi_application()

+ 0 - 0
suitablephones/__init__.py


+ 3 - 0
suitablephones/admin.py

@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.

+ 6 - 0
suitablephones/apps.py

@@ -0,0 +1,6 @@
+from django.apps import AppConfig
+
+
+class SuitablephonesConfig(AppConfig):
+    default_auto_field = 'django.db.models.BigAutoField'
+    name = 'suitablephones'

+ 23 - 0
suitablephones/fetchphones.py

@@ -0,0 +1,23 @@
+import yaml
+import json
+
+LINEAGEWIKI = '/home/d0c/Code/lineage_wiki'
+
+with open(LINEAGEWIKI+"/_data/devices/surnia.yml", "r") as stream:
+    try:
+        data=yaml.safe_load(stream)
+        #print(type(data))
+        for i in data.keys():
+            value=data[i]
+            print(i, " = ", type(value))
+           # if isinstance(value, (list, dict)):
+           #     print(value)
+        ##print(json.dumps(data, sort_keys=True, indent=4))
+    except yaml.YAMLError as exc:
+        print(exc)
+
+## create instance of model
+# m = MyModel(**data_dict)
+# don't forget to save to database!
+# m.save()
+#

+ 0 - 0
suitablephones/migrations/__init__.py


+ 40 - 0
suitablephones/models.py

@@ -0,0 +1,40 @@
+from django.db import models
+
+# Create your models here.
+
+class Device(models.Model):
+    #battery  =  <class 'dict'>
+    architecture  = models.CharField(max_length=100)
+    #before_install  =  <class 'dict'>
+    #bluetooth  =  <class 'dict'>
+    #cameras  =  <class 'list'>
+    cpu  = models.CharField(max_length=100)
+    codename  = models.CharField(max_length=100)
+    cpu_cores  = models.CharField(max_length=100)
+    cpu_freq  = models.CharField(max_length=100)
+    #current_branch  =  <class 'float'>
+    download_boot  = models.CharField(max_length=100)
+    dimensions  = models.CharField(max_length=100)
+    gpu  = models.CharField(max_length=100)
+    image  = models.CharField(max_length=100)
+    install_method  = models.CharField(max_length=100)
+    kernel  = models.CharField(max_length=100)
+    #maintainers  =  <class 'list'>
+    #models  =  <class 'list'>
+    #peripherals  =  <class 'list'>
+    name  = models.CharField(max_length=100)
+    recovery_boot  = models.CharField(max_length=100)
+    ram  = models.CharField(max_length=100)
+    recovery_reboot  = models.CharField(max_length=100)
+    release  = models.CharField(max_length=100)
+    #screen  =  <class 'dict'>
+    #sdcard  =  <class 'dict'>
+    storage  = models.CharField(max_length=100)
+    soc  = models.CharField(max_length=100)
+    tree  = models.CharField(max_length=100)
+    type  = models.CharField(max_length=100)
+    vendor  = models.CharField(max_length=100)
+    vendor_short  = models.CharField(max_length=100)
+    #versions  =  <class 'list'>
+    
+    wifi  = models.CharField(max_length=100)

+ 3 - 0
suitablephones/tests.py

@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.

+ 7 - 0
suitablephones/urls.py

@@ -0,0 +1,7 @@
+from django.urls import path
+from . import views
+
+urlpatterns = [
+    path('suitablephones/', views.suitablephones, name='suitablephones'),
+]
+

+ 5 - 0
suitablephones/views.py

@@ -0,0 +1,5 @@
+from django.shortcuts import render
+from django.http import HttpResponse
+
+def suitablephones(request):
+    return HttpResponse("These are suitable phones")