Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
58f69e7f
Commit
58f69e7f
authored
Feb 26, 2016
by
Devon Carew
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2211 from devoncarew/flx_times
add timing info for flx creation
parents
e843d9d0
9c9bda23
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
18 additions
and
9 deletions
+18
-9
run.dart
packages/flutter_tools/lib/src/commands/run.dart
+1
-1
flx.dart
packages/flutter_tools/lib/src/flx.dart
+6
-2
bundle.dart
packages/flx/lib/bundle.dart
+1
-1
signing.dart
packages/flx/lib/signing.dart
+9
-4
signing_test.dart
packages/flx/test/signing_test.dart
+1
-1
No files found.
packages/flutter_tools/lib/src/commands/run.dart
View file @
58f69e7f
...
@@ -128,7 +128,7 @@ class RunCommand extends RunCommandBase {
...
@@ -128,7 +128,7 @@ class RunCommand extends RunCommandBase {
debugPort:
debugPort
debugPort:
debugPort
);
);
printTrace
(
'Finished
start
command.'
);
printTrace
(
'Finished
$name
command.'
);
return
result
;
return
result
;
}
}
}
}
...
...
packages/flutter_tools/lib/src/flx.dart
View file @
58f69e7f
...
@@ -256,7 +256,7 @@ Future<int> build(
...
@@ -256,7 +256,7 @@ Future<int> build(
Future
<
int
>
assemble
({
Future
<
int
>
assemble
({
Map
manifestDescriptor:
const
{},
Map
manifestDescriptor:
const
{},
ArchiveFile
snapshotFile
:
null
,
ArchiveFile
snapshotFile
,
String
assetBasePath:
defaultAssetBasePath
,
String
assetBasePath:
defaultAssetBasePath
,
String
materialAssetBasePath:
defaultMaterialAssetBasePath
,
String
materialAssetBasePath:
defaultMaterialAssetBasePath
,
String
outputPath:
defaultFlxOutputPath
,
String
outputPath:
defaultFlxOutputPath
,
...
@@ -287,11 +287,15 @@ Future<int> assemble({
...
@@ -287,11 +287,15 @@ Future<int> assemble({
if
(
fontManifest
!=
null
)
if
(
fontManifest
!=
null
)
archive
.
addFile
(
fontManifest
);
archive
.
addFile
(
fontManifest
);
await
CipherParameters
.
get
().
seedRandom
();
printTrace
(
'Calling CipherParameters.seedRandom().'
);
CipherParameters
.
get
().
seedRandom
();
AsymmetricKeyPair
keyPair
=
keyPairFromPrivateKeyFileSync
(
privateKeyPath
);
AsymmetricKeyPair
keyPair
=
keyPairFromPrivateKeyFileSync
(
privateKeyPath
);
printTrace
(
'KeyPair from
$privateKeyPath
:
$keyPair
.'
);
printTrace
(
'Encoding zip file.'
);
Uint8List
zipBytes
=
new
Uint8List
.
fromList
(
new
ZipEncoder
().
encode
(
archive
));
Uint8List
zipBytes
=
new
Uint8List
.
fromList
(
new
ZipEncoder
().
encode
(
archive
));
ensureDirectoryExists
(
outputPath
);
ensureDirectoryExists
(
outputPath
);
printTrace
(
'Creating flx at
$outputPath
.'
);
Bundle
bundle
=
new
Bundle
.
fromContent
(
Bundle
bundle
=
new
Bundle
.
fromContent
(
path:
outputPath
,
path:
outputPath
,
manifest:
manifestDescriptor
,
manifest:
manifestDescriptor
,
...
...
packages/flx/lib/bundle.dart
View file @
58f69e7f
...
@@ -72,7 +72,7 @@ class Bundle {
...
@@ -72,7 +72,7 @@ class Bundle {
this
.
path
,
this
.
path
,
this
.
manifest
,
this
.
manifest
,
contentBytes
,
contentBytes
,
AsymmetricKeyPair
keyPair
:
null
AsymmetricKeyPair
keyPair
})
:
_contentBytes
=
contentBytes
{
})
:
_contentBytes
=
contentBytes
{
assert
(
path
!=
null
);
assert
(
path
!=
null
);
assert
(
manifest
!=
null
);
assert
(
manifest
!=
null
);
...
...
packages/flx/lib/signing.dart
View file @
58f69e7f
...
@@ -20,6 +20,7 @@ class CipherParameters {
...
@@ -20,6 +20,7 @@ class CipherParameters {
final
String
signerAlgorithm
=
'SHA-256/ECDSA'
;
final
String
signerAlgorithm
=
'SHA-256/ECDSA'
;
final
String
hashAlgorithm
=
'SHA-256'
;
final
String
hashAlgorithm
=
'SHA-256'
;
final
ECDomainParameters
domain
=
new
ECDomainParameters
(
'prime256v1'
);
final
ECDomainParameters
domain
=
new
ECDomainParameters
(
'prime256v1'
);
SecureRandom
get
random
{
SecureRandom
get
random
{
if
(
_random
==
null
)
if
(
_random
==
null
)
_initRandom
(
new
Uint8List
(
16
),
new
Uint8List
(
16
));
_initRandom
(
new
Uint8List
(
16
),
new
Uint8List
(
16
));
...
@@ -29,12 +30,16 @@ class CipherParameters {
...
@@ -29,12 +30,16 @@ class CipherParameters {
// Seeds our secure random number generator using data from /dev/urandom.
// Seeds our secure random number generator using data from /dev/urandom.
// Disclaimer: I don't really understand why we need 2 parameters for
// Disclaimer: I don't really understand why we need 2 parameters for
// pointycastle's API.
// pointycastle's API.
Future
seedRandom
()
async
{
void
seedRandom
()
{
if
(
_random
!=
null
)
return
;
try
{
try
{
RandomAccessFile
file
=
await
new
File
(
"/dev/urandom"
).
open
();
RandomAccessFile
file
=
new
File
(
"/dev/urandom"
).
openSync
();
Uint8List
key
=
new
Uint8List
.
fromList
(
await
file
.
read
(
16
));
Uint8List
key
=
new
Uint8List
.
fromList
(
file
.
readSync
(
16
));
Uint8List
iv
=
new
Uint8List
.
fromList
(
await
file
.
read
(
16
));
Uint8List
iv
=
new
Uint8List
.
fromList
(
file
.
readSync
(
16
));
_initRandom
(
key
,
iv
);
_initRandom
(
key
,
iv
);
file
.
closeSync
();
}
on
FileSystemException
{
}
on
FileSystemException
{
// TODO(mpcomplete): need an entropy source on Windows. We might get this
// TODO(mpcomplete): need an entropy source on Windows. We might get this
// for free from Dart itself soon.
// for free from Dart itself soon.
...
...
packages/flx/test/signing_test.dart
View file @
58f69e7f
...
@@ -34,7 +34,7 @@ main() async {
...
@@ -34,7 +34,7 @@ main() async {
// Set up a key generator.
// Set up a key generator.
CipherParameters
cipher
=
CipherParameters
.
get
();
CipherParameters
cipher
=
CipherParameters
.
get
();
await
cipher
.
seedRandom
();
cipher
.
seedRandom
();
ECKeyGeneratorParameters
ecParams
=
new
ECKeyGeneratorParameters
(
cipher
.
domain
);
ECKeyGeneratorParameters
ecParams
=
new
ECKeyGeneratorParameters
(
cipher
.
domain
);
ParametersWithRandom
<
ECKeyGeneratorParameters
>
keyGeneratorParams
=
ParametersWithRandom
<
ECKeyGeneratorParameters
>
keyGeneratorParams
=
new
ParametersWithRandom
<
ECKeyGeneratorParameters
>(
ecParams
,
cipher
.
random
);
new
ParametersWithRandom
<
ECKeyGeneratorParameters
>(
ecParams
,
cipher
.
random
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment