mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-01 07:01:12 +00:00
Add secret key generator
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -12,4 +12,4 @@ thirdpart/site.*
|
|||||||
restart.sh
|
restart.sh
|
||||||
settings.py.mysql
|
settings.py.mysql
|
||||||
settings.py.sqlite
|
settings.py.sqlite
|
||||||
|
secret_key.py
|
||||||
|
30
secret_key_generator.py
Normal file
30
secret_key_generator.py
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# encoding: utf-8
|
||||||
|
|
||||||
|
from hashlib import md5, sha1
|
||||||
|
from base64 import urlsafe_b64encode as b64encode
|
||||||
|
import random
|
||||||
|
random.seed()
|
||||||
|
|
||||||
|
def random_string():
|
||||||
|
"""
|
||||||
|
Generate a random string (currently a random number as a string)
|
||||||
|
"""
|
||||||
|
return str(random.randint(0,100000))
|
||||||
|
|
||||||
|
def generate_key(max_length, data, encoder=b64encode, digester=md5):
|
||||||
|
"""
|
||||||
|
Generate a Base64-encoded 'random' key by hashing the data.
|
||||||
|
data is a tuple of seeding values. Pass arbitrary encoder and
|
||||||
|
digester for specific hashing and formatting of keys
|
||||||
|
"""
|
||||||
|
base = ''
|
||||||
|
for arg in data:
|
||||||
|
base += str(arg)
|
||||||
|
key = encoder(digester(base).digest())
|
||||||
|
return key[:max_length]
|
||||||
|
|
||||||
|
def generate_secret_key(file_name):
|
||||||
|
f = open(file_name, 'w')
|
||||||
|
f.write("SECRET_KEY = '%s'" % generate_key(40, (random_string(),)))
|
||||||
|
f.close()
|
@@ -235,3 +235,11 @@ else:
|
|||||||
LOGIN_URL = SITE_ROOT + 'accounts/login'
|
LOGIN_URL = SITE_ROOT + 'accounts/login'
|
||||||
|
|
||||||
SEAFILE_VERSION = '0.9.4'
|
SEAFILE_VERSION = '0.9.4'
|
||||||
|
|
||||||
|
try:
|
||||||
|
from secret_key import *
|
||||||
|
except ImportError:
|
||||||
|
SETTINGS_DIR = os.path.abspath(os.path.dirname(__file__))
|
||||||
|
from secret_key_generator import generate_secret_key
|
||||||
|
generate_secret_key(os.path.join(SETTINGS_DIR, 'secret_key.py'))
|
||||||
|
from secret_key import *
|
||||||
|
8
utils.py
8
utils.py
@@ -1,11 +1,10 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
# encoding: utf-8
|
# encoding: utf-8
|
||||||
import settings
|
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import time
|
import time
|
||||||
import os
|
|
||||||
import stat
|
import stat
|
||||||
|
|
||||||
from django.shortcuts import render_to_response
|
from django.shortcuts import render_to_response
|
||||||
from django.template import RequestContext
|
from django.template import RequestContext
|
||||||
from django.utils.hashcompat import sha_constructor
|
from django.utils.hashcompat import sha_constructor
|
||||||
@@ -15,12 +14,11 @@ from django.core.cache import cache
|
|||||||
|
|
||||||
from seaserv import seafserv_rpc, ccnet_threaded_rpc, seafserv_threaded_rpc, \
|
from seaserv import seafserv_rpc, ccnet_threaded_rpc, seafserv_threaded_rpc, \
|
||||||
get_repo, get_commits, get_group_repoids
|
get_repo, get_commits, get_group_repoids
|
||||||
|
|
||||||
EMPTY_SHA1 = '0000000000000000000000000000000000000000'
|
|
||||||
|
|
||||||
import settings
|
import settings
|
||||||
from settings import PREVIEW_FILEEXT
|
from settings import PREVIEW_FILEEXT
|
||||||
|
|
||||||
|
EMPTY_SHA1 = '0000000000000000000000000000000000000000'
|
||||||
|
|
||||||
def go_permission_error(request, msg=None):
|
def go_permission_error(request, msg=None):
|
||||||
"""
|
"""
|
||||||
Return permisson error page.
|
Return permisson error page.
|
||||||
|
Reference in New Issue
Block a user